diff options
-rw-r--r-- | sys/arch/octeon/dev/cn30xxcorereg.h | 55 | ||||
-rw-r--r-- | sys/arch/octeon/octeon/locore.S | 6 |
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 */ |