Source-Changes-HG archive

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

[src/trunk]: src/sys/arch Finish CPU core support for Octeon Cavium CN70XX:



details:   https://anonhg.NetBSD.org/src/rev/2269706bd479
branches:  trunk
changeset: 1011030:2269706bd479
user:      simonb <simonb%NetBSD.org@localhost>
date:      Mon Jun 15 07:48:12 2020 +0000

description:
Finish CPU core support for Octeon Cavium CN70XX:
 - decode actual CPU name
 - per CPU core reset logic (partially adapted from OpenBSD)
 - handle Octeon 3 ioclock rate differences to other cores (from OpenBSD)

diffstat:

 sys/arch/evbmips/cavium/machdep.c      |   27 +--
 sys/arch/mips/cavium/dev/octeon_uart.c |    8 +-
 sys/arch/mips/cavium/octeon_misc.c     |  273 +++++++++++++++++++++++++++++++++
 sys/arch/mips/cavium/octeonreg.h       |   66 +++++++
 sys/arch/mips/cavium/octeonvar.h       |   40 +++-
 sys/arch/mips/conf/files.octeon        |    3 +-
 sys/arch/mips/mips/mips_machdep.c      |   13 +-
 7 files changed, 388 insertions(+), 42 deletions(-)

diffs (truncated from 570 to 300 lines):

diff -r 0eabab897d05 -r 2269706bd479 sys/arch/evbmips/cavium/machdep.c
--- a/sys/arch/evbmips/cavium/machdep.c Mon Jun 15 03:39:00 2020 +0000
+++ b/sys/arch/evbmips/cavium/machdep.c Mon Jun 15 07:48:12 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: machdep.c,v 1.13 2020/06/05 07:17:38 simonb Exp $      */
+/*     $NetBSD: machdep.c,v 1.14 2020/06/15 07:48:12 simonb Exp $      */
 
 /*
  * Copyright 2001, 2002 Wasabi Systems, Inc.
@@ -115,7 +115,7 @@
 #include "opt_cavium.h"
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: machdep.c,v 1.13 2020/06/05 07:17:38 simonb Exp $");
+__KERNEL_RCSID(0, "$NetBSD: machdep.c,v 1.14 2020/06/15 07:48:12 simonb Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -191,7 +191,6 @@
 mach_init(uint64_t arg0, uint64_t arg1, uint64_t arg2, uint64_t arg3)
 {
        uint64_t btinfo_paddr;
-       int corefreq;
 
        /* clear the BSS segment */
        memset(edata, 0, end - edata);
@@ -205,20 +204,10 @@
            (struct octeon_btinfo *)MIPS_PHYS_TO_KSEG0(btinfo_paddr),
            sizeof(octeon_btinfo));
 
-       corefreq = octeon_btinfo.obt_eclock_hz;
-
-       octeon_cal_timer(corefreq);
+       octeon_cal_timer(octeon_btinfo.obt_eclock_hz);
 
-       switch (MIPS_PRID_IMPL(mips_options.mips_cpu_id)) {
-       case 0: cpu_setmodel("Cavium Octeon CN38XX/CN36XX"); break;
-       case 1: cpu_setmodel("Cavium Octeon CN31XX/CN3020"); break;
-       case 2: cpu_setmodel("Cavium Octeon CN3005/CN3010"); break;
-       case 3: cpu_setmodel("Cavium Octeon CN58XX"); break;
-       case 4: cpu_setmodel("Cavium Octeon CN5[4-7]XX"); break;
-       case 6: cpu_setmodel("Cavium Octeon CN50XX"); break;
-       case 7: cpu_setmodel("Cavium Octeon CN52XX"); break;
-       default: cpu_setmodel("Cavium Octeon"); break;
-       }
+       cpu_setmodel("Cavium Octeon %s",
+           octeon_cpu_model(mips_options.mips_cpu_id));
 
        mach_init_vector();
 
@@ -459,11 +448,7 @@
         */
        delay(80000);
 
