Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp708250pxj; Wed, 16 Jun 2021 11:41:31 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyYsGbN5tMY3dynP20Qr6aP2EL4IfHciwifV3R+Mdd0ggRuWJEKvyK4myEQJciDRH2LCG5y X-Received: by 2002:aa7:dd81:: with SMTP id g1mr1382833edv.274.1623868891358; Wed, 16 Jun 2021 11:41:31 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1623868891; cv=none; d=google.com; s=arc-20160816; b=BzHTNaDUKKlvKl8JlqFw+h+LUPqKxUgWXpnX7QForH4dNBcWvRmBgMQd38wRRmOWhf G24g7VNvtFUFvODVcxJXs+1joXoP9xoIvIIH1cd0EGyHurt4cYmFWbqgHwAm5V4e8qA8 Hy1Au+cX2do81VlhE2j/GFJNk8pOQj9jnKJUKWZJP67jVe0ziXF23Ij1V1KixHblGTyh leR05JnRL52FTNvbdIGbid/nrqkGv0IhSKjYpPaTE8BR+iXnxyYCMhq1r1xWqKfTAT8G nsbqhSGJVsTW28pznqNtE11Y3MZJDXYqLJKmEKKu6URRU8uz9pUoXMWHUL5svVSiptT8 cuwQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature; bh=2jLSVmuLw4Nb055fI6F5c4n6Y22HkMR7OQfqkvuCNLI=; b=emu2uX8cW3TmE6S24JsSJ4RjvtqbWoIKZDbHZsneHHtfhlsJDETdNhoYp1KJdMf4oC EsZCsvds7xirjqfcw6TbFk6CNFduBF9YPNwYkClZXG8VENOh6plOG7uri+ef//+rfdGL 7dIX5Q/qtqZ2oOYu/YvKEgHzZSDaytjhN4uS6C/A7Uya5Cv6wmYArGl6n9fQumKfjjhP WiKZZUk/jnaqgBtKGINCBey3MBvkWrGgIZJ48apObxxp8ODX/E2emGmApi39hMsCoYOQ SZf1DP1xnwmJIQq/txNw27dHOMW1RC6P6W4kPc+KngdLwSiqEUdhgsQEQhjvglwuKeEf NE0w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel-dk.20150623.gappssmtp.com header.s=20150623 header.b=fUjGVI1w; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id z22si2878601edb.151.2021.06.16.11.41.06; Wed, 16 Jun 2021 11:41:31 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel-dk.20150623.gappssmtp.com header.s=20150623 header.b=fUjGVI1w; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232543AbhFPNBn (ORCPT + 99 others); Wed, 16 Jun 2021 09:01:43 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33046 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232223AbhFPNBm (ORCPT ); Wed, 16 Jun 2021 09:01:42 -0400 Received: from mail-ot1-x32a.google.com (mail-ot1-x32a.google.com [IPv6:2607:f8b0:4864:20::32a]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 9BA43C06175F for ; Wed, 16 Jun 2021 05:59:36 -0700 (PDT) Received: by mail-ot1-x32a.google.com with SMTP id w23-20020a9d5a970000b02903d0ef989477so2340645oth.9 for ; Wed, 16 Jun 2021 05:59:36 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=kernel-dk.20150623.gappssmtp.com; s=20150623; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=2jLSVmuLw4Nb055fI6F5c4n6Y22HkMR7OQfqkvuCNLI=; b=fUjGVI1wI44GueP/8qBEGqyVV7NLUmOaIAeyp6CWQXjf7vZ7tnDvIJgVm6qIzUZk3t 8JWqWR2V4MG5tM4WpAU1MejqCWif82xUXXy/0FMAcKRMCHYnTZNLbIaLrqv5kOQIOkjp sApMoUC+CA2QoEQfSDKsfQF1oai8iMC663Uo9AYqcUx5pGrRG3YsfWa+ERQrJLvTG1tq xLV2Lohb2GjBvNa5VIzi2beGU3UuVLkRnSSTN5wdWeWTkgS7dmp0z+DuKbDoTX7UGksI aW7tvP8LiEZIgEwq7PEGyHJRy82VqVLeQL2h/X4HrhjIha4cZxaMLq+NOfIJFaqey22V SwqQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=2jLSVmuLw4Nb055fI6F5c4n6Y22HkMR7OQfqkvuCNLI=; b=kM65YMRorif1381onttxVyizRYywGI5XlGznZQ6JSyKlsGGntxYGq8dh8pHm2hvjRw DZxGWelebnpXxzr4DSg98NzgBUzWc3NIVFHk2t9NfSAEsQ6KyxIZyC0zpfMQTLCsLBxG I9LLk7DYssqObqyhlHKxiKBbJyoE11bcRY6FLtcLYiE4MIbJU2pPfIuGl4IOqr6VKaQA r5iUvpPcK4SXZp29CxFrTxXPA3muZUwO2xz8CVr4L8t5aGowfayig9K9YMFreeRP2xJY vZwkatvmHhK9FUM5MB1NKeAgKJHJfQebbOfSPnlqYjUJ6MH//ffYoKN0J1XUqlYcD46g RoqQ== X-Gm-Message-State: AOAM533o3n+9XCk++qjDMs+7u7Nzq+wHwQDQvY+z2MDKGdtiFthdoklN V07eTe/ncmXBOpbgn3L/BFJjbQ== X-Received: by 2002:a9d:4d8d:: with SMTP id u13mr3755526otk.367.1623848375674; Wed, 16 Jun 2021 05:59:35 -0700 (PDT) Received: from [192.168.1.134] ([198.8.77.61]) by smtp.gmail.com with ESMTPSA id 26sm460938ooy.46.2021.06.16.05.59.34 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Wed, 16 Jun 2021 05:59:35 -0700 (PDT) Subject: Re: [PATCH] nbd: provide a way for userspace processes to identify device backends To: Prasanna Kumar Kalever , linux-kernel@vger.kernel.org Cc: linux-block@vger.kernel.org, nbd@other.debian.org, josef@toxicpanda.com, idryomov@redhat.com, xiubli@redhat.com References: <20210429102828.31248-1-prasanna.kalever@redhat.com> From: Jens Axboe Message-ID: Date: Wed, 16 Jun 2021 06:59:33 -0600 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.10.0 MIME-Version: 1.0 In-Reply-To: <20210429102828.31248-1-prasanna.kalever@redhat.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 4/29/21 4:28 AM, Prasanna Kumar Kalever wrote: > Problem: > On reconfigure of device, there is no way to defend if the backend > storage is matching with the initial backend storage. > > Say, if an initial connect request for backend "pool1/image1" got > mapped to /dev/nbd0 and the userspace process is terminated. A next > reconfigure request within NBD_ATTR_DEAD_CONN_TIMEOUT is allowed to > use /dev/nbd0 for a different backend "pool1/image2" > > For example, an operation like below could be dangerous: > > $ sudo rbd-nbd map --try-netlink rbd-pool/ext4-image > /dev/nbd0 > $ sudo blkid /dev/nbd0 > /dev/nbd0: UUID="bfc444b4-64b1-418f-8b36-6e0d170cfc04" TYPE="ext4" > $ sudo pkill -9 rbd-nbd > $ sudo rbd-nbd attach --try-netlink --device /dev/nbd0 rbd-pool/xfs-image > /dev/nbd0 > $ sudo blkid /dev/nbd0 > /dev/nbd0: UUID="d29bf343-6570-4069-a9ea-2fa156ced908" TYPE="xfs" > > Solution: > Provide a way for userspace processes to keep some metadata to identify > between the device and the backend, so that when a reconfigure request is > made, we can compare and avoid such dangerous operations. > > With this solution, as part of the initial connect request, backend > path can be stored in the sysfs per device config, so that on a reconfigure > request it's easy to check if the backend path matches with the initial > connect backend path. > > Please note, ioctl interface to nbd will not have these changes, as there > won't be any reconfigure. Applied, thanks. -- Jens Axboe