1 1.5 skrll /* $NetBSD: at91dbgureg.h,v 1.5 2012/11/12 18:00:36 skrll Exp $ */ 2 1.2 matt 3 1.2 matt /* 4 1.2 matt * Copyright (c) 2007 Embedtronics Oy 5 1.2 matt * All rights reserved. 6 1.2 matt * 7 1.2 matt * Redistribution and use in source and binary forms, with or without 8 1.2 matt * modification, are permitted provided that the following conditions 9 1.2 matt * are met: 10 1.2 matt * 1. Redistributions of source code must retain the above copyright 11 1.2 matt * notice, this list of conditions and the following disclaimer. 12 1.2 matt * 2. Redistributions in binary form must reproduce the above copyright 13 1.2 matt * notice, this list of conditions and the following disclaimer in the 14 1.2 matt * documentation and/or other materials provided with the distribution. 15 1.2 matt * 16 1.2 matt * THIS SOFTWARE IS PROVIDED BY ICHIRO FUKUHARA ``AS IS'' AND ANY EXPRESS OR 17 1.2 matt * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 18 1.2 matt * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 19 1.2 matt * IN NO EVENT SHALL ICHIRO FUKUHARA OR THE VOICES IN HIS HEAD BE LIABLE FOR 20 1.2 matt * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 21 1.2 matt * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 22 1.2 matt * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 23 1.2 matt * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 24 1.2 matt * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 25 1.2 matt * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 26 1.2 matt * SUCH DAMAGE. 27 1.2 matt */ 28 1.2 matt 29 1.2 matt #ifndef _AT91DBGUREG_H_ 30 1.2 matt #define _AT91DBGUREG_H_ 31 1.2 matt 32 1.2 matt #define AT91DBGU_BASE 0xFFFFF200 /* DBGU unit base addresses (physical) */ 33 1.2 matt #define AT91DBGU_SIZE 0x200 /* DBGU peripheral address space size */ 34 1.2 matt 35 1.2 matt #define DBGU_CR 0x00UL /* Control Register */ 36 1.2 matt #define DBGU_MR 0x04UL /* Mode Register */ 37 1.2 matt #define DBGU_IER 0x08UL /* Interrupt Enable Register */ 38 1.2 matt #define DBGU_IDR 0x0CUL /* Interrupt Disable Register */ 39 1.2 matt #define DBGU_IMR 0x10UL /* Interrupt Mask Register */ 40 1.2 matt #define DBGU_SR 0x14UL /* Status Register */ 41 1.2 matt #define DBGU_RHR 0x18UL /* Receive Holding Register */ 42 1.2 matt #define DBGU_THR 0x1CUL /* Transmit Holding Register */ 43 1.2 matt #define DBGU_BRGR 0x20UL /* Baud Rate Generator Register */ 44 1.2 matt #define DBGU_CIDR 0x40UL /* Chip ID Register */ 45 1.2 matt #define DBGU_EXID 0x44UL /* Chip ID Extension Register */ 46 1.2 matt #define DBGU_FNR 0x48UL /* Force NTRST Register */ 47 1.2 matt #define DBGU_PDC 0x100UL 48 1.2 matt 49 1.2 matt /* Control Register bits: */ 50 1.2 matt #define DBGU_CR_RSTSTA 0x100 /* 1 = reset the status bits */ 51 1.2 matt #define DBGU_CR_TXDIS 0x080 /* 1 = disable transmitter */ 52 1.2 matt #define DBGU_CR_TXEN 0x040 /* 1 = enable transmitter */ 53 1.2 matt #define DBGU_CR_RXDIS 0x020 /* 1 = disable receiver */ 54 1.2 matt #define DBGU_CR_RXEN 0x010 /* 1 = enable receiver */ 55 1.2 matt #define DBGU_CR_RSTTX 0x008 /* 1 = reset transmitter */ 56 1.2 matt #define DBGU_CR_RSTRX 0x004 /* 1 = reset receiver */ 57 1.2 matt 58 1.2 matt /* Mode Register bits: */ 59 1.2 matt #define DBGU_MR_CHMODE 0xC000 /* channel mode */ 60 1.2 matt #define DBGU_MR_CHMOD_NORMAL 0x0000 61 1.2 matt #define DBGU_MR_CHMOD_ECHO 0x4000 62 1.2 matt #define DBGU_MR_CHMOD_LOCAL_LOOP 0x8000 63 1.2 matt #define DBGU_MR_CHMOD_REMOTE_LOOP 0xC000 64 1.2 matt 65 1.2 matt #define DBGU_MR_PAR 0x0E00 /* parity type */ 66 1.2 matt #define DBGU_MR_PAR_EVEN 0x0000 67 1.2 matt #define DBGU_MR_PAR_ODD 0x0200 68 1.2 matt #define DBGU_MR_PAR_SPACE 0x0400 69 1.2 matt #define DBGU_MR_PAR_MARK 0x0600 70 1.2 matt #define DBGU_MR_PAR_NONE 0x0800 71 1.2 matt 72 1.2 matt /* Interrupt bits: */ 73 1.2 matt #define DBGU_INT_COMMRX 0x80000000 74 1.2 matt #define DBGU_INT_COMMTX 0x40000000 75 1.2 matt #define DBGU_INT_RXBUFF 0x00001000 76 1.2 matt #define DBGU_INT_TXBUFE 0x00000800 77 1.2 matt #define DBGU_INT_TXEMPTY 0x00000200 78 1.2 matt #define DBGU_INT_PARE 0x00000080 79 1.2 matt #define DBGU_INT_FRAME 0x00000040 80 1.2 matt #define DBGU_INT_OVRE 0x00000020 81 1.2 matt #define DBGU_INT_ENDTX 0x00000010 82 1.2 matt #define DBGU_INT_ENDRX 0x00000008 83 1.2 matt #define DBGU_INT_TXRDY 0x00000002 84 1.2 matt #define DBGU_INT_RXRDY 0x00000001 85 1.2 matt 86 1.2 matt /* Status register bits: */ 87 1.2 matt #define DBGU_SR_COMMRX 0x80000000 88 1.2 matt #define DBGU_SR_COMMTX 0x40000000 89 1.2 matt #define DBGU_SR_RXBUFF 0x00001000 90 1.2 matt #define DBGU_SR_TXBUFE 0x00000800 91 1.2 matt #define DBGU_SR_TXEMPTY 0x00000200 92 1.2 matt #define DBGU_SR_PARE 0x00000080 93 1.2 matt #define DBGU_SR_FRAME 0x00000040 94 1.2 matt #define DBGU_SR_OVRE 0x00000020 95 1.2 matt #define DBGU_SR_ENDTX 0x00000010 96 1.2 matt #define DBGU_SR_ENDRX 0x00000008 97 1.2 matt #define DBGU_SR_TXRDY 0x00000002 98 1.2 matt #define DBGU_SR_RXRDY 0x00000001 99 1.2 matt 100 1.2 matt 101 1.2 matt /* Chip ID Register bits: */ 102 1.2 matt #define DBGU_CIDR_EXT 0x80000000 /* 1 = Extended Chip ID exists */ 103 1.2 matt 104 1.2 matt #define DBGU_CIDR_NVPTYP 0x70000000 /* Nonvolatile Pgm Mem Type */ 105 1.2 matt #define DBGU_CIDR_NVPTYP_ROM 0x00000000 106 1.2 matt #define DBGU_CIDR_NVPTYP_ROMLESS 0x10000000 107 1.2 matt #define DBGU_CIDR_NVPTYP_SRAM 0x40000000 108 1.2 matt #define DBGU_CIDR_NVPTYP_FLASH 0x20000000 109 1.2 matt #define DBGU_CIDR_NVTYP_ROM_FLASH 0x30000000 /* NVPSIZ is ROM size, NVPSIZ2 is Flash Size */ 110 1.2 matt 111 1.2 matt #define DBGU_CIDR_ARCH 0x0FF00000 /* Architecture identifier */ 112 1.2 matt #define DBGU_CIDR_ARCH_AT91SAM9XX 0x01900000 /* AT91SAM9xx Series */ 113 1.2 matt #define DBGU_CIDR_ARCH_AT91SAM9XEXX 0x02900000 /* AT91SAM9XExx Series */ 114 1.2 matt #define DBGU_CIDR_ARCH_AT91X34 0x03400000 /* AT91x34 Series */ 115 1.2 matt #define DBGU_CIDR_ARCH_CAP9 0x03900000 /* CAP9 Series */ 116 1.2 matt #define DBGU_CIDR_ARCH_AT91X40 0x04000000 /* AT91x40 Series */ 117 1.2 matt #define DBGU_CIDR_ARCH_AT91X42 0x04200000 /* AT91x42 Series */ 118 1.2 matt #define DBGU_CIDR_ARCH_AT91X55 0x05500000 /* AT91x55 Series */ 119 1.2 matt #define DBGU_CIDR_ARCH_AT91SAM7AXX 0x06000000 /* AT91SAM7Axx Series */ 120 1.2 matt #define DBGU_CIDR_ARCH_AT91X63 0x06300000 /* AT91x63 Series */ 121 1.2 matt #define DBGU_CIDR_ARCH_AT91SAM7SXX 0x07000000 /* AT91SAM7Sxx Series */ 122 1.2 matt #define DBGU_CIDR_ARCH_AT91SAM7XCXX 0x07100000 /* AT91SAM7XCxx Series */ 123 1.2 matt #define DBGU_CIDR_ARCH_AT91SAM7SEXX 0x07200000 /* AT91SAM7SExx Series */ 124 1.2 matt #define DBGU_CIDR_ARCH_AT91SAM7LXX 0x07300000 /* AT91SAM7LExx Series */ 125 1.2 matt #define DBGU_CIDR_ARCH_AT91SAM7XXX 0x07500000 /* AT91SAM7Xxx Series */ 126 1.2 matt #define DBGU_CIDR_ARCH_AT91X92 0x09200000 /* AT91x92 Series */ 127 1.2 matt #define DBGU_CIDR_ARCH_AT75CXX 0x0F000000 /* AT75Cxx Series */ 128 1.2 matt 129 1.2 matt #define DBGU_CIDR_SRAMSIZ 0x000F0000 /* Internal SRAM Size */ 130 1.2 matt #define DBGU_CIDR_SRAMSIZ_1K 0x00010000 131 1.2 matt #define DBGU_CIDR_SRAMSIZ_2K 0x00020000 132 1.2 matt #define DBGU_CIDR_SRAMSIZ_4K 0x00050000 133 1.2 matt #define DBGU_CIDR_SRAMSIZ_8K 0x00080000 134 1.2 matt #define DBGU_CIDR_SRAMSIZ_16K 0x00090000 135 1.2 matt #define DBGU_CIDR_SRAMSIZ_32K 0x000A0000 136 1.2 matt #define DBGU_CIDR_SRAMSIZ_64K 0x000B0000 137 1.2 matt #define DBGU_CIDR_SRAMSIZ_128K 0x000C0000 138 1.2 matt #define DBGU_CIDR_SRAMSIZ_256K 0x000D0000 139 1.2 matt #define DBGU_CIDR_SRAMSIZ_96K 0x000E0000 140 1.2 matt #define DBGU_CIDR_SRAMSIZ_512K 0x000F0000 141 1.2 matt 142 1.2 matt #define DBGU_CIDR_NVPSIZ 0x00000F00 /* Nonvolatile Pgm Mem Size */ 143 1.2 matt #define DBGU_CIDR_NVPSIZ_NONE 0x00000000 144 1.2 matt #define DBGU_CIDR_NVPSIZ_8K 0x00000100 145 1.2 matt #define DBGU_CIDR_NVPSIZ_16K 0x00000200 146 1.2 matt #define DBGU_CIDR_NVPSIZ_32K 0x00000300 147 1.2 matt #define DBGU_CIDR_NVPSIZ_64K 0x00000500 148 1.2 matt #define DBGU_CIDR_NVPSIZ_128K 0x00000700 149 1.2 matt #define DBGU_CIDR_NVPSIZ_256K 0x00000900 150 1.2 matt #define DBGU_CIDR_NVPSIZ_512K 0x00000A00 151 1.2 matt #define DBGU_CIDR_NVPSIZ_1024K 0x00000C00 152 1.2 matt #define DBGU_CIDR_NVPSIZ_2048K 0x00000E00 153 1.2 matt 154 1.2 matt #define DBGU_CIDR_NPVSIZ2 0x0000F000 /* Nonvolatile Pgm 2 Mem Size */ 155 1.2 matt #define DBGU_CIDR_NVPSIZ2_NONE 0x00000000 156 1.2 matt #define DBGU_CIDR_NVPSIZ2_8K 0x00001000 157 1.2 matt #define DBGU_CIDR_NVPSIZ2_16K 0x00002000 158 1.2 matt #define DBGU_CIDR_NVPSIZ2_32K 0x00003000 159 1.2 matt #define DBGU_CIDR_NVPSIZ2_64K 0x00005000 160 1.2 matt #define DBGU_CIDR_NVPSIZ2_128K 0x00007000 161 1.2 matt #define DBGU_CIDR_NVPSIZ2_256K 0x00009000 162 1.2 matt #define DBGU_CIDR_NVPSIZ2_512K 0x0000A000 163 1.2 matt #define DBGU_CIDR_NVPSIZ2_1024K 0x0000C000 164 1.2 matt #define DBGU_CIDR_NVPSIZ2_2048K 0x0000E000 165 1.2 matt 166 1.2 matt #define DBGU_CIDR_EPROC 0x000000E0 /* Embedded Processor ID */ 167 1.2 matt #define DBGU_CIDR_EPROC_946ES 0x00000020 168 1.2 matt #define DBGU_CIDR_EPROC_7TDMI 0x00000040 169 1.2 matt #define DBGU_CIDR_EPROC_920T 0x00000080 170 1.2 matt #define DBGU_CIDR_EPROC_926EJS 0x000000E0 171 1.2 matt 172 1.2 matt #define DBGU_CIDR_VERSION 0x0000001F /* version of the device */ 173 1.2 matt 174 1.2 matt #define DBGU_CIDR_AT91RM9200 0x09290781 175 1.4 aymeric #define DBGU_CIDR_AT91SAM9260 0x019803A2 176 1.2 matt #define DBGU_CIDR_AT91SAM9261 0x019703A0 177 1.2 matt #define DBGU_CIDR_AT91SAM9263 0x019607A0 178 1.2 matt 179 1.2 matt #define AT91RM9200_CHIP_ID DBGU_CIDR_AT91RM9200 180 1.2 matt #define AT91SAM9260_CHIP_ID DBGU_CIDR_AT91SAM9260 181 1.2 matt #define AT91SAM9261_CHIP_ID DBGU_CIDR_AT91SAM9261 182 1.2 matt #define AT91SAM9263_CHIP_ID DBGU_CIDR_AT91SAM9263 183 1.2 matt 184 1.5 skrll #define DBGUREG(reg) *((volatile uint32_t*)(AT91DBGU_BASE + (reg))) 185 1.2 matt 186 1.2 matt #define DBGU_INIT(mstclk, speed) do { \ 187 1.2 matt DBGUREG(DBGU_PDC + PDC_PTCR) = PDC_PTCR_TXTDIS | PDC_PTCR_RXTDIS; \ 188 1.2 matt DBGUREG(DBGU_BRGR) = ((mstclk) / 16 + (speed) / 2) / (speed); \ 189 1.2 matt DBGUREG(DBGU_MR) = DBGU_MR_PAR_NONE; \ 190 1.2 matt DBGUREG(DBGU_CR) = DBGU_CR_RSTSTA | DBGU_CR_RSTTX | DBGU_CR_RSTRX; \ 191 1.2 matt DBGUREG(DBGU_CR) = DBGU_CR_TXEN | DBGU_CR_RXEN; \ 192 1.2 matt (void)DBGUREG(DBGU_SR); \ 193 1.2 matt } while (/*CONSTCOND*/0) 194 1.2 matt 195 1.2 matt #define DBGU_PUTC(ch) do { \ 196 1.2 matt int s = splserial(); \ 197 1.2 matt while ((DBGUREG(DBGU_SR) & DBGU_SR_TXRDY) == 0) { \ 198 1.2 matt splx(s); s = splserial(); \ 199 1.2 matt }; \ 200 1.2 matt DBGUREG(DBGU_THR) = ch; \ 201 1.2 matt splx(s); \ 202 1.2 matt } while (/*CONSTCOND*/0) 203 1.2 matt 204 1.2 matt #define DBGU_PEEKC() ((DBGUREG(DBGU_SR) & DBGU_SR_RXRDY) ? DBGUREG(DBGU_RHR) : -1) 205 1.2 matt 206 1.2 matt #define DBGU_PUTS(string) do { \ 207 1.2 matt const char *_ptr = (string); \ 208 1.2 matt while (*_ptr) { \ 209 1.2 matt DBGU_PUTC(*_ptr); \ 210 1.2 matt _ptr++; \ 211 1.2 matt } \ 212 1.2 matt } while (/*CONSTCOND*/0) 213 1.2 matt 214 1.2 matt #endif // _AT91DBGUREG_H_ 215 1.2 matt 216