summaryrefslogtreecommitdiffstats
path: root/firmware/export/tcc730.h
blob: c1208ecc282d75d95dbaf030ed13a0de8984ebb0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
/***************************************************************************
 *             __________               __   ___.
 *   Open      \______   \ ____   ____ |  | _\_ |__   _______  ___
 *   Source     |       _//  _ \_/ ___\|  |/ /| __ \ /  _ \  \/  /
 *   Jukebox    |    |   (  <_> )  \___|    < | \_\ (  <_> > <  <
 *   Firmware   |____|_  /\____/ \___  >__|_ \|___  /\____/__/\_ \
 *                     \/            \/     \/    \/            \/
 * $Id$
 *
 * Copyright (C) 2005 by Jean-Philippe Bernardy
 *
 * All files in this archive are subject to the GNU General Public License.
 * See the file COPYING in the source tree root for full license agreement.
 *
 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
 * KIND, either express or implied.
 *
 ****************************************************************************/

#ifndef TCC730_H
#define TCC730_H

/* int is 16 bit 
   long is 32 bit */

#define IOBASE (0x3f0000)
#define MMIO(t, x) (*(volatile t*)(IOBASE+(x))) 

#define OSCCON MMIO(unsigned char, 0x01)
#define WTCON  MMIO(unsigned char, 0x02)
#define BTCON  MMIO(unsigned char, 0x04)
#define BTCNT  MMIO(unsigned char, 0x05)
#define WDTEN  MMIO(unsigned char, 0x06)
#define WDTCON MMIO(unsigned char, 0x07)

#define TACON  MMIO(unsigned char, 0x08)
#define TAPRE  MMIO(unsigned char, 0x09)
#define TADATA MMIO(unsigned int, 0x0A)
#define TACNT  MMIO(unsigned int, 0x0C)

#define IMR0 MMIO(unsigned int, 0x22)
#define IMR1 MMIO(unsigned int, 0x2A)

#define P0  MMIO(unsigned char, 0x30)
#define P1  MMIO(unsigned char, 0x31)
#define P2  MMIO(unsigned char, 0x32)
#define P3  MMIO(unsigned char, 0x33)
#define P4  MMIO(unsigned char, 0x34)
#define P5  MMIO(unsigned char, 0x35)
#define P6  MMIO(unsigned char, 0x36)
#define P7  MMIO(unsigned char, 0x37)
#define P8  MMIO(unsigned char, 0x38)
#define P9  MMIO(unsigned char, 0x39)
#define P10 MMIO(unsigned char, 0x3A)

#define P0CON    MMIO(unsigned char,0x40)
#define P1CON    MMIO(unsigned char,0x41)
#define P2CON    MMIO(unsigned int,0x42)
#define P2CONH   MMIO(unsigned char,0x42)
#define P2CONL   MMIO(unsigned char,0x43)
#define P3CON    MMIO(unsigned int,0x44)
#define P3CONH   MMIO(unsigned char,0x44)
#define P3CONL   MMIO(unsigned char,0x45)
#define P3PUR    MMIO(unsigned char,0x46)
#define P5CON    MMIO(unsigned char,0x48)
#define P5PUR    MMIO(unsigned char,0x49)
#define P5INTMOD MMIO(unsigned int,0x4A)
#define P5INTCON MMIO(unsigned char,0x4C)
#define P4CON    MMIO(unsigned char,0x50)
#define P4INTCON MMIO(unsigned char,0x51)
#define P4INTMOD MMIO(unsigned char,0x52)
#define P6CON    MMIO(unsigned char,0x53)
#define P7CON    MMIO(unsigned char,0x54)
#define P8CON    MMIO(unsigned char,0x55)
#define P9CON    MMIO(unsigned char,0x56)
#define P10CON   MMIO(unsigned char,0x57)

#define IISCON0  MMIO(unsigned char, 0x0a0)
#define IISMODE0 MMIO(unsigned char, 0x0a1)
#define IISPTR0  MMIO(unsigned char, 0x0a2)
#define IISCON1  MMIO(unsigned char, 0x0a3)
#define IISMODE1 MMIO(unsigned char, 0x0a4)
#define IISPTR1  MMIO(unsigned char, 0x0a5)

#define ADDATA MMIO(unsigned int, 0x74)
#define ADCON  MMIO(unsigned char, 0x76)

#define PLL0DATA MMIO(unsigned int, 0xA8)
#define PLL0CON  MMIO(unsigned char, 0xAA)
#define PLL1DATA MMIO(unsigned int, 0xAC)
#define PLL1CON  MMIO(unsigned char, 0xAE)

#define IISBUF ((volatile unsigned int*)(IOBASE+(0x0c0)))

#define MIUSCFG MMIO(unsigned char, 0x110)
#define MIUDCOM MMIO(unsigned char, 0x111)
#define MIUDCFG MMIO(unsigned int, 0x112)
#define MIUDCNT MMIO(unsigned int, 0x114)

#define DDMACOM  MMIO(unsigned char, 0x120)
#define DDMACFG  MMIO(unsigned char, 0x121)
#define DDMAIADR MMIO(unsigned long, 0x122)
#define DDMAEADR MMIO(unsigned long, 0x126)
#define DDMANUM  MMIO(unsigned int, 0x12A)
#define DDMACNT  MMIO(unsigned int, 0x12C)

#endif