diff options
author | Paul Mackerras <paulus@samba.org> | 2005-10-22 01:36:52 -0400 |
---|---|---|
committer | Paul Mackerras <paulus@samba.org> | 2005-10-22 01:36:52 -0400 |
commit | 529294d59fdc77bf15f00f2308bbeb73e03e7042 (patch) | |
tree | e04c555d8c1ed398b1543442e0f2d4d82b360acb /arch/ppc64 | |
parent | f7abbc190b0edec34627d5348ba1d5fa5577da77 (diff) |
ppc64: Rearrange btext initialization for consistency with ppc32
Moved init_boot_display from arch/ppc64/kernel/pmac_setup.c to
arch/ppc64/kernel/btext.c and declared it in asm-ppc64/btext.h.
Call it from init_early rather than pmac_init_early.
Signed-off-by: Paul Mackerras <paulus@samba.org>
Diffstat (limited to 'arch/ppc64')
-rw-r--r-- | arch/ppc64/kernel/btext.c | 42 | ||||
-rw-r--r-- | arch/ppc64/kernel/pmac_setup.c | 49 | ||||
-rw-r--r-- | arch/ppc64/kernel/setup.c | 4 |
3 files changed, 46 insertions, 49 deletions
diff --git a/arch/ppc64/kernel/btext.c b/arch/ppc64/kernel/btext.c index b6fbfbe9032d..506a37885c5c 100644 --- a/arch/ppc64/kernel/btext.c +++ b/arch/ppc64/kernel/btext.c | |||
@@ -18,6 +18,7 @@ | |||
18 | #include <asm/io.h> | 18 | #include <asm/io.h> |
19 | #include <asm/lmb.h> | 19 | #include <asm/lmb.h> |
20 | #include <asm/processor.h> | 20 | #include <asm/processor.h> |
21 | #include <asm/udbg.h> | ||
21 | 22 | ||
22 | #undef NO_SCROLL | 23 | #undef NO_SCROLL |
23 | 24 | ||
@@ -131,6 +132,47 @@ int btext_initialize(struct device_node *np) | |||
131 | return 0; | 132 | return 0; |
132 | } | 133 | } |
133 | 134 | ||
135 | static void btext_putc(unsigned char c) | ||
136 | { | ||
137 | btext_drawchar(c); | ||
138 | } | ||
139 | |||
140 | void __init init_boot_display(void) | ||
141 | { | ||
142 | char *name; | ||
143 | struct device_node *np = NULL; | ||
144 | int rc = -ENODEV; | ||
145 | |||
146 | printk("trying to initialize btext ...\n"); | ||
147 | |||
148 | name = (char *)get_property(of_chosen, "linux,stdout-path", NULL); | ||
149 | if (name != NULL) { | ||
150 | np = of_find_node_by_path(name); | ||
151 | if (np != NULL) { | ||
152 | if (strcmp(np->type, "display") != 0) { | ||
153 | printk("boot stdout isn't a display !\n"); | ||
154 | of_node_put(np); | ||
155 | np = NULL; | ||
156 | } | ||
157 | } | ||
158 | } | ||
159 | if (np) | ||
160 | rc = btext_initialize(np); | ||
161 | if (rc) { | ||
162 | for (np = NULL; (np = of_find_node_by_type(np, "display"));) { | ||
163 | if (get_property(np, "linux,opened", NULL)) { | ||
164 | printk("trying %s ...\n", np->full_name); | ||
165 | rc = btext_initialize(np); | ||
166 | printk("result: %d\n", rc); | ||
167 | } | ||
168 | if (rc == 0) | ||
169 | break; | ||
170 | } | ||
171 | } | ||
172 | if (rc == 0 && udbg_putc == NULL) | ||
173 | udbg_putc = btext_putc; | ||
174 | } | ||
175 | |||
134 | 176 | ||
135 | /* Calc the base address of a given point (x,y) */ | 177 | /* Calc the base address of a given point (x,y) */ |
136 | static unsigned char * calc_base(int x, int y) | 178 | static unsigned char * calc_base(int x, int y) |
diff --git a/arch/ppc64/kernel/pmac_setup.c b/arch/ppc64/kernel/pmac_setup.c index c059805d8cce..c3ea73df937d 100644 --- a/arch/ppc64/kernel/pmac_setup.c +++ b/arch/ppc64/kernel/pmac_setup.c | |||
@@ -274,48 +274,6 @@ static void pmac_halt(void) | |||
274 | pmac_power_off(); | 274 | pmac_power_off(); |
275 | } | 275 | } |
276 | 276 | ||
277 | #ifdef CONFIG_BOOTX_TEXT | ||
278 | static void btext_putc(unsigned char c) | ||
279 | { | ||
280 | btext_drawchar(c); | ||
281 | } | ||
282 | |||
283 | static void __init init_boot_display(void) | ||
284 | { | ||
285 | char *name; | ||
286 | struct device_node *np = NULL; | ||
287 | int rc = -ENODEV; | ||
288 | |||
289 | printk("trying to initialize btext ...\n"); | ||
290 | |||
291 | name = (char *)get_property(of_chosen, "linux,stdout-path", NULL); | ||
292 | if (name != NULL) { | ||
293 | np = of_find_node_by_path(name); | ||
294 | if (np != NULL) { | ||
295 | if (strcmp(np->type, "display") != 0) { | ||
296 | printk("boot stdout isn't a display !\n"); | ||
297 | of_node_put(np); | ||
298 | np = NULL; | ||
299 | } | ||
300 | } | ||
301 | } | ||
302 | if (np) | ||
303 | rc = btext_initialize(np); | ||
304 | if (rc == 0) | ||
305 | return; | ||
306 | |||
307 | for (np = NULL; (np = of_find_node_by_type(np, "display"));) { | ||
308 | if (get_property(np, "linux,opened", NULL)) { | ||
309 | printk("trying %s ...\n", np->full_name); | ||
310 | rc = btext_initialize(np); | ||
311 | printk("result: %d\n", rc); | ||
312 | } | ||
313 | if (rc == 0) | ||
314 | return; | ||
315 | } | ||
316 | } | ||
317 | #endif /* CONFIG_BOOTX_TEXT */ | ||
318 | |||
319 | /* | 277 | /* |
320 | * Early initialization. | 278 | * Early initialization. |
321 | */ | 279 | */ |
@@ -333,13 +291,6 @@ static void __init pmac_init_early(void) | |||
333 | sccdbg = 1; | 291 | sccdbg = 1; |
334 | udbg_init_scc(NULL); | 292 | udbg_init_scc(NULL); |
335 | } | 293 | } |
336 | #ifdef CONFIG_BOOTX_TEXT | ||
337 | else { | ||
338 | init_boot_display(); | ||
339 | |||
340 | udbg_putc = btext_putc; | ||
341 | } | ||
342 | #endif /* CONFIG_BOOTX_TEXT */ | ||
343 | 294 | ||
344 | /* Setup interrupt mapping options */ | 295 | /* Setup interrupt mapping options */ |
345 | ppc64_interrupt_controller = IC_OPEN_PIC; | 296 | ppc64_interrupt_controller = IC_OPEN_PIC; |
diff --git a/arch/ppc64/kernel/setup.c b/arch/ppc64/kernel/setup.c index b7885028fcf1..44ee6ebe9a60 100644 --- a/arch/ppc64/kernel/setup.c +++ b/arch/ppc64/kernel/setup.c | |||
@@ -585,6 +585,10 @@ void __init setup_system(void) | |||
585 | */ | 585 | */ |
586 | finish_device_tree(); | 586 | finish_device_tree(); |
587 | 587 | ||
588 | #ifdef CONFIG_BOOTX_TEXT | ||
589 | init_boot_display(); | ||
590 | #endif | ||
591 | |||
588 | /* | 592 | /* |
589 | * Initialize xmon | 593 | * Initialize xmon |
590 | */ | 594 | */ |