From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from down.free-electrons.com ([37.187.137.238] helo=mail.free-electrons.com) by bombadil.infradead.org with esmtp (Exim 4.80.1 #2 (Red Hat Linux)) id 1bADPF-00040s-IN for linux-mtd@lists.infradead.org; Tue, 07 Jun 2016 09:34:42 +0000 Date: Tue, 7 Jun 2016 11:34:09 +0200 From: Boris Brezillon To: Hauke Mehrtens Cc: computersforpeace@gmail.com, linux-mtd@lists.infradead.org, David.Woodhouse@intel.com, john@phrozen.org Subject: Re: [PATCH 5/6] MTD: xway: add missing write_buf and read_buf to nand driver Message-ID: <20160607113409.5ef102dd@bbrezillon> In-Reply-To: <1465161609-19303-6-git-send-email-hauke@hauke-m.de> References: <1465161609-19303-1-git-send-email-hauke@hauke-m.de> <1465161609-19303-6-git-send-email-hauke@hauke-m.de> MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit List-Id: Linux MTD discussion mailing list List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , On Sun, 5 Jun 2016 23:20:08 +0200 Hauke Mehrtens wrote: > From: John Crispin > > Signed-off-by: John Crispin > Signed-off-by: Hauke Mehrtens > --- > drivers/mtd/nand/xway_nand.c | 28 ++++++++++++++++++++++++++++ > 1 file changed, 28 insertions(+) > > diff --git a/drivers/mtd/nand/xway_nand.c b/drivers/mtd/nand/xway_nand.c > index d44e00d..bc4018e 100644 > --- a/drivers/mtd/nand/xway_nand.c > +++ b/drivers/mtd/nand/xway_nand.c > @@ -146,6 +146,32 @@ static unsigned char xway_read_byte(struct mtd_info *mtd) > return ret; > } > > +static void xway_read_buf(struct mtd_info *mtd, u_char *buf, int len) > +{ > + struct nand_chip *this = mtd->priv; You should now use mtd_to_nand(). Please rebase your work on top of nand/next [1], and I'm pretty sure you'll get a NULL pointer. > + unsigned long nandaddr = (unsigned long) this->IO_ADDR_R; > + unsigned long flags; > + int i; > + > + spin_lock_irqsave(&ebu_lock, flags); > + for (i = 0; i < len; i++) > + buf[i] = ltq_r8((void __iomem *)(nandaddr | NAND_READ_DATA)); > + spin_unlock_irqrestore(&ebu_lock, flags); > +} > + > +static void xway_write_buf(struct mtd_info *mtd, const u_char *buf, int len) > +{ > + struct nand_chip *this = mtd->priv; > + unsigned long nandaddr = (unsigned long) this->IO_ADDR_W; > + unsigned long flags; > + int i; > + > + spin_lock_irqsave(&ebu_lock, flags); > + for (i = 0; i < len; i++) > + ltq_w8(buf[i], (void __iomem *)(nandaddr | NAND_WRITE_DATA)); > + spin_unlock_irqrestore(&ebu_lock, flags); > +} > + > static int xway_nand_probe(struct platform_device *pdev) > { > struct nand_chip *this = platform_get_drvdata(pdev); > @@ -187,6 +213,8 @@ static struct platform_nand_data xway_nand_data = { > .dev_ready = xway_dev_ready, > .select_chip = xway_select_chip, > .read_byte = xway_read_byte, > + .read_buf = xway_read_buf, > + .write_buf = xway_write_buf, > } > }; > [1]https://github.com/linux-nand/linux/tree/nand/next -- Boris Brezillon, Free Electrons Embedded Linux and Kernel engineering http://free-electrons.com