nios2: Fix ioremap
authorGuenter Roeck <linux@roeck-us.net>
Thu, 12 Dec 2019 08:34:03 +0000 (16:34 +0800)
committerLey Foon Tan <ley.foon.tan@intel.com>
Thu, 12 Dec 2019 08:34:33 +0000 (16:34 +0800)
commite32ea127d81c12882f39c2783d78634597ff21a2
treea6377ed4cb0d5f79f251a803a94198dfb8686fa6
parente42617b825f8073569da76dc4510bfa019b1c35a
nios2: Fix ioremap

Commit 5ace77e0b41a ("nios2: remove __ioremap") removed the following code,
with the argument that cacheflag is always 0 and the expression would
therefore always be false.

if (IS_MAPPABLE_UNCACHEABLE(phys_addr) &&
    IS_MAPPABLE_UNCACHEABLE(last_addr) &&
    !(cacheflag & _PAGE_CACHED))
return (void __iomem *)(CONFIG_NIOS2_IO_REGION_BASE + phys_addr);

This did not take the "!" in the expression into account. Result is that
nios2 images no longer boot. Restoring the removed code fixes the problem.

Fixes: 5ace77e0b41a ("nios2: remove __ioremap")
Cc: Christoph Hellwig <hch@lst.de>
Signed-off-by: Guenter Roeck <linux@roeck-us.net>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Ley Foon Tan <ley.foon.tan@intel.com>
arch/nios2/mm/ioremap.c