Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/powerpc/oea Add a hack for qemu/macppc. OF_finddevi...



details:   https://anonhg.NetBSD.org/src/rev/22ae3ba3ce76
branches:  trunk
changeset: 1005067:22ae3ba3ce76
user:      joerg <joerg%NetBSD.org@localhost>
date:      Wed Nov 27 21:07:32 2019 +0000

description:
Add a hack for qemu/macppc. OF_finddevice calls will crash depending on
the boot loader and kernel being used. This patch allows using
-prom-env qemu_boot_hack=y to disable the lookup.

diffstat:

 sys/arch/powerpc/oea/ofw_autoconf.c |  19 +++++++++++++------
 1 files changed, 13 insertions(+), 6 deletions(-)

diffs (40 lines):

diff -r f84b498b1e82 -r 22ae3ba3ce76 sys/arch/powerpc/oea/ofw_autoconf.c
--- a/sys/arch/powerpc/oea/ofw_autoconf.c       Wed Nov 27 20:58:25 2019 +0000
+++ b/sys/arch/powerpc/oea/ofw_autoconf.c       Wed Nov 27 21:07:32 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ofw_autoconf.c,v 1.23 2018/11/21 17:54:42 scole Exp $ */
+/* $NetBSD: ofw_autoconf.c,v 1.24 2019/11/27 21:07:32 joerg Exp $ */
 /*
  * Copyright (C) 1995, 1996 Wolfgang Solfrank.
  * Copyright (C) 1995, 1996 TooLs GmbH.
@@ -31,7 +31,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ofw_autoconf.c,v 1.23 2018/11/21 17:54:42 scole Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ofw_autoconf.c,v 1.24 2019/11/27 21:07:32 joerg Exp $");
 
 #ifdef ofppc
 #include "gtpci.h"
@@ -137,10 +137,17 @@
         *   /pci/mac-io/ata-3@2000/disk@0:0/netbsd.new         (OF-3.x)
         */
        strcpy(cbootpath, bootpath);
-       while ((node = OF_finddevice(cbootpath)) == -1) {
-               if ((p = strrchr(cbootpath, '/')) == NULL)
-                       break;
-               *p = '\0';
+
+       if ((node = OF_finddevice("/options")) == -1 ||
+           OF_getprop(node, "qemu_boot_hack", type, sizeof(type) - 1) == -1 ||
+           type[0] != 'y') {
+               while ((node = OF_finddevice(cbootpath)) == -1) {
+                       if ((p = strrchr(cbootpath, '/')) == NULL)
+                               break;
+                       *p = '\0';
+               }
+       } else {
+               node = -1;
        }
 
        printf("bootpath: %s\n", bootpath);



Home | Main Index | Thread Index | Old Index