From 819e36b8ceadb1d67db1ffe91b99c5282bfc6159 Mon Sep 17 00:00:00 2001 From: "H. Nikolaus Schaller" Date: Fri, 20 Apr 2012 14:10:36 +0200 Subject: tree moved to a better location --- cpu/omap4/cpu.c | 79 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 79 insertions(+) create mode 100644 cpu/omap4/cpu.c (limited to 'cpu/omap4/cpu.c') diff --git a/cpu/omap4/cpu.c b/cpu/omap4/cpu.c new file mode 100644 index 0000000..698bbdf --- /dev/null +++ b/cpu/omap4/cpu.c @@ -0,0 +1,79 @@ +/* + * (C) Copyright 2004-2009 Texas Insturments + * + * (C) Copyright 2002 + * Sysgo Real-Time Solutions, GmbH + * Marius Groeger + * + * (C) Copyright 2002 + * Gary Jennejohn, DENX Software Engineering, + * + * See file CREDITS for list of people who contributed to this + * project. + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * version 2 as published by the Free Software Foundation. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, + * MA 02111-1307 USA + */ + +/* + * CPU specific code + */ + +#include +#include + +/* See also ARM Ref. Man. */ +#define C1_MMU (1<<0) /* mmu off/on */ +#define C1_ALIGN (1<<1) /* alignment faults off/on */ +#define C1_DC (1<<2) /* dcache off/on */ +#define C1_WB (1<<3) /* merging write buffer on/off */ +#define C1_BIG_ENDIAN (1<<7) /* big endian off/on */ +#define C1_SYS_PROT (1<<8) /* system protection */ +#define C1_ROM_PROT (1<<9) /* ROM protection */ +#define C1_IC (1<<12) /* icache off/on */ +#define C1_HIGH_VECTORS (1<<13) /* location of vectors: low/high addresses */ +#define RESERVED_1 (0xf << 3) /* must be 111b for R/W */ + +int cpu_init (void) +{ + return 0; +} + +unsigned int cortex_a9_rev(void) +{ + + unsigned int i; + + /* turn off I/D-cache */ + asm ("mrc p15, 0, %0, c0, c0, 0" : "=r" (i)); + + return i; +} + +unsigned int omap_revision(void) +{ + unsigned int rev = cortex_a9_rev(); + + switch(rev) { + case 0x410FC091: + return OMAP4430_ES1_0; + case 0x411FC092: + if (__raw_readl(0x4a002204) == 0x3b95c02f) + return OMAP4430_ES2_1; + else + return OMAP4430_ES2_0; + default: + return OMAP4430_SILICON_ID_INVALID; + } +} -- cgit v1.1