Received: by 2002:a05:6358:7058:b0:131:369:b2a3 with SMTP id 24csp9624717rwp; Thu, 20 Jul 2023 07:33:54 -0700 (PDT) X-Google-Smtp-Source: APBJJlGpmEHDmtHJiL7ULXTTmKJo2YbbjlYsfTag3GGeKO1sVyDLm2l9N9Pc5PTS5s298gfIVFrf X-Received: by 2002:a17:906:518c:b0:994:577:f9dd with SMTP id y12-20020a170906518c00b009940577f9ddmr2398901ejk.9.1689863634004; Thu, 20 Jul 2023 07:33:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1689863633; cv=none; d=google.com; s=arc-20160816; b=BSRsJfBwGQ4/eYrBAGYp9t2e8WRlm87/SXkHHklPQ49hAb4eJ3zLeJldGgIv0vMDDi Rgj3cglYXn5RXwwp+rd2vn1GJkm0COvF0P/0Biiii2KxHjQry6DTaseSwCBDoXIUv0NC 3HBAWUQfc2BlcdSEYaM9i85kmYOblvZjBGjyhMLR+qtGcd6VgLaJWOyKykKsD+kCVixx uqY8X/ak32cuQTth+TQ8rFZARPkI4yKL9FyGynrvSmR8pfS/pOUXmyQ6GXv300Tait9s HMUeG71uNKP5m1hB1BYk5aQaZSFIy5cXlao1tvYkfiaEZV0km6NwcaECad7nSXJA27vi E2QQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature:dkim-signature; bh=ZGnybU3gGB5aNK910zLVij5aowP7RWZlN7dwTs5iv2w=; fh=YOXfMHkq9e5ZT5iT908ByXCI3PzrwSDr9xzJ3bAyhmk=; b=tYkeZbzK0Vu6IMbU25Bbfl+Ai4OFGwu9PA7iuUMJjjsl5SClOxGxdk2ngyK4H9M6I1 vht/E5JCoK50IcC5J1cYET84ee+F6MWlKjJAJG3Hw9RDE5H2J9rm2IqlXsSavAfEkU/a krgU5gvb7qH6gU/yDGSa9AVKC9s5NGMMN+yE7+dWX/hF1x1ecLPpEbMJAhjkt8ifVG2f LJVZM0FdaalEp0+Ia98fS4DVfJBzcVw4bELV9ZUhH0vBTXJ7LL3XI4ZuqtLAMuMx3HtE e5/eul03Nv6wZtOUQLllVWsy41NVAl4KIFTLjkEFlcjrscvu/ZqsueqBvQya1zOyBsoC iFLw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@suse.de header.s=susede2_rsa header.b="y3LtS5/g"; dkim=neutral (no key) header.i=@suse.de header.s=susede2_ed25519; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=suse.de Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id h19-20020a1709062dd300b00993686e193csi760989eji.53.2023.07.20.07.33.29; Thu, 20 Jul 2023 07:33:53 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@suse.de header.s=susede2_rsa header.b="y3LtS5/g"; dkim=neutral (no key) header.i=@suse.de header.s=susede2_ed25519; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=suse.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231812AbjGTOD2 (ORCPT + 99 others); Thu, 20 Jul 2023 10:03:28 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40438 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231808AbjGTOD1 (ORCPT ); Thu, 20 Jul 2023 10:03:27 -0400 Received: from smtp-out1.suse.de (smtp-out1.suse.de [IPv6:2001:67c:2178:6::1c]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 5B4BB210B; Thu, 20 Jul 2023 07:03:24 -0700 (PDT) Received: from imap2.suse-dmz.suse.de (imap2.suse-dmz.suse.de [192.168.254.74]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature ECDSA (P-521) server-digest SHA512) (No client certificate requested) by smtp-out1.suse.de (Postfix) with ESMTPS id AA0DC22C64; Thu, 20 Jul 2023 14:03:22 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=suse.de; s=susede2_rsa; t=1689861802; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc:cc: mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=ZGnybU3gGB5aNK910zLVij5aowP7RWZlN7dwTs5iv2w=; b=y3LtS5/gtRX9lVn3eFs2GAUvGyKcWlYfvac6mcNsjImdFCTBRjER9JwMgDYreJLiWRoeQX G4GnuucJ+GYBhf6SftdM6fAIE5chEafvKewVmqb+BVJ0Dh9GgVx1bDj9WFG00YWcu1A91f o1qlgWgo7mm8/KYPvP03TDZ7U3IalMA= DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=suse.de; s=susede2_ed25519; t=1689861802; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc:cc: mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=ZGnybU3gGB5aNK910zLVij5aowP7RWZlN7dwTs5iv2w=; b=RBWSyVgblVwr03N26SRGPofyGJCbUi/vpnVfiIgmUxhEhB3PIB08n6hKz2jnquMbkp9gNX GMq+KLeEJQfBoIBw== Received: from imap2.suse-dmz.suse.de (imap2.suse-dmz.suse.de [192.168.254.74]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature ECDSA (P-521) server-digest SHA512) (No client certificate requested) by imap2.suse-dmz.suse.de (Postfix) with ESMTPS id 6A54B133DD; Thu, 20 Jul 2023 14:03:22 +0000 (UTC) Received: from dovecot-director2.suse.de ([192.168.254.65]) by imap2.suse-dmz.suse.de with ESMTPSA id YTNYGao+uWTVZAAAMHmgww (envelope-from ); Thu, 20 Jul 2023 14:03:22 +0000 Message-ID: Date: Thu, 20 Jul 2023 16:03:22 +0200 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.12.0 Subject: Re: [RFC PATCH 3/6] block: add new genhd flag GENHD_FL_NO_NVMEM Content-Language: en-US To: Daniel Golle Cc: Jens Axboe , Ulf Hansson , Miquel Raynal , Richard Weinberger , Vignesh Raghavendra , Dave Chinner , Matthew Wilcox , =?UTF-8?Q?Thomas_Wei=c3=9fschuh?= , Jan Kara , Damien Le Moal , Ming Lei , Min Li , Christian Loehle , Adrian Hunter , Jack Wang , Florian Fainelli , Yeqi Fu , Avri Altman , Hans de Goede , Ye Bin , Greg Kroah-Hartman , =?UTF-8?B?UmFmYcWCIE1pxYJlY2tp?= , linux-block@vger.kernel.org, linux-kernel@vger.kernel.org, linux-mmc@vger.kernel.org, linux-mtd@lists.infradead.org References: <96510d925cb0ca1a3a132f8f8affd4bbdafd8fc9.1689802933.git.daniel@makrotopia.org> <0592e021-237d-6d41-7faf-e5b93aefbeea@suse.de> From: Hannes Reinecke In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-2.2 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A, RCVD_IN_DNSWL_BLOCKED,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 7/20/23 15:47, Daniel Golle wrote: > On Thu, Jul 20, 2023 at 10:24:18AM +0200, Hannes Reinecke wrote: >> On 7/20/23 00:03, Daniel Golle wrote: >>> Add new flag to destinguish block devices which should not act as an >>> NVMEM provider, such as for example an emulated block device on top of >>> an MTD partition which already acts as an NVMEM provider itself. >>> >>> Signed-off-by: Daniel Golle >>> --- >>> include/linux/blkdev.h | 3 +++ >>> 1 file changed, 3 insertions(+) >>> >>> diff --git a/include/linux/blkdev.h b/include/linux/blkdev.h >>> index 2f5371b8482c0..e853d1815be15 100644 >>> --- a/include/linux/blkdev.h >>> +++ b/include/linux/blkdev.h >>> @@ -80,11 +80,14 @@ struct partition_meta_info { >>> * ``GENHD_FL_NO_PART``: partition support is disabled. The kernel will not >>> * scan for partitions from add_disk, and users can't add partitions manually. >>> * >>> + * ``GENHD_FL_NO_NVMEM``: NVMEM emulation is disabled. The kernel will not >>> + * emulate an NVMEM device on top of this disk. >>> */ >>> enum { >>> GENHD_FL_REMOVABLE = 1 << 0, >>> GENHD_FL_HIDDEN = 1 << 1, >>> GENHD_FL_NO_PART = 1 << 2, >>> + GENHD_FL_NO_NVMEM = 1 << 3, >>> }; >>> enum { >> Please reverse this flag. Most of the devices will not have an NVMEM >> partition, and we shouldn't require each and every driver to tag their >> devices. >> So please use GENHD_FL_NVMEM and only set this flag on devices which really >> have an NVMEM partition. > > The idea here was to exclude all those devices which already implement > an NVMEM provider on a lower layer themselves, such as MTD. > In this cases it would be ambigous if the OF node represents the > NVMEM device registered by the MTD framework or if blk-nvmem should be > used. > Hmm; not sure if I follow. In the end, it doesn't really matter whether you check for GENHD_FL_NO_NVMEM or !GENHD_FL_NVMEM. With the difference being that in the former case you have to tag 99% of all existing block devices, and in the latter you have to tag 1%. > In all other cases device tree can unambigously indicate whether a > block device should serve as NVMEM provider (and right, most of them > never will). > > However, reversing the logic seems fine just as well. Thanks. Please do. Cheers, Hannes