diff --git a/sys/boot/ofw/libofw/Makefile b/sys/boot/ofw/libofw/Makefile index 8a56a778f76f..0e45708cd5d9 100644 --- a/sys/boot/ofw/libofw/Makefile +++ b/sys/boot/ofw/libofw/Makefile @@ -14,7 +14,7 @@ CFLAGS+= -I${.CURDIR}/../../common -I${.CURDIR}/../../.. -I. CFLAGS+= -ffreestanding .if ${MACHINE_ARCH} == "powerpc" -CFLAGS+= -msoft-float +CFLAGS+= -msoft-float -DPOWERMAC_SCREEN_HACK .endif .ifdef(BOOT_DISK_DEBUG) diff --git a/sys/boot/ofw/libofw/ofw_console.c b/sys/boot/ofw/libofw/ofw_console.c index 59ce9a5067d5..560dd9f03bc7 100644 --- a/sys/boot/ofw/libofw/ofw_console.c +++ b/sys/boot/ofw/libofw/ofw_console.c @@ -42,6 +42,10 @@ int ofw_cons_poll(void); static ihandle_t stdin; static ihandle_t stdout; +#ifdef POWERMAC_SCREEN_HACK +static ihandle_t stdout1; +static int do_stdout1 = 0; +#endif struct console ofwconsole = { "ofw", @@ -57,9 +61,26 @@ struct console ofwconsole = { static void ofw_cons_probe(struct console *cp) { +#ifdef POWERMAC_SCREEN_HACK + char path1[128], path2[128]; +#endif OF_getprop(chosen, "stdin", &stdin, sizeof(stdin)); OF_getprop(chosen, "stdout", &stdout, sizeof(stdout)); +#ifdef POWERMAC_SCREEN_HACK + stdout1 = OF_open("screen"); + if (stdout1 != -1) { + if (OF_instance_to_path(stdout, path1, sizeof(path1)) == -1) + path1[0] = '\0'; + if (OF_instance_to_path(stdout1, path2, sizeof(path2)) == -1) + path2[0] = '\0'; + if (strcmp(path1, path2) == 0) { + OF_close(stdout1); + } else { + do_stdout1 = 1; + } + } +#endif cp->c_flags |= C_PRESENTIN|C_PRESENTOUT; } @@ -77,10 +98,18 @@ ofw_cons_putchar(int c) if (c == '\n') { cbuf = '\r'; OF_write(stdout, &cbuf, 1); +#ifdef POWERMAC_SCREEN_HACK + if (do_stdout1 != 0) + OF_write(stdout1, &cbuf, 1); +#endif } cbuf = c; OF_write(stdout, &cbuf, 1); +#ifdef POWERMAC_SCREEN_HACK + if (do_stdout1 != 0) + OF_write(stdout1, &cbuf, 1); +#endif } static int saved_char = -1;