-       /* initiate chip soft-reset */
-       uint64_t fuse = octeon_read_csr(CIU_FUSE);
-       octeon_write_csr(CIU_SOFT_BIST, fuse);
-       octeon_read_csr(CIU_SOFT_RST);
-       octeon_write_csr(CIU_SOFT_RST, fuse);
+       octeon_soft_reset();
 
        delay(1000000);
 
diff -r 0eabab897d05 -r 2269706bd479 sys/arch/mips/cavium/dev/octeon_uart.c
--- a/sys/arch/mips/cavium/dev/octeon_uart.c    Mon Jun 15 03:39:00 2020 +0000
+++ b/sys/arch/mips/cavium/dev/octeon_uart.c    Mon Jun 15 07:48:12 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: octeon_uart.c,v 1.5 2020/05/31 14:05:21 simonb Exp $   */
+/*     $NetBSD: octeon_uart.c,v 1.6 2020/06/15 07:48:12 simonb Exp $   */
 
 /*
  * Copyright (c) 2007 Internet Initiative Japan, Inc.
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: octeon_uart.c,v 1.5 2020/05/31 14:05:21 simonb Exp $");
+__KERNEL_RCSID(0, "$NetBSD: octeon_uart.c,v 1.6 2020/06/15 07:48:12 simonb Exp $");
 
 #include "opt_octeon.h"
 
@@ -139,7 +139,7 @@
        }
 
        sc_com->sc_type = COM_TYPE_16550_NOERS;
-       sc_com->sc_frequency = curcpu()->ci_cpu_freq;
+       sc_com->sc_frequency = octeon_ioclock_speed();
        sc_com->enable = octuart_com_enable;
        sc_com->disable = octuart_com_disable;
 
@@ -205,7 +205,7 @@
        return comcnattach1(
                &regs,
                speed,
-               curcpu()->ci_cpu_freq,
+               octeon_ioclock_speed(),
                COM_TYPE_16550_NOERS,
                CONMODE);
 }
diff -r 0eabab897d05 -r 2269706bd479 sys/arch/mips/cavium/octeon_misc.c
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/sys/arch/mips/cavium/octeon_misc.c        Mon Jun 15 07:48:12 2020 +0000
@@ -0,0 +1,273 @@
+/*     $NetBSD: octeon_misc.c,v 1.1 2020/06/15 07:48:12 simonb Exp $   */
+
+/*-
+ * Copyright (c) 2020 The NetBSD Foundation, Inc.
+ * All rights reserved.
+ *
+ * This code is derived from software contributed to The NetBSD Foundation
+ * by Simon Burge.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
+ * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
+ * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ */
+
+/*
+ * Copyright (c) 2009, 2010 Miodrag Vallat.
+ * Copyright (c) 2019 Visa Hankala.
+ *
+ * Permission to use, copy, modify, and distribute this software for any
+ * purpose with or without fee is hereby granted, provided that the above
+ * copyright notice and this permission notice appear in all copies.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+ * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+ * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+ * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+ * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+ * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+ * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+ */
+/*
+ * Copyright (c) 2003-2004 Opsycon AB  (www.opsycon.se / www.opsycon.com)
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ *    notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ *    notice, this list of conditions and the following disclaimer in the
+ *    documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS
+ * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+ * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
+ * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ *
+ */
+
+#include <sys/cdefs.h>
+__KERNEL_RCSID(0, "$NetBSD: octeon_misc.c,v 1.1 2020/06/15 07:48:12 simonb Exp $");
+
+#include <sys/param.h>
+
+#include <mips/cavium/octeonreg.h>
+#include <mips/cavium/octeonvar.h>
+#include <mips/cavium/dev/octeon_ciureg.h>
+
+int    octeon_core_ver;
+
+/*
+ * Return the name of the CPU model we are running on.
+ * Side effect: sets the octeon_core_ver variable.
+ */
+const char *
+octeon_cpu_model(mips_prid_t cpu_id)
+{
+       const uint64_t fuse = octeon_xkphys_read_8(CIU_FUSE);
+       const int numcores = popcount64(fuse);
+       const int clock_mhz = curcpu()->ci_cpu_freq / 1000000;
+       const char *family;
+       const char *coremodel;
+       bool tested;
+       static char buf[sizeof("CNnnXX-NNNN (unverified)")] = {};
+
+       if (buf[0] != 0)
+               return buf;             /* we've been here before */
+
+       /* 
+        * Don't print "pass X.Y", but if needed:
+        *      passhi = ((cpu_id >> 3) & 7) + '0';
+        *      passlo = (cpu_id & 7) + '0';
+        * Note some chips use different representation for the pass number.
+        */
+
+#ifdef OCTEON_DEBUG
+       printf("cpuid = 0x%x\n", cpu_id);
+#endif
+
+       switch (numcores) {
+       case  1: coremodel = "10"; break;
+       case  2: coremodel = "20"; break;
+       case  3: coremodel = "25"; break;
+       case  4: coremodel = "30"; break;
+       case  5: coremodel = "32"; break;
+       case  6: coremodel = "34"; break;
+       case  7: coremodel = "38"; break;
+       case  8: coremodel = "40"; break;
+       case  9: coremodel = "42"; break;
+       case 10: coremodel = "45"; break;
+       case 11: coremodel = "48"; break;
+       case 12: coremodel = "50"; break;
+       case 13: coremodel = "52"; break;
+       case 14: coremodel = "55"; break;
+       case 15: coremodel = "58"; break;
+       case 16: coremodel = "60"; break;
+       case 24: coremodel = "70"; break;
+       case 32: coremodel = "80"; break;
+       case 40: coremodel = "85"; break;
+       case 44: coremodel = "88"; break;
+       case 48: coremodel = "90"; break;
+       default:
+               coremodel = "XX"; break;
+       }
+
+       /*
+         * Assume all CPU families haven't been tested unless explicitly
+         * noted.  Sources of extra information for determining actual
+         * CPU models include chip documentation and U-Boot source code.
+        */
+       tested = false;
+
+       switch (MIPS_PRID_IMPL(cpu_id)) {
+       /* the order of these cases is the numeric value of MIPS_CNnnXX */
+       case MIPS_CN38XX:
+               family = "38";  /* XXX may also be family "36" or "37" */
+               octeon_core_ver = OCTEON_1;
+               break;
+       case MIPS_CN31XX:
+               family = "31";  /* XXX may also be model "3020" */
+               octeon_core_ver = OCTEON_1;
+               break;
+       case MIPS_CN30XX:
+               family = "30";  /* XXX half cache model is "3005" */
+               octeon_core_ver = OCTEON_1;
+               break;
+       case MIPS_CN58XX:
+               family = "58";
+               octeon_core_ver = OCTEON_PLUS;
+               break;
+       case MIPS_CN56XX:
+               family = "56";  /* XXX may also be family "54", "55" or "57" */
+               octeon_core_ver = OCTEON_PLUS;
+               break;
+       case MIPS_CN50XX:
+               family = "50";
+               octeon_core_ver = OCTEON_PLUS;
+               tested = true;
+               break;
+       case MIPS_CN52XX:
+               family = "52";  /* XXX may also be family "51" */
+               octeon_core_ver = OCTEON_PLUS;
+               break;
+       case MIPS_CN63XX:
+               family = "63";  /* XXX may also be family "62" */
+               octeon_core_ver = OCTEON_2;
+               break;
+       case MIPS_CN68XX:
+               family = "68";
+               octeon_core_ver = OCTEON_2;
+               break;
+       case MIPS_CN66XX:
+               family = "66";
+               octeon_core_ver = OCTEON_2;
+               break;
+       case MIPS_CN61XX:
+               family = "61";  /* XXX may also be family "60" */
+               octeon_core_ver = OCTEON_2;
+               break;
+       case MIPS_CN78XX:
+               family = "78";  /* XXX may also be family "76" or "77" */
+               octeon_core_ver = OCTEON_3;
+               break;



Home | Main Index | Thread Index | Old Index