]> git.proxmox.com Git - mirror_ubuntu-focal-kernel.git/commitdiff
tty: serial: uartlite: allow 64 bit address
authorLizhi Hou <lizhi.hou@xilinx.com>
Mon, 29 Nov 2021 20:23:02 +0000 (12:23 -0800)
committerStefan Bader <stefan.bader@canonical.com>
Mon, 7 Mar 2022 15:35:37 +0000 (16:35 +0100)
BugLink: https://bugs.launchpad.net/bugs/1960566
[ Upstream commit 3672fb65155530b5eea6225685c75329b6debec3 ]

The base address of uartlite registers could be 64 bit address which is from
device resource. When ulite_probe() calls ulite_assign(), this 64 bit
address is casted to 32-bit. The fix is to replace "u32" type with
"phys_addr_t" type for the base address in ulite_assign() argument list.

Fixes: 8fa7b6100693 ("[POWERPC] Uartlite: Separate the bus binding from the driver proper")
Signed-off-by: Lizhi Hou <lizhi.hou@xilinx.com>
Link: https://lore.kernel.org/r/20211129202302.1319033-1-lizhi.hou@xilinx.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
Signed-off-by: Kamal Mostafa <kamal@canonical.com>
Signed-off-by: Stefan Bader <stefan.bader@canonical.com>
drivers/tty/serial/uartlite.c

index 56066d93a65b856bd104477c11db3ce53a3bec89..9a4049c894f7a59e4c8c165847706424589ae579 100644 (file)
@@ -618,7 +618,7 @@ static struct uart_driver ulite_uart_driver = {
  *
  * Returns: 0 on success, <0 otherwise
  */
-static int ulite_assign(struct device *dev, int id, u32 base, int irq,
+static int ulite_assign(struct device *dev, int id, phys_addr_t base, int irq,
                        struct uartlite_data *pdata)
 {
        struct uart_port *port;