Source-Changes-HG archive

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

[src/trunk]: src/sys/arch Disable BSC0 on Raspberry Pi 3 and Zero W boards.



details:   https://anonhg.NetBSD.org/src/rev/0c2ab327a95d
branches:  trunk
changeset: 354468:0c2ab327a95d
user:      jmcneill <jmcneill%NetBSD.org@localhost>
date:      Sat Jun 17 17:03:40 2017 +0000

description:
Disable BSC0 on Raspberry Pi 3 and Zero W boards.

diffstat:

 sys/arch/arm/broadcom/bcm2835_bsc.c |  13 +++++++++++--
 sys/arch/evbarm/rpi/rpi_machdep.c   |  19 +++++++++++++++++--
 sys/arch/evbarm/rpi/vcprop.h        |  24 +++++++++++++++++++++++-
 3 files changed, 51 insertions(+), 5 deletions(-)

diffs (121 lines):

diff -r f864e9fa5e84 -r 0c2ab327a95d sys/arch/arm/broadcom/bcm2835_bsc.c
--- a/sys/arch/arm/broadcom/bcm2835_bsc.c       Sat Jun 17 16:34:07 2017 +0000
+++ b/sys/arch/arm/broadcom/bcm2835_bsc.c       Sat Jun 17 17:03:40 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: bcm2835_bsc.c,v 1.5 2015/01/24 00:27:31 jakllsch Exp $ */
+/*     $NetBSD: bcm2835_bsc.c,v 1.6 2017/06/17 17:03:40 jmcneill Exp $ */
 
 /*
  * Copyright (c) 2012 Jonathan A. Kollasch
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: bcm2835_bsc.c,v 1.5 2015/01/24 00:27:31 jakllsch Exp $");
+__KERNEL_RCSID(0, "$NetBSD: bcm2835_bsc.c,v 1.6 2017/06/17 17:03:40 jmcneill Exp $");
 
 #include <sys/param.h>
 #include <sys/bus.h>
@@ -99,8 +99,10 @@
 {
        struct bsciic_softc * const sc = device_private(self);
        struct amba_attach_args * const aaa = aux;
+       prop_dictionary_t prop = device_properties(self);
        struct i2cbus_attach_args iba;
        u_int bscunit = ~0;
+       bool disable = false;
        static ONCE_DECL(control);
 
        switch (aaa->aaa_addr) {
@@ -112,6 +114,13 @@
                break;
        }
 
+       prop_dictionary_get_bool(prop, "disable", &disable);
+       if (disable) {
+               aprint_naive(": disabled\n");
+               aprint_normal(": disabled\n");
+               return;
+       }
+
        aprint_naive("\n");
        aprint_normal(": BSC%u\n", bscunit);
 
diff -r f864e9fa5e84 -r 0c2ab327a95d sys/arch/evbarm/rpi/rpi_machdep.c
--- a/sys/arch/evbarm/rpi/rpi_machdep.c Sat Jun 17 16:34:07 2017 +0000
+++ b/sys/arch/evbarm/rpi/rpi_machdep.c Sat Jun 17 17:03:40 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: rpi_machdep.c,v 1.70 2017/01/06 14:55:37 skrll Exp $   */
+/*     $NetBSD: rpi_machdep.c,v 1.71 2017/06/17 17:03:40 jmcneill Exp $        */
 
 /*-
  * Copyright (c) 2012 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: rpi_machdep.c,v 1.70 2017/01/06 14:55:37 skrll Exp $");
+__KERNEL_RCSID(0, "$NetBSD: rpi_machdep.c,v 1.71 2017/06/17 17:03:40 jmcneill Exp $");
 
 #include "opt_arm_debug.h"
 #include "opt_bcm283x.h"
@@ -1201,6 +1201,21 @@
                }
        }
 #endif
+
+       /* BSC0 is used internally on some boards */
+       if (device_is_a(dev, "bsciic") &&
+           ((struct amba_attach_args *)aux)->aaa_addr == BCM2835_BSC0_BASE) {
+               const uint32_t rev = vb.vbt_boardrev.rev;
+
+               if ((rev & VCPROP_REV_ENCFLAG) != 0) {
+                       switch (__SHIFTOUT(rev, VCPROP_REV_MODEL)) {
+                       case RPI_MODEL_B_PI3:
+                       case RPI_MODEL_ZERO_W:
+                               prop_dictionary_set_bool(dict, "disable", true);
+                               break;
+                       }
+               }
+       }
 }
 
 SYSCTL_SETUP(sysctl_machdep_rpi, "sysctl machdep subtree setup (rpi)")
diff -r f864e9fa5e84 -r 0c2ab327a95d sys/arch/evbarm/rpi/vcprop.h
--- a/sys/arch/evbarm/rpi/vcprop.h      Sat Jun 17 16:34:07 2017 +0000
+++ b/sys/arch/evbarm/rpi/vcprop.h      Sat Jun 17 17:03:40 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: vcprop.h,v 1.15 2016/04/03 11:02:17 mlelstv Exp $      */
+/*     $NetBSD: vcprop.h,v 1.16 2017/06/17 17:03:40 jmcneill Exp $     */
 
 /*-
  * Copyright (c) 2012 The NetBSD Foundation, Inc.
@@ -137,6 +137,28 @@
        uint32_t rev;
 } ;
 
+#define        VCPROP_REV_PCBREV       __BITS(3,0)
+#define        VCPROP_REV_MODEL        __BITS(11,4)
+#define         RPI_MODEL_A            0
+#define         RPI_MODEL_B            1
+#define         RPI_MODEL_A_PLUS       2
+#define         RPI_MODEL_B_PLUS       3
+#define         RPI_MODEL_B_PI2        4
+#define         RPI_MODEL_ALPHA        5
+#define         RPI_MODEL_COMPUTE      6
+#define         RPI_MODEL_ZERO         7
+#define         RPI_MODEL_B_PI3        8
+#define         RPI_MODEL_COMPUTE_PI3  9
+#define         RPI_MODEL_ZERO_W       10
+#define        VCPROP_REV_PROCESSOR    __BITS(15,12)
+#define         RPI_PROCESSOR_BCM2835  0
+#define         RPI_PROCESSOR_BCM2836  1
+#define         RPI_PROCESSOR_BCM2837  2
+#define        VCPROP_REV_MANUF        __BITS(19,16)
+#define        VCPROP_REV_MEMSIZE      __BITS(22,20)
+#define        VCPROP_REV_ENCFLAG      __BIT(23)
+#define        VCPROP_REV_WARRANTY     __BITS(25,24)
+
 struct vcprop_tag_macaddr {
        struct vcprop_tag tag;
        uint64_t addr;



Home | Main Index | Thread Index | Old Index