The code in legacy_serial.c wouldn't properly compare OF translation
results against OF_BAD_ADDR as it's using a phys_addr_t which is 32
bits on some 32-bit powerpc platforms. This fixes it by always using
a u64 which is what is returned by the OF parsing routines. It also
makes translation failure harmless for ISA serial ports. If they
can't translate, we can't use the UART early, but we can still let the
8250 driver use it later on by using IO port accessors.
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Signed-off-by: Paul Mackerras <paulus@samba.org>
static int __init add_legacy_soc_port(struct device_node *np,
struct device_node *soc_dev)
{
static int __init add_legacy_soc_port(struct device_node *np,
struct device_node *soc_dev)
{
u32 *addrp;
upf_t flags = UPF_BOOT_AUTOCONF | UPF_SKIP_TEST | UPF_SHARE_IRQ;
u32 *addrp;
upf_t flags = UPF_BOOT_AUTOCONF | UPF_SKIP_TEST | UPF_SHARE_IRQ;
u32 *reg;
char *typep;
int index = -1;
u32 *reg;
char *typep;
int index = -1;
DBG(" -> add_legacy_isa_port(%s)\n", np->full_name);
DBG(" -> add_legacy_isa_port(%s)\n", np->full_name);
if (typep && *typep == 'S')
index = simple_strtol(typep+1, NULL, 0) - 1;
if (typep && *typep == 'S')
index = simple_strtol(typep+1, NULL, 0) - 1;
- /* Translate ISA address */
+ /* Translate ISA address. If it fails, we still register the port
+ * with no translated address so that it can be picked up as an IO
+ * port later by the serial driver
+ */
taddr = of_translate_address(np, reg);
if (taddr == OF_BAD_ADDR)
taddr = of_translate_address(np, reg);
if (taddr == OF_BAD_ADDR)
/* Add port, irq will be dealt with later */
return add_legacy_port(np, index, UPIO_PORT, reg[1], taddr,
/* Add port, irq will be dealt with later */
return add_legacy_port(np, index, UPIO_PORT, reg[1], taddr,
static int __init add_legacy_pci_port(struct device_node *np,
struct device_node *pci_dev)
{
static int __init add_legacy_pci_port(struct device_node *np,
struct device_node *pci_dev)
{
- phys_addr_t addr, base;
u32 *addrp;
unsigned int flags;
int iotype, index = -1, lindex = 0;
u32 *addrp;
unsigned int flags;
int iotype, index = -1, lindex = 0;