[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [XenPPC] [pushed] [ppc] enough UART auto detection to satisfy our ISA targets
changeset: 9961:a99c33054d4ab381259fb59e396f824181091be4 tag: tip user: jimix@xxxxxxxxxxxxxxxxxxxxx date: Mon May 1 17:43:09 2006 -0400 files: xen/arch/ppc/boot_of.c xen/arch/ppc/setup.c description: [ppc] enough UART auto detection to satisfy our ISA targets We currently assume the location of the ISA bus. We also assume that we will takeover the UART that OF is using diff -r 55a15be14e7c41539fe7d827c4746bf976d2f935 -r a99c33054d4ab381259fb59e396f824181091be4 xen/arch/ppc/boot_of.c --- a/xen/arch/ppc/boot_of.c Mon May 1 16:04:05 2006 -0400 +++ b/xen/arch/ppc/boot_of.c Mon May 1 17:43:09 2006 -0400 @@ -22,8 +22,11 @@ #include <xen/lib.h> #include <xen/multiboot.h> #include <xen/compile.h> +#include <xen/spinlock.h> +#include <xen/serial.h> #include <public/of-devtree.h> #include <asm/page.h> +#include <asm/io.h> #include "dart.h" static ulong of_vec; @@ -33,8 +36,8 @@ static char bootargs[256]; static char bootargs[256]; static char dom0args[256]; -extern unsigned int timebase_freq; extern unsigned long opic_addr; +extern struct ns16550_defaults ns16550; #undef OF_DEBUG @@ -331,8 +334,6 @@ static int __init of_claim(void * virt, return rets[0]; } -#if unused_but_will_be - static int __init of_instance_to_package(int ih) { int rets[1] = { OF_FAILURE }; @@ -353,8 +354,6 @@ static int __init of_getparent(int ph) DBG("getparent 0x%x -> 0x%x\n", ph, rets[0]); return rets[0]; } - -#endif extern char _start[]; extern char _end[]; @@ -830,7 +829,58 @@ static void boot_of_module(ulong r3, ulo static int __init boot_of_serial(void) { - /* fill this in */ + int n; + int p; + int rc; + u32 val[3]; + char buf[64]; + + n = of_instance_to_package(of_out); + if (n == OF_FAILURE) { + of_panic("instance-to-package of /chosen/stdout: failed\n"); + } + + p = of_getparent(n); + if (p == OF_FAILURE) { + of_panic("no parent for: 0x%x\n", n); + } + + buf[0] = '\0'; + of_getprop(p, "device_type", buf, sizeof (buf)); + if (strstr(buf, "isa") == NULL) { + of_panic("only ISA UARTS supported\n"); + } + + /* should get this from devtree */ + isa_io_base = 0xf4000000; + of_printf("%s: ISA base: 0x%lx\n", __func__, isa_io_base); + + buf[0] = '\0'; + of_getprop(n, "device_type", buf, sizeof (buf)); + if (strstr(buf, "serial") == NULL) { + of_panic("only UARTS supported\n"); + } + + rc = of_getprop(n, "reg", val, sizeof (val)); + if (rc == OF_FAILURE) { + of_panic("%s: no location for serial port\n", __func__); + } + ns16550.io_base = val[1]; + + ns16550.baud = BAUD_AUTO; + ns16550.data_bits = 8; + ns16550.parity = 'n'; + ns16550.stop_bits = 1; + + rc = of_getprop(n, "interrupts", val, sizeof (val)); + if (rc == OF_FAILURE) { + of_printf("%s: no ISRC, forcing poll mode\n", __func__); + ns16550.irq = 0; + } + ns16550.irq = val[0]; + of_printf("%s: ISRC=0x%x, but forcing poll mode\n", __func__, ns16550.irq); + ns16550.irq = 0; + return 1; } diff -r 55a15be14e7c41539fe7d827c4746bf976d2f935 -r a99c33054d4ab381259fb59e396f824181091be4 xen/arch/ppc/setup.c --- a/xen/arch/ppc/setup.c Mon May 1 16:04:05 2006 -0400 +++ b/xen/arch/ppc/setup.c Mon May 1 17:43:09 2006 -0400 @@ -60,7 +60,8 @@ cpumask_t cpu_online_map; /* missing ifd cpumask_t cpu_online_map; /* missing ifdef in schedule.c */ /* XXX get this from ISA node in device tree */ -ulong isa_io_base = 0xf4000000; +ulong isa_io_base; +struct ns16550_defaults ns16550; struct vcpu *idle_vcpu[NR_CPUS]; extern char _start[]; @@ -166,17 +167,6 @@ static void __init __start_xen(multiboot if ((mbi->flags & MBI_CMDLINE) && (mbi->cmdline != 0)) cmdline_parse(__va((ulong)mbi->cmdline)); - /* We initialise the serial devices very early so we can get debugging. */ - /* XXX find this in device tree */ - struct ns16550_defaults ns16550 = { - .baud = BAUD_AUTO, - .data_bits = 8, - .parity = 'n', - .stop_bits = 1, - /* On maple this is 10, but we run in poll mode at the moment */ - .irq = 0, - .io_base = 0x3f8, - }; ns16550_init(0, &ns16550); serial_init_preirq(); _______________________________________________ Xen-ppc-devel mailing list Xen-ppc-devel@xxxxxxxxxxxxxxxxxxx http://lists.xensource.com/xen-ppc-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |