summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authoryasuoka <yasuoka@openbsd.org>2014-03-13 02:17:13 +0000
committeryasuoka <yasuoka@openbsd.org>2014-03-13 02:17:13 +0000
commitd8671520e2d8d38c72f6c0b0599c58740042fccc (patch)
treeded36081fbf10a004ffccb200e1134e6086f4f26
parentmerge conflicts (diff)
downloadwireguard-openbsd-d8671520e2d8d38c72f6c0b0599c58740042fccc.tar.xz
wireguard-openbsd-d8671520e2d8d38c72f6c0b0599c58740042fccc.zip
Drop the REPUN bit from CvmCtl register not to allow unaligned access.
Also add new cn30xxcorereg.h to provide constant variables of octeon core.
-rw-r--r--sys/arch/octeon/dev/cn30xxcorereg.h55
-rw-r--r--sys/arch/octeon/octeon/locore.S6
2 files changed, 59 insertions, 2 deletions
diff --git a/sys/arch/octeon/dev/cn30xxcorereg.h b/sys/arch/octeon/dev/cn30xxcorereg.h
new file mode 100644
index 00000000000..b4e12114a07
--- /dev/null
+++ b/sys/arch/octeon/dev/cn30xxcorereg.h
@@ -0,0 +1,55 @@
+/* $OpenBSD: cn30xxcorereg.h,v 1.1 2014/03/13 02:17:13 yasuoka Exp $ */
+
+/*
+ * Copyright (c) 2014 YASUOKA Masahiko <yasuoka@openbsd.org>
+ *
+ * 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.
+ */
+
+#ifndef _CN30XXCOREREG_H_
+#define _CN30XXCOREREG_H_
+
+/*
+ * Cavium Networks OCTEON CN30XX Hardware Reference Manual CN30XX-HM-1.0
+ * 4. cnMIPS Cores
+ */
+
+/* 4.11 Core Coprocessor 0 Privileged Registers */
+
+/* CvmCtl Registers */
+#define COP_0_CVMCTL_FUSE_START_BIT 0x80000000
+#define COP_0_CVMCTL_NOFDA_CP2 0x10000000
+#define COP_0_CVMCTL_NOMUL 0x08000000
+#define COP_0_CVMCTL_NOCRYPTO 0x04000000
+#define COP_0_CVMCTL_RST_SHT 0x02000000
+#define COP_0_CVMCTL_BIST_DIS 0x01000000
+#define COP_0_CVMCTL_DISSETPRED 0x00800000
+#define COP_0_CVMCTL_DISJRPRED 0x00400000
+#define COP_0_CVMCTL_DISICACHE 0x00200000
+#define COP_0_CVMCTL_DISWAIT 0x00100000
+#define COP_0_CVMCTL_DEFET 0x00080000
+#define COP_0_CVMCTL_DISCO 0x00040000
+#define COP_0_CVMCTL_DISCE 0x00020000
+#define COP_0_CVMCTL_DDCLK 0x00010000
+#define COP_0_CVMCTL_DCICLK 0x00008000
+#define COP_0_CVMCTL_REPUN 0x00004000
+#define COP_0_CVMCTL_IPREF 0x00002000
+#define COP_0_CVMCTL_USEUN 0x00001000
+#define COP_0_CVMCTL_DISIOCACHE 0x00000800
+#define COP_0_CVMCTL_IRAND 0x00000400
+#define COP_0_CVMCTL_IPPCI 0x00000380
+#define COP_0_CVMCTL_IPTI 0x00000070
+#define COP_0_CVMCTL_LE 0x00000002
+#define COP_0_CVMCTL_USELY 0x00000001
+
+#endif /* _CN30XXCOREREG_H_ */
diff --git a/sys/arch/octeon/octeon/locore.S b/sys/arch/octeon/octeon/locore.S
index 991ea37d4d2..fe86a51a103 100644
--- a/sys/arch/octeon/octeon/locore.S
+++ b/sys/arch/octeon/octeon/locore.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: locore.S,v 1.5 2012/10/03 11:18:23 miod Exp $ */
+/* $OpenBSD: locore.S,v 1.6 2014/03/13 02:17:13 yasuoka Exp $ */
/*
* Copyright (c) 2001-2004 Opsycon AB (www.opsycon.se / www.opsycon.com)
@@ -34,6 +34,7 @@
#include <mips64/mips_cpu.h>
#include <machine/regnum.h>
#include <machine/cpustate.h>
+#include <octeon/dev/cn30xxcorereg.h>
#include "assym.h"
@@ -48,7 +49,8 @@ start:
mtc0 t0, COP_0_EBASE
/* initialize cvmctl */
- dli t0, 0x900043F0
+ dli t0, COP_0_CVMCTL_FUSE_START_BIT|COP_0_CVMCTL_NOFDA_CP2|\
+ COP_0_CVMCTL_IPPCI|COP_0_CVMCTL_IPTI
dmtc0 t0, COP_0_CVMCTL
/* initialize cvmmemctl */