Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp231538imm; Fri, 5 Oct 2018 02:55:38 -0700 (PDT) X-Google-Smtp-Source: ACcGV60rUv74AM0R2dSwBE6biVTL3c/T0k/l0jTaCiy8QUxqJbslpeXiKnheUhOXEjeodAlbgBvW X-Received: by 2002:a63:ff23:: with SMTP id k35-v6mr9539968pgi.62.1538733338117; Fri, 05 Oct 2018 02:55:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1538733338; cv=none; d=google.com; s=arc-20160816; b=Zo6caeJYFiGzunaSkR5Nh9g8AtNQT5JjY8FkZ7WLBawzQWRB4fORMcU1LmgYj5ef3r tqMgCG68Esb36+4U16SO0nEXh2F9QKjLZIdW9jTVTlxk//fY7YT4SELqtE78rxUxNl3x f7Zd0SSXNGZixlITgaZRh+X2BVbuGXxws+IbvoDoDAsqI7cO8chMNzZQgSP/QRsX41dF OoQ9FEjIIFTyyM2Lnkx2J+Prhe/ludNHMX1fRWlY14T/F4dr/JA1SxROfyN3hRMzMuKH zuYaJPKB5Ou9pUx+YqS70kGuQ10VDSzmLdigFfBrqMowgznHgZm8NG+bl0x4qn2yzPYy 8OBQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=PH2v1EyC/Q0Z27StVDDCxqQ9M7qe2weX3U7+lh0eLkk=; b=jdXXM2V2NWxjSVRvE7JWPpwZkrXoQ7ZzhrySrmRYviFbbKQWIoKcgllr5FQXmDI4eR 03exKHF9d+Jku0j2qy+vlQD+0qDcmDuPHtpdonv9ltjWCmASWE3s/SPjumaqsiFj0CQA PcYpZFbQzrLvhrh0sREo2jPm3tsSXUtcgYZryjO1EdNeON2huRYhDUbVFQrdossrJbxS 1aQbA1+tojNk6sUWt1MGboiRxnyfzN8KKolRwEMAuX3Wj63OQxoWz9rYYGP+Bm9EUda1 CPCYn92uxz5SHAbNBmbyxLiVAvOG1gsgr2vzyoE5EwdSbAWmLyyXJvjmwMSt6LX/7O+t xNpA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=EuwETibI; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 20-v6si7902402pfk.287.2018.10.05.02.55.22; Fri, 05 Oct 2018 02:55:38 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=EuwETibI; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728021AbeJEQwj (ORCPT + 99 others); Fri, 5 Oct 2018 12:52:39 -0400 Received: from mail-lj1-f196.google.com ([209.85.208.196]:39107 "EHLO mail-lj1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727540AbeJEQwj (ORCPT ); Fri, 5 Oct 2018 12:52:39 -0400 Received: by mail-lj1-f196.google.com with SMTP id p1-v6so7185189ljg.6 for ; Fri, 05 Oct 2018 02:54:36 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=PH2v1EyC/Q0Z27StVDDCxqQ9M7qe2weX3U7+lh0eLkk=; b=EuwETibIl9HLdH2D2silGlOTlfJyrcVneh8Cyi2KcuCumK/ygemRH7IfkXDnf5IUgx lD257MIIU5ivddrajs/R/oi7iM3zIO7KOecicJfVj1ctj/jHVe90DZqevbhPBLjIU/mu ijgc1k2QiHgmfghsGhDOJH+mS3ZvlMJi8pnfK5BUXcVygmRp82HWFvHhqj8UYksHqdXt etwROrYjeDvFKRBbfTJm2e8Zxtip5o949mQE5wgHctfZmxHKD6hkmN55F4IndvKuG7rn /fEKC5RjLh2CBBB6InEkogA4DTyJwv9FpOeJljNW+uQNLWy9O0NWVrpzf+RpGFXEozMm FJ0g== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=PH2v1EyC/Q0Z27StVDDCxqQ9M7qe2weX3U7+lh0eLkk=; b=Y8w4LziEbEmtAHd545gnmpOpUW87l8Qks2nKGhjpL5Y25kDe9QY0oMR5NcgTaP8FDS 76J7EhxoD08iqi+uTGTxIwpaG0ND0g45VC2zkTViTR4XfVqYjlKoqPNO6sbq6rdGAild 2coqqktkZUicl5Qb/Nckpc+A1GxqFPCUh0ukdpVsoPpjNFQIiJsmCl1kRJMmjXyT4OLo 1VamYRofFvvKz2tp5JVmwuYPGe8v7+NXmTykvLl9bVVKQJmLLrAX+dWqDRK7aTu2tB6V u8oDLx7lHSyHiBsRurbgAoE1cNiuJGj99oUVHN8TGAiIfX7hfBzkoQF4WvFj95R/PRBU Is7g== X-Gm-Message-State: ABuFfojVqB+p+z5j+UZ2UdOiZKold8uT7HQXmOLqczup2mtjN4xbwsY6 o24gz6riBFpn7wL2ZLkpYrGKnqUEnC9jhFVBF/k= X-Received: by 2002:a2e:8919:: with SMTP id d25-v6mr7405185lji.69.1538733275410; Fri, 05 Oct 2018 02:54:35 -0700 (PDT) MIME-Version: 1.0 References: <20181004142942.11887-1-ricardo.ribalda@gmail.com> <20181004142942.11887-2-ricardo.ribalda@gmail.com> <20181005002125.12fd229f@bbrezillon> <20181005090811.6b7e9957@bbrezillon> <20181005103730.57d52e3c@bbrezillon> In-Reply-To: <20181005103730.57d52e3c@bbrezillon> From: Ricardo Ribalda Delgado Date: Fri, 5 Oct 2018 11:54:18 +0200 Message-ID: Subject: Re: [PATCH v10 10/10] mtd: maps: gpio-addr-flash: Add support for device-tree devices To: Boris Brezillon Cc: David Woodhouse , Brian Norris , Marek Vasut , Richard Weinberger , Zhouyang Jia , linux-mtd@lists.infradead.org, LKML Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Boris Just seen that you already did the rebase at https://github.com/bbrezillon/linux-0day/commits/mtd/physmap-cleanup Thanks for that. I am about to test it in real hw (unless you want me wait) Cheers! On Fri, Oct 5, 2018 at 10:37 AM Boris Brezillon wrote: > > On Fri, 5 Oct 2018 10:10:22 +0200 > Ricardo Ribalda Delgado wrote: > > > On Fri, Oct 5, 2018 at 9:08 AM Boris Brezillon > > wrote: > > > > > > Hi Ricardo, > > > > > > On Fri, 5 Oct 2018 08:31:35 +0200 > > > Ricardo Ribalda Delgado wrote: > > > > > > > Hi Boris > > > > > > > > > > > > On Fri, Oct 5, 2018 at 12:21 AM Boris Brezillon > > > > wrote: > > > > > > > > > > Hi Ricardo, > > > > > > > > > > On Thu, 4 Oct 2018 16:29:42 +0200 > > > > > Ricardo Ribalda Delgado wrote: > > > > > > > > > > > Allow creating gpio-addr-flash via device-tree and not just via platform > > > > > > data. > > > > > > > > > > > > Mimic what physmap_of_versatile and physmap_of_gemini does to reduce > > > > > > code duplicity. > > > > > > > > > > > > Signed-off-by: Ricardo Ribalda Delgado > > > > > > --- > > > > > > drivers/mtd/maps/Kconfig | 8 +++ > > > > > > drivers/mtd/maps/Makefile | 3 +- > > > > > > drivers/mtd/maps/gpio-addr-flash.c | 95 +++++++++++++++++++----------- > > > > > > drivers/mtd/maps/gpio-addr-flash.h | 34 +++++++++++ > > > > > > drivers/mtd/maps/physmap_of_core.c | 5 ++ > > > > > > drivers/mtd/maps/physmap_of_gpio.c | 21 +++++++ > > > > > > 6 files changed, 129 insertions(+), 37 deletions(-) > > > > > > create mode 100644 drivers/mtd/maps/gpio-addr-flash.h > > > > > > create mode 100644 drivers/mtd/maps/physmap_of_gpio.c > > > > > > > > > > > > diff --git a/drivers/mtd/maps/Kconfig b/drivers/mtd/maps/Kconfig > > > > > > index afb36bff13a7..427143d42168 100644 > > > > > > --- a/drivers/mtd/maps/Kconfig > > > > > > +++ b/drivers/mtd/maps/Kconfig > > > > > > @@ -94,6 +94,14 @@ config MTD_PHYSMAP_OF_GEMINI > > > > > > platforms, some detection and setting up parallel mode on the > > > > > > external interface. > > > > > > > > > > > > +config MTD_PHYSMAP_OF_GPIO > > > > > > + bool "GPIO-assisted OF-based physical memory map handling" > > > > > > + depends on MTD_PHYSMAP_OF > > > > > > + depends on MTD_GPIO_ADDR > > > > > > + help > > > > > > + This provides some extra DT physmap parsing for flashes that are > > > > > > + partially physically addressed and assisted by GPIOs. > > > > > > + > > > > > > > > > > Hm, so now we have the physmap_of driver which uses a function exposed > > > > > by the gpio-addr-flash module, but this module is also declaring a > > > > > platform_driver. It's probably working fine, but it's hard to follow. > > > > > > > > > > So, I decided to give it a try and started to rework a bit the physmap, > > > > > physmap_of and gpio-addr-flash drivers. Here is the result [1] (it's > > > > > only been compile tested). With this rework we now have a single > > > > > driver which supports DT and !DT init and can also use GPIOs to > > > > > extend the physical memory range in case it's not large enough to > > > > > address the whole memory dev. > > > > > > > > > > Let me know what you think of this approach. > > > > > > > > > > > > > The code is definitely easier to follow. But I believe you should > > > > rebase your changes on mines (1-9) and instead of 10 apply your > > > > patch-set.: > > > > - "mtd: maps: Merge gpio-addr-flash.c into physmap-core.c" includes > > > > all my changes and some of them are not obvious:( Port to gpiod, > > > > gpio_values, win_order, use new apis....) > > > > > > True. > > > > > > > - Also there would be 1 (or 2) fixes that should be included in stable > > > > that we lose using your approach "mtd: maps: gpio-addr-flash: Fix > > > > ioremapped size", "mtd: physmap_of: Release resources on error" > > > > > > I'm not sure this is really useful to backport them to stable since > > > blackfin users never complained about it (plus, blackin arch is now > > > gone), but okay. > > > > > > > - And last, but not least, I want some credit for all this work ;) > > > > After 10 iterations I guess that I deserve more than a Documentation > > > > change, specially when my code would be on the tree. > > > > > > Fair enough. > > > > > > > > > > > My other concern is that maybe we are giving too much entity to > > > > gpio-addr by including it in the core. But if you are fine with it, I > > > > am fine with it. > > > > > > Well, the gpio-addr stuff is just here to support platforms that do not > > > have enough ADDR lines (or iomem address space) to address the whole > > > device. I see it as an 'extension' of the physmap logic, which is why I > > > think it makes sense to have this logic in the physmap driver instead > > > of creating a completely new driver. > > > > > > > > > > > If you want i can do the rebase and start testing on my board. What do > > > > you think? > > > > > > That'd be great! > > > > Can you start by picking 1-8 from my patchset so i do not have to > > resend it again and again while we work on your changes? > > Done. -- Ricardo Ribalda