[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20180709181206.3422a8fb@bbrezillon>
Date: Mon, 9 Jul 2018 18:12:06 +0200
From: Boris Brezillon <boris.brezillon@...tlin.com>
To: Arnd Bergmann <arnd@...db.de>
Cc: Miquel Raynal <miquel.raynal@...tlin.com>,
Richard Weinberger <richard@....at>,
David Woodhouse <dwmw2@...radead.org>,
Brian Norris <computersforpeace@...il.com>,
Marek Vasut <marek.vasut@...il.com>,
Sekhar Nori <nsekhar@...com>,
Gregory CLEMENT <gregory.clement@...tlin.com>,
Alexander Sverdlin <alexander.sverdlin@...il.com>,
Bartosz Golaszewski <bgolaszewski@...libre.com>,
linux-mtd@...ts.infradead.org, linux-kernel@...r.kernel.org
Subject: Re: [PATCH 1/3] mtd: rawnand: davinci: fix build testing on 64-bit
Hi Arnd,
On Mon, 9 Jul 2018 17:57:02 +0200
Arnd Bergmann <arnd@...db.de> wrote:
> Now that we can build this driver everywhere, we run into a couple
> of warnings like:
>
> drivers/mtd/nand/raw/davinci_nand.c: In function 'nand_davinci_correct_4bit':
> drivers/mtd/nand/raw/davinci_nand.c:322:21: error: cast from pointer to integer of different size [-Werror=pointer-to-int-cast]
>
> In all cases, this is harmless and we just need to cast to an uintptr_t
> rather than an unsigned 32-bit integer.
>
> Fixes: 347af8918e8a ("mtd: rawnand: davinci: Allow selection of this driver when COMPILE_TEST=y")
> Signed-off-by: Arnd Bergmann <arnd@...db.de>
Actually, I have all those fixes in my nand/api-cleanup branch [1]. I
was planning on sending a v2 of my COMPILE_TEST series to address
those problems before activating COMPILE_TEST on those drivers (Miquel
already dropped the patches activating COMPILE_TEST on sunxi, davinci
and atmel).
Regards,
Boris
[1]https://github.com/bbrezillon/linux-0day/commits/nand/api-cleanup
> ---
> drivers/mtd/nand/raw/davinci_nand.c | 16 ++++++++--------
> 1 file changed, 8 insertions(+), 8 deletions(-)
>
> diff --git a/drivers/mtd/nand/raw/davinci_nand.c b/drivers/mtd/nand/raw/davinci_nand.c
> index cd12e5abafde..c638bd60eb0b 100644
> --- a/drivers/mtd/nand/raw/davinci_nand.c
> +++ b/drivers/mtd/nand/raw/davinci_nand.c
> @@ -102,7 +102,7 @@ static void nand_davinci_hwcontrol(struct mtd_info *mtd, int cmd,
> unsigned int ctrl)
> {
> struct davinci_nand_info *info = to_davinci_nand(mtd);
> - uint32_t addr = info->current_cs;
> + uintptr_t addr = info->current_cs;
> struct nand_chip *nand = mtd_to_nand(mtd);
>
> /* Did the control lines change? */
> @@ -122,7 +122,7 @@ static void nand_davinci_hwcontrol(struct mtd_info *mtd, int cmd,
> static void nand_davinci_select_chip(struct mtd_info *mtd, int chip)
> {
> struct davinci_nand_info *info = to_davinci_nand(mtd);
> - uint32_t addr = info->ioaddr;
> + uintptr_t addr = info->ioaddr;
>
> /* maybe kick in a second chipselect */
> if (chip > 0)
> @@ -319,7 +319,7 @@ static int nand_davinci_correct_4bit(struct mtd_info *mtd,
> /* Unpack ten bytes into eight 10 bit values. We know we're
> * little-endian, and use type punning for less shifting/masking.
> */
> - if (WARN_ON(0x01 & (unsigned) ecc_code))
> + if (WARN_ON(0x01 & (uintptr_t)ecc_code))
> return -EINVAL;
> ecc16 = (unsigned short *)ecc_code;
>
> @@ -441,9 +441,9 @@ static void nand_davinci_read_buf(struct mtd_info *mtd, uint8_t *buf, int len)
> {
> struct nand_chip *chip = mtd_to_nand(mtd);
>
> - if ((0x03 & ((unsigned)buf)) == 0 && (0x03 & len) == 0)
> + if ((0x03 & ((uintptr_t)buf)) == 0 && (0x03 & len) == 0)
> ioread32_rep(chip->IO_ADDR_R, buf, len >> 2);
> - else if ((0x01 & ((unsigned)buf)) == 0 && (0x01 & len) == 0)
> + else if ((0x01 & ((uintptr_t)buf)) == 0 && (0x01 & len) == 0)
> ioread16_rep(chip->IO_ADDR_R, buf, len >> 1);
> else
> ioread8_rep(chip->IO_ADDR_R, buf, len);
> @@ -454,9 +454,9 @@ static void nand_davinci_write_buf(struct mtd_info *mtd,
> {
> struct nand_chip *chip = mtd_to_nand(mtd);
>
> - if ((0x03 & ((unsigned)buf)) == 0 && (0x03 & len) == 0)
> + if ((0x03 & ((uintptr_t)buf)) == 0 && (0x03 & len) == 0)
> iowrite32_rep(chip->IO_ADDR_R, buf, len >> 2);
> - else if ((0x01 & ((unsigned)buf)) == 0 && (0x01 & len) == 0)
> + else if ((0x01 & ((uintptr_t)buf)) == 0 && (0x01 & len) == 0)
> iowrite16_rep(chip->IO_ADDR_R, buf, len >> 1);
> else
> iowrite8_rep(chip->IO_ADDR_R, buf, len);
> @@ -680,7 +680,7 @@ static int nand_davinci_probe(struct platform_device *pdev)
> info->chip.bbt_md = pdata->bbt_md;
> info->timing = pdata->timing;
>
> - info->ioaddr = (uint32_t __force) vaddr;
> + info->ioaddr = (uintptr_t __force) vaddr;
>
> info->current_cs = info->ioaddr;
> info->core_chipsel = pdata->core_chipsel;
Powered by blists - more mailing lists