Source-Changes-HG archive

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

[src/netbsd-8]: src/sys/arch/powerpc/oea Pull up following revision(s) (reque...



details:   https://anonhg.NetBSD.org/src/rev/10f48d12c7c0
branches:  netbsd-8
changeset: 465857:10f48d12c7c0
user:      bouyer <bouyer%NetBSD.org@localhost>
date:      Thu Dec 05 16:53:06 2019 +0000

description:
Pull up following revision(s) (requested by joerg in ticket #1465):
        sys/arch/powerpc/oea/ofw_autoconf.c: revision 1.24
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 4c37e2f853d9 -r 10f48d12c7c0 sys/arch/powerpc/oea/ofw_autoconf.c
--- a/sys/arch/powerpc/oea/ofw_autoconf.c       Thu Dec 05 16:50:54 2019 +0000
+++ b/sys/arch/powerpc/oea/ofw_autoconf.c       Thu Dec 05 16:53:06 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ofw_autoconf.c,v 1.20 2014/02/18 12:27:15 macallan Exp $ */
+/* $NetBSD: ofw_autoconf.c,v 1.20.22.1 2019/12/05 16:53:06 bouyer 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.20 2014/02/18 12:27:15 macallan Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ofw_autoconf.c,v 1.20.22.1 2019/12/05 16:53:06 bouyer 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