tsunamireg.h revision 1290
1/* 2 * Copyright (c) 2004 The Regents of The University of Michigan 3 * All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions are 7 * met: redistributions of source code must retain the above copyright 8 * notice, this list of conditions and the following disclaimer; 9 * redistributions in binary form must reproduce the above copyright 10 * notice, this list of conditions and the following disclaimer in the 11 * documentation and/or other materials provided with the distribution; 12 * neither the name of the copyright holders nor the names of its 13 * contributors may be used to endorse or promote products derived from 14 * this software without specific prior written permission. 15 * 16 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 17 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 18 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 19 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 20 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 21 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 22 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 26 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 27 */ 28 29#ifndef __TSUNAMIREG_H__ 30#define __TSUNAMIREG_H__ 31 32#define ALPHA_K0SEG_BASE ULL(0xfffffc0000000000) 33 34// CChip Registers 35#define TSDEV_CC_CSR 0x00 36#define TSDEV_CC_MTR 0x01 37#define TSDEV_CC_MISC 0x02 38 39#define TSDEV_CC_AAR0 0x04 40#define TSDEV_CC_AAR1 0x05 41#define TSDEV_CC_AAR2 0x06 42#define TSDEV_CC_AAR3 0x07 43#define TSDEV_CC_DIM0 0x08 44#define TSDEV_CC_DIM1 0x09 45#define TSDEV_CC_DIR0 0x0A 46#define TSDEV_CC_DIR1 0x0B 47#define TSDEV_CC_DRIR 0x0C 48#define TSDEV_CC_PRBEN 0x0D 49#define TSDEV_CC_IIC0 0x0E 50#define TSDEV_CC_IIC1 0x0F 51#define TSDEV_CC_MPR0 0x10 52#define TSDEV_CC_MPR1 0x11 53#define TSDEV_CC_MPR2 0x12 54#define TSDEV_CC_MPR3 0x13 55 56#define TSDEV_CC_DIM2 0x18 57#define TSDEV_CC_DIM3 0x19 58#define TSDEV_CC_DIR2 0x1A 59#define TSDEV_CC_DIR3 0x1B 60#define TSDEV_CC_IIC2 0x1C 61#define TSDEV_CC_IIC3 0x1D 62 63// BigTsunami Registers 64#define TSDEV_CC_BDIMS 0x1000000 65#define TSDEV_CC_BDIRS 0x2000000 66#define TSDEV_CC_IPIQ 0x20 //0xf01a000800 67#define TSDEV_CC_IPIR 0x21 //0xf01a000840 68#define TSDEV_CC_ITIR 0x22 //0xf01a000880 69 70 71// PChip Registers 72#define TSDEV_PC_WSBA0 0x00 73#define TSDEV_PC_WSBA1 0x01 74#define TSDEV_PC_WSBA2 0x02 75#define TSDEV_PC_WSBA3 0x03 76#define TSDEV_PC_WSM0 0x04 77#define TSDEV_PC_WSM1 0x05 78#define TSDEV_PC_WSM2 0x06 79#define TSDEV_PC_WSM3 0x07 80#define TSDEV_PC_TBA0 0x08 81#define TSDEV_PC_TBA1 0x09 82#define TSDEV_PC_TBA2 0x0A 83#define TSDEV_PC_TBA3 0x0B 84#define TSDEV_PC_PCTL 0x0C 85#define TSDEV_PC_PLAT 0x0D 86#define TSDEV_PC_RES 0x0E 87#define TSDEV_PC_PERROR 0x0F 88#define TSDEV_PC_PERRMASK 0x10 89#define TSDEV_PC_PERRSET 0x11 90#define TSDEV_PC_TLBIV 0x12 91#define TSDEV_PC_TLBIA 0x13 92#define TSDEV_PC_PMONCTL 0x14 93#define TSDEV_PC_PMONCNT 0x15 94 95#define TSDEV_PC_SPST 0x20 96 97 98// DChip Registers 99#define TSDEV_DC_DSC 0x20 100#define TSDEV_DC_STR 0x21 101#define TSDEV_DC_DREV 0x22 102#define TSDEV_DC_DSC2 0x23 103 104// I/O Ports 105#define TSDEV_PIC1_MASK 0x21 106#define TSDEV_PIC2_MASK 0xA1 107#define TSDEV_PIC1_ISR 0x20 108#define TSDEV_PIC2_ISR 0xA0 109#define TSDEV_PIC1_ACK 0x20 110#define TSDEV_PIC2_ACK 0xA0 111#define TSDEV_DMA1_RESET 0x0D 112#define TSDEV_DMA2_RESET 0xDA 113#define TSDEV_DMA1_MODE 0x0B 114#define TSDEV_DMA2_MODE 0xD6 115#define TSDEV_DMA1_MASK 0x0A 116#define TSDEV_DMA2_MASK 0xD4 117#define TSDEV_TMR_CTL 0x61 118#define TSDEV_TMR2_CTL 0x43 119#define TSDEV_TMR2_DATA 0x42 120#define TSDEV_TMR0_DATA 0x40 121 122#define TSDEV_RTC_ADDR 0x70 123#define TSDEV_RTC_DATA 0x71 124 125// RTC defines 126#define RTC_SECOND 0 // second of minute [0..59] 127#define RTC_SECOND_ALARM 1 // seconds to alarm 128#define RTC_MINUTE 2 // minute of hour [0..59] 129#define RTC_MINUTE_ALARM 3 // minutes to alarm 130#define RTC_HOUR 4 // hour of day [0..23] 131#define RTC_HOUR_ALARM 5 // hours to alarm 132#define RTC_DAY_OF_WEEK 6 // day of week [1..7] 133#define RTC_DAY_OF_MONTH 7 // day of month [1..31] 134#define RTC_MONTH 8 // month of year [1..12] 135#define RTC_YEAR 9 // year [00..99] 136#define RTC_CONTROL_REGISTERA 10 // control register A 137#define RTC_CONTROL_REGISTERB 11 // control register B 138#define RTC_CONTROL_REGISTERC 12 // control register C 139#define RTC_CONTROL_REGISTERD 13 // control register D 140#define RTC_REGNUMBER_RTC_CR1 0x6A // control register 1 141 142#define PCHIP_PCI0_MEMORY ULL(0x00000000000) 143#define PCHIP_PCI0_IO ULL(0x001FC000000) 144#define TSUNAMI_UNCACHABLE_BIT ULL(0x80000000000) 145#define TSUNAMI_PCI0_MEMORY TSUNAMI_UNCACHABLE_BIT + PCHIP_PCI0_MEMORY 146#define TSUNAMI_PCI0_IO TSUNAMI_UNCACHABLE_BIT + PCHIP_PCI0_IO 147 148 149// UART Defines 150#define UART_IER_RDI 0x01 151#define UART_IER_THRI 0x02 152#define UART_IER_RLSI 0x04 153 154 155#define UART_LSR_TEMT 0x40 156#define UART_LSR_THRE 0x20 157#define UART_LSR_DR 0x01 158 159#define UART_MCR_LOOP 0x10 160 161#endif // __TSUNAMIREG_H__ 162