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 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454
|
/*! \file include/sys/h8.h
\brief Internal Interface: H8/3297 processor registers
\author Markus L. Noga <markus@noga.de>
*/
/*
* The contents of this file are subject to the Mozilla Public License
* Version 1.0 (the "License"); you may not use this file except in
* compliance with the License. You may obtain a copy of the License
* at http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS"
* basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See
* the License for the specific language governing rights and
* limitations under the License.
*
* The Original Code is legOS code, released October 17, 1999.
*
* The Initial Developer of the Original Code is Markus L. Noga.
* Portions created by Markus L. Noga are Copyright (C) 1999
* Markus L. Noga. All Rights Reserved.
*
* Contributor(s): Markus L. Noga <markus@noga.de>
*/
#ifndef __sys_h8_h__
#define __sys_h8_h__
#ifdef __cplusplus
extern "C" {
#endif
// 16 bit timer registers
//
//! 16-bit timer interrupt enable register
extern unsigned char T_IER;
//! 16-bit timer control / status register
extern volatile unsigned char T_CSR;
//! 16-bit timer count register
extern volatile unsigned T_CNT;
//! 16-bit timer output compare register A
extern unsigned T_OCRA;
//! 16-bit timer output compare register B
/* address shared with T_OCRA */
extern unsigned T_OCRB;
//! 16-bit timer control register
extern unsigned char T_CR;
//! 16-bit timer output control register
extern unsigned char T_OCR;
//! 16-bit timer input capture A register
extern volatile unsigned T_ICRA;
//! 16-bit timer input capture B register
extern volatile unsigned T_ICRB;
//! 16-bit timer input capture C register
extern volatile unsigned T_ICRC;
//! 16-bit timer input capture D register
extern volatile unsigned T_ICRD;
//
// TIER bitmasks
//
#define TIER_ENABLE_ICA 0x80 // input capture IRQ enables
#define TIER_ENABLE_ICB 0x40
#define TIER_ENABLE_ICC 0x20
#define TIER_ENABLE_ICD 0x10
#define TIER_ENABLE_OCA 0x08 // output compare IRQ enables
#define TIER_ENABLE_OCB 0x04
#define TIER_ENABLE_OF 0x02 // overflow IRQ enable
#define TIER_RESERVED 0x01 // always set.
//
// TCSR bitmasks
//
#define TCSR_ICA 0x80 // input capture events
#define TCSR_ICB 0x40
#define TCSR_ICC 0x20
#define TCSR_ICD 0x10
#define TCSR_OCA 0x08 // output compare events
#define TCSR_OCB 0x04
#define TCSR_OF 0x02 // overflow event
#define TCSR_RESET_ON_A 0x01 // reset counter on match A
//
// TCR bitmasks
//
#define TCR_A_RISING 0x80 // input capture on rising
#define TCR_B_RISING 0x40 // edge. if not set -> lower
#define TCR_C_RISING 0x20
#define TCR_D_RISING 0x10
#define TCR_BUFFER_A 0x08 // buffer A in C
#define TCR_BUFFER_B 0x04 // buffer B in D
#define TCR_CLOCK_2 0x00 // clock = pclock / 2
#define TCR_CLOCK_8 0x01 // clock = pclock / 8
#define TCR_CLOCK_32 0x02 // clock = pclock / 32
#define TCR_CLOCK_EXT 0x03 // external clock, rising edge
//
// TOCR bitmasks
//
#define TOCR_OCRA 0x00 // select register to write
#define TOCR_OCRB 0x10
#define TOCR_ENABLE_A 0x08 // enable output signals
#define TOCR_ENABLE_B 0x04
#define TOCR_HIGH_LEVEL_A 0x02 // set output to high for match
#define TOCR_HIGH_LEVEL_B 0x01
//
// 8 bit timer registers
//
//! serial / timer control register
extern unsigned char STCR;
//! timer 0 control register
extern unsigned char T0_CR;
//! timer 0 control / status register
extern volatile unsigned char T0_CSR;
//! timer 0 constant A register
extern unsigned char T0_CORA;
//! timer 0 constant B register
extern unsigned char T0_CORB;
//! timer 0 counter register
extern volatile unsigned char T0_CNT;
//! timer 1 control register
extern unsigned char T1_CR;
//! timer 1 control / status register
extern volatile unsigned char T1_CSR;
//! timer 1 constant A register
extern unsigned char T1_CORA;
//! timer 1 constant B register
extern unsigned char T1_CORB;
//! timer 1 counter register
extern volatile unsigned char T1_CNT;
//
// CR flag bitmasks
//
#define CR_ENABLE_IRQA 0x40
#define CR_ENABLE_IRQB 0x80
#define CR_ENABLE_IRQO 0x20
#define CR_CLEAR_NEVER 0x00
#define CR_CLEAR_ON_A 0x08
#define CR_CLEAR_ON_B 0x10
#define CR_CLEAR_ON_EXTERN 0x18
// I don't define speeds here because the STCR bits are involved, too.
// Also, speeds differ for T0 and T1.
//
// CSR bitmasks
//
#define CSR_MATCH_A 0x40
#define CSR_MATCH_B 0x80
#define CSR_OVERFLOW 0x20
#define CSR_IGNORE_B 0x00
#define CSR_0_ON_B 0x04
#define CSR_1_ON_B 0x08
#define CSR_TOGGLE_ON_B 0x0c
#define CSR_IGNORE_A 0x00
#define CSR_0_ON_A 0x01
#define CSR_1_ON_A 0x02
#define CSR_TOGGLE_ON_A 0x03
//
// Serial port
//
//! serial receive data register
extern volatile unsigned char S_RDR;
//! serial transmit data register
extern unsigned char S_TDR;
//! serial mode register
extern unsigned char S_MR;
//! serial control register
extern unsigned char S_CR;
//! serial status register
extern volatile unsigned char S_SR;
//! serial baud rate register
extern unsigned char S_BRR;
//! serial / timer control register
extern unsigned char S_TCR;
//
// register bitmasks
//
#define SMR_SYNC 0x80 // in sync mode, the other settings
#define SMR_ASYNC 0x00 // have no effect.
#define SMR_7BIT 0x40
#define SMR_8BIT 0x00
#define SMR_P_NONE 0x00
#define SMR_P_EVEN 0x20
#define SMR_P_ODD 0x30
#define SMR_1STOP 0x00
#define SMR_2STOP 0x08
#define SMR_MP 0x04 // multiprocessing -> no parity
// for mp, mpe in STRC must be set
#define SMR_CLOCK 0x00 // clock rate for baud rate generator
#define SMR_CLOCK_4 0x01 // pclock / 4
#define SMR_CLOCK_16 0x02 // pclock / 16
#define SMR_CLOCK_64 0x03 // pclock / 64
#define SCR_TX_IRQ 0x80 // TIE transmit irq enable
#define SCR_RX_IRQ 0x40 // RIE receive / recv err irq enable
#define SCR_TRANSMIT 0x20 // enable transmission
#define SCR_RECEIVE 0x10 // enable receiving
#define SCR_MP_IRQ 0x08 // multiprocessing receive irq
#define SCR_TE_IRQ 0x04 // TEI transmit end irq enable
#define SCR_INT_CLOCK 0x00 // internal clock source
#define SCR_EXT_CLOCK 0x02 // external clock source
#define SCR_CLOCK_OUT 0x01 // output internal clock to SCK pin
#define SSR_TRANS_EMPTY 0x80 // transmit buffer empty
#define SSR_RECV_FULL 0x40 // receive buffer full
#define SSR_OVERRUN_ERR 0x20 // overrun error
#define SSR_FRAMING_ERR 0x10 // framing error
#define SSR_PARITY_ERR 0x08 // parity error
#define SSR_ERRORS 0x38 // all errors
#define SSR_TRANS_END 0x04 // transmission end because buffer empty
#define SSR_MP 0x02 // multiprocessor
#define SSR_MP_TRANSFER 0x01 // multiprocessor bit transfer
//
// values for the bit rate register BRR
// assuming CMR_CLOCK selected on 16 MHz processor
// error <= 0.16%
//
#define B2400 207
#define B4800 103
#define B9600 51
#define B19200 25
#define B38400 12
// A/D converter
//
//! A/D converter data register A high
extern volatile unsigned char AD_A_H;
//! A/D converter data register A low
/*! bits 0..5 reserved, probably zero */
extern volatile unsigned char AD_A_L;
//! A/D converter data register B high
extern volatile unsigned char AD_B_H;
//! A/D converter data register B low
/*! bits 0..5 reserved, probably zero */
extern volatile unsigned char AD_B_L;
//! A/D converter data register C high
extern volatile unsigned char AD_C_H;
//! A/D converter data register C low
/*! bits 0..5 reserved, probably zero */
extern volatile unsigned char AD_C_L;
//! A/D converter data register D high
extern volatile unsigned char AD_D_H;
//! A/D converter data register D low
/*! bits 0..5 reserved, probably zero */
extern volatile unsigned char AD_D_L;
//! A/D converter data register A
/*! bits 0..5 reserved, probably zero */
extern volatile unsigned AD_A;
//! A/D converter data register B
/*! bits 0..5 reserved, probably zero */
extern volatile unsigned AD_B;
//! A/D converter data register C
/*! bits 0..5 reserved, probably zero */
extern volatile unsigned AD_C;
//! A/D converter data register D
/*! bits 0..5 reserved, probably zero */
extern volatile unsigned AD_D;
//! A/D converter control / status register
extern volatile unsigned char AD_CSR;
//! A/D converter control register
extern unsigned char AD_CR;
//
// A/D CSR bitmasks
//
#define ADCSR_END 0x80
#define ADCSR_ENABLE_IRQ 0x40
#define ADCSR_START 0x20
#define ADCSR_SCAN 0x10 // enable scan mode
#define ADCSR_TIME_266 0x00 // select A/D conversion time
#define ADCSR_TIME_134 0x08
#define ADCSR_GROUP_0 0x00 // select scan group
#define ADCSR_GROUP_1 0x04
#define ADCSR_AN_0 0x00 // first group of inputs to convert
#define ADCSR_AN_1 0x01
#define ADCSR_AN_2 0x02
#define ADCSR_AN_3 0x03 // in scan mode: AN0-AN3
//
// A/D CR bitmasks
//
#define ADCR_EXTERN 0x80 // allow external triggering
//
// system control register
// FIXME: incomplete
//! system control register
extern unsigned char SYSCR;
#define SYSCR_SOFTWARE_STANDBY 0x80 // software standby flag
//
// I/O ports
//
//! port 1 input pull-up control register
extern unsigned char PORT1_PCR;
//! port 2 input pull-up control register
extern unsigned char PORT2_PCR;
//! port 3 input pull-up control register
extern unsigned char PORT3_PCR;
//! port 1 data direction register
extern unsigned char PORT1_DDR;
//! port 1 I/O register
extern volatile unsigned char PORT1;
//! port 2 data direction register
extern unsigned char PORT2_DDR;
//! port 2 I/O register
extern volatile unsigned char PORT2;
//! port 3 data direction register
extern unsigned char PORT3_DDR;
//! port 3 I/O register
extern volatile unsigned char PORT3;
//! port 4 data direction register
extern unsigned char PORT4_DDR;
//! port 4 I/O register
extern volatile unsigned char PORT4;
//! port 5 data direction register
extern unsigned char PORT5_DDR;
//! port 5 I/O register
extern volatile unsigned char PORT5;
//! port 6 data direction register
extern unsigned char PORT6_DDR;
//! port 6 I/O register
extern volatile unsigned char PORT6;
//! port 7 input register
extern volatile unsigned char PORT7;
//! watch dog timer control register
extern volatile unsigned int WDT_CSR;
#define WDT_CSR_PASSWORD (0xA500)
#define WDT_CSR_ENABLE (0x0020)
#define WDT_CSR_MODE_WATCHDOG (0x0040)
#define WDT_CSR_MODE_OVERFLOW (0x0000)
#define WDT_CSR_WATCHDOG_NMI (0x0000)
#define WDT_CSR_WATCHDOG_RES (0x0008)
#define WDT_CSR_CLOCK_2 (0x0000)
#define WDT_CSR_CLOCK_32 (0x0001)
#define WDT_CSR_CLOCK_64 (0x0002)
#define WDT_CSR_CLOCK_128 (0x0003)
#define WDT_CSR_CLOCK_256 (0x0004)
#define WDT_CSR_CLOCK_512 (0x0005)
#define WDT_CSR_CLOCK_2048 (0x0006)
#define WDT_CSR_CLOCK_4096 (0x0007)
//! watch dog timer counter register
extern volatile unsigned char WDT_CNT;
#define WDT_CNT_PASSWORD (0x5A00)
#define WDT_CNT_CLEAR (0x0000)
#define WDT_CNT_MSEC_64 (0x0006)
#ifdef __cplusplus
}
#endif
#endif // __sys_h8_h__
|