1213496Scognet/*- 2213496Scognet * Copyright (c) 2009 Greg Ansley All rights reserved. 3213496Scognet * 4213496Scognet * Redistribution and use in source and binary forms, with or without 5213496Scognet * modification, are permitted provided that the following conditions 6213496Scognet * are met: 7213496Scognet * 1. Redistributions of source code must retain the above copyright 8213496Scognet * notice, this list of conditions and the following disclaimer. 9213496Scognet * 2. Redistributions in binary form must reproduce the above copyright 10213496Scognet * notice, this list of conditions and the following disclaimer in the 11213496Scognet * documentation and/or other materials provided with the distribution. 12213496Scognet * 13213496Scognet * THIS SOFTWARE IS PROVIDED BY AUTHOR AND CONTRIBUTORS ``AS IS'' AND 14213496Scognet * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 15213496Scognet * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 16213496Scognet * ARE DISCLAIMED. IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE 17213496Scognet * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 18213496Scognet * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 19213496Scognet * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 20213496Scognet * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 21213496Scognet * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 22213496Scognet * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 23213496Scognet * SUCH DAMAGE. 24213496Scognet */ 25213496Scognet 26213496Scognet/* 27213496Scognet * $FreeBSD$ 28213496Scognet */ 29213496Scognet 30213496Scognet#ifndef _AT91REG_H_ 31236080Smarius#define _AT91REG_H_ 32213496Scognet 33213496Scognet#include "opt_at91.h" 34213496Scognet 35213496Scognet/* Where builtin peripherals start in KVM */ 36236080Smarius#define AT91_BASE 0xd0000000 37213496Scognet 38213496Scognet/* A few things that we count on being the same 39213496Scognet * throught the whole family of SOCs */ 40213496Scognet 41213496Scognet/* SYSC System Controler */ 42213496Scognet/* System Registers */ 43236080Smarius#define AT91_SYS_BASE 0xffff000 44236080Smarius#define AT91_SYS_SIZE 0x1000 45213496Scognet 46213496Scognet#if defined(AT91SAM9G45) || defined(AT91SAM9263) 47236080Smarius#define AT91_DBGU_BASE 0xfffee00 48213496Scognet#else 49236080Smarius#define AT91_DBGU_BASE 0xffff200 50213496Scognet#endif 51236080Smarius#define AT91_DBGU_SIZE 0x200 52236080Smarius#define DBGU_C1R (64) /* Chip ID1 Register */ 53236080Smarius#define DBGU_C2R (68) /* Chip ID2 Register */ 54236080Smarius#define DBGU_FNTR (72) /* Force NTRST Register */ 55213496Scognet 56236080Smarius#define AT91_CPU_VERSION_MASK 0x0000001f 57236080Smarius#define AT91_CPU_RM9200 0x09290780 58236080Smarius#define AT91_CPU_SAM9260 0x019803a0 59236080Smarius#define AT91_CPU_SAM9261 0x019703a0 60236080Smarius#define AT91_CPU_SAM9263 0x019607a0 61236080Smarius#define AT91_CPU_SAM9G10 0x819903a0 62236080Smarius#define AT91_CPU_SAM9G20 0x019905a0 63236080Smarius#define AT91_CPU_SAM9G45 0x819b05a0 64236081Smarius#define AT91_CPU_SAM9XE128 0x329973a0 65236081Smarius#define AT91_CPU_SAM9XE256 0x329a93a0 66236081Smarius#define AT91_CPU_SAM9XE512 0x329aa3a0 67213496Scognet 68236080Smarius#define AT91_ARCH(chipid) ((chipid >> 20) & 0xff) 69236080Smarius#define AT91_CPU(chipid) (chipid & ~AT91_CPU_VERSION_MASK) 70236080Smarius#define AT91_ARCH_SAM9 (0x19) 71236080Smarius#define AT91_ARCH_SAM9XE (0x29) 72236080Smarius#define AT91_ARCH_RM92 (0x92) 73213496Scognet 74213496Scognet#endif /* _AT91REG_H_ */ 75