1 /*-------------------------------------------------------------------------
2 at89x51.h - register declarations for ATMEL 89x51 processors
4 Copyright (C) 1999, Bernd Bartmann <bernd.bartmann AT gmail.com>
6 Based on reg51.h by Sandeep Dutta sandeep.dutta AT usa.net
7 KEIL C compatible definitions are included
9 This library is free software; you can redistribute it and/or modify it
10 under the terms of the GNU General Public License as published by the
11 Free Software Foundation; either version 2, or (at your option) any
14 This library is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
19 You should have received a copy of the GNU General Public License
20 along with this library; see the file COPYING. If not, write to the
21 Free Software Foundation, 51 Franklin Street, Fifth Floor, Boston,
24 As a special exception, if you link this library with other files,
25 some of which are compiled with SDCC, to produce an executable,
26 this library does not by itself cause the resulting executable to
27 be covered by the GNU General Public License. This exception does
28 not however invalidate any other reasons why the executable file
29 might be covered by the GNU General Public License.
30 -------------------------------------------------------------------------*/
37 /* BYTE addressable registers */
62 /* BIT addressable registers */
158 /* BIT definitions for bits that are not directly accessible */
203 #define T0_GATE_ 0x08
207 #define T1_GATE_ 0x80
212 #define T0_MASK_ 0x0F
213 #define T1_MASK_ 0xF0
216 /* Interrupt numbers: address = (number * 8) + 3 */
217 #define IE0_VECTOR 0 /* 0x03 external interrupt 0 */
218 #define TF0_VECTOR 1 /* 0x0b timer 0 */
219 #define IE1_VECTOR 2 /* 0x13 external interrupt 1 */
220 #define TF1_VECTOR 3 /* 0x1b timer 1 */
221 #define SI0_VECTOR 4 /* 0x23 serial port 0 */