avr/cpp/atmega168/IO.h

Go to the documentation of this file.
00001 /**********************************************************************************************************************\
00002 
00003         C++ library for Atmel AVR microcontrollers
00004         Copyright (C) 2007 Lauri Kirikal, Mikk Leini, Rasmus Raag, MTU TTU Robotiklubi
00005 
00006         This program is free software; you can redistribute it and/or
00007         modify it under the terms of the GNU General Public License
00008         as published by the Free Software Foundation; either version 2
00009         of the License, or (at your option) any later version.
00010 
00011         This program is distributed in the hope that it will be useful,
00012         but WITHOUT ANY WARRANTY; without even the implied warranty of
00013         MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00014         GNU General Public License for more details.
00015 
00016         You should have received a copy of the GNU General Public License
00017         along with this program; if not, write to the Free Software
00018         Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
00019 
00020         See http://creativecommons.org/licenses/GPL/2.0/
00021 
00022         MTU TTU Robotiklubi  http://www.robotiklubi.ee robotiklubi@gmail.com
00023         Lauri Kirikal        laurikirikal@gmail.com
00024         Mikk Leini           mikk.leini@gmail.com
00025 
00026 \**********************************************************************************************************************/
00027 
00028 #ifndef __AVR_CPP_ATMEGA168_IO_H__
00029 #define __AVR_CPP_ATMEGA168_IO_H__
00030 
00031 #if defined(__DOXYGEN__) && !defined(__AVR_CPP_IO_H__)
00032 #include <avr/cpp/IO.h>
00033 #endif
00034 
00035 #ifndef __AVR_CPP_IO_H__
00036 #error "Include <avr/cpp/IO.h> instead of <avr/cpp/atmega168/IO.h>."
00037 #else
00038 
00039 
00040 /**********************************************************************************************************************\
00041 
00042         atmega168 registers, bits and ports declarations.
00043         This file is generated. Do not modify manually.
00044 
00045 \**********************************************************************************************************************/
00046 
00047 // Registers
00048 namespace AVRCpp
00049 {
00050         __DECLARE_8BIT_REGISTER__(UDR0);
00051         __DECLARE_8BIT_REGISTER__(UBRR0H);
00052         __DECLARE_8BIT_REGISTER__(UBRR0L);
00053         __DECLARE_8BIT_REGISTER__(UCSR0C);
00054         __DECLARE_8BIT_REGISTER__(UCSR0B);
00055         __DECLARE_8BIT_REGISTER__(UCSR0A);
00056         __DECLARE_8BIT_REGISTER__(TWAMR);
00057         __DECLARE_8BIT_REGISTER__(TWCR);
00058         __DECLARE_8BIT_REGISTER__(TWDR);
00059         __DECLARE_8BIT_REGISTER__(TWAR);
00060         __DECLARE_8BIT_REGISTER__(TWSR);
00061         __DECLARE_8BIT_REGISTER__(TWBR);
00062         __DECLARE_8BIT_REGISTER__(ASSR);
00063         __DECLARE_8BIT_REGISTER__(OCR2B);
00064         __DECLARE_8BIT_REGISTER__(OCR2A);
00065         __DECLARE_8BIT_REGISTER__(TCNT2);
00066         __DECLARE_8BIT_REGISTER__(TCCR2B);
00067         __DECLARE_8BIT_REGISTER__(TCCR2A);
00068         __DECLARE_8BIT_REGISTER__(OCR1BH);
00069         __DECLARE_8BIT_REGISTER__(OCR1BL);
00070         __DECLARE_8BIT_REGISTER__(OCR1AH);
00071         __DECLARE_8BIT_REGISTER__(OCR1AL);
00072         __DECLARE_8BIT_REGISTER__(ICR1H);
00073         __DECLARE_8BIT_REGISTER__(ICR1L);
00074         __DECLARE_8BIT_REGISTER__(TCNT1H);
00075         __DECLARE_8BIT_REGISTER__(TCNT1L);
00076         __DECLARE_8BIT_REGISTER__(TCCR1C);
00077         __DECLARE_8BIT_REGISTER__(TCCR1B);
00078         __DECLARE_8BIT_REGISTER__(TCCR1A);
00079         __DECLARE_8BIT_REGISTER__(DIDR1);
00080         __DECLARE_8BIT_REGISTER__(DIDR0);
00081         __DECLARE_8BIT_REGISTER__(ADMUX);
00082         __DECLARE_8BIT_REGISTER__(ADCSRB);
00083         __DECLARE_8BIT_REGISTER__(ADCSRA);
00084         __DECLARE_8BIT_REGISTER__(ADCH);
00085         __DECLARE_8BIT_REGISTER__(ADCL);
00086         __DECLARE_8BIT_REGISTER__(TIMSK2);
00087         __DECLARE_8BIT_REGISTER__(TIMSK1);
00088         __DECLARE_8BIT_REGISTER__(TIMSK0);
00089         __DECLARE_8BIT_REGISTER__(PCMSK2);
00090         __DECLARE_8BIT_REGISTER__(PCMSK1);
00091         __DECLARE_8BIT_REGISTER__(PCMSK0);
00092         __DECLARE_8BIT_REGISTER__(EICRA);
00093         __DECLARE_8BIT_REGISTER__(PCICR);
00094         __DECLARE_8BIT_REGISTER__(OSCCAL);
00095         __DECLARE_8BIT_REGISTER__(PRR);
00096         __DECLARE_8BIT_REGISTER__(CLKPR);
00097         __DECLARE_8BIT_REGISTER__(WDTCSR);
00098         __DECLARE_8BIT_REGISTER__(SREG);
00099         __DECLARE_8BIT_REGISTER__(SPH);
00100         __DECLARE_8BIT_REGISTER__(SPL);
00101         __DECLARE_8BIT_REGISTER__(SPMCSR);
00102         __DECLARE_8BIT_REGISTER__(MCUCR);
00103         __DECLARE_8BIT_REGISTER__(MCUSR);
00104         __DECLARE_8BIT_REGISTER__(SMCR);
00105         __DECLARE_8BIT_REGISTER__(ACSR);
00106         __DECLARE_8BIT_REGISTER__(SPDR);
00107         __DECLARE_8BIT_REGISTER__(SPSR);
00108         __DECLARE_8BIT_REGISTER__(SPCR);
00109         __DECLARE_8BIT_REGISTER__(GPIOR2);
00110         __DECLARE_8BIT_REGISTER__(GPIOR1);
00111         __DECLARE_8BIT_REGISTER__(OCR0B);
00112         __DECLARE_8BIT_REGISTER__(OCR0A);
00113         __DECLARE_8BIT_REGISTER__(TCNT0);
00114         __DECLARE_8BIT_REGISTER__(TCCR0B);
00115         __DECLARE_8BIT_REGISTER__(TCCR0A);
00116         __DECLARE_8BIT_REGISTER__(GTCCR);
00117         __DECLARE_8BIT_REGISTER__(EEARH);
00118         __DECLARE_8BIT_REGISTER__(EEARL);
00119         __DECLARE_8BIT_REGISTER__(EEDR);
00120         __DECLARE_8BIT_REGISTER__(EECR);
00121         __DECLARE_8BIT_REGISTER__(GPIOR0);
00122         __DECLARE_8BIT_REGISTER__(EIMSK);
00123         __DECLARE_8BIT_REGISTER__(EIFR);
00124         __DECLARE_8BIT_REGISTER__(PCIFR);
00125         __DECLARE_8BIT_REGISTER__(TIFR2);
00126         __DECLARE_8BIT_REGISTER__(TIFR1);
00127         __DECLARE_8BIT_REGISTER__(TIFR0);
00128         __DECLARE_8BIT_REGISTER__(PORTD);
00129         __DECLARE_8BIT_REGISTER__(DDRD);
00130         __DECLARE_8BIT_REGISTER__(PIND);
00131         __DECLARE_8BIT_REGISTER__(PORTC);
00132         __DECLARE_8BIT_REGISTER__(DDRC);
00133         __DECLARE_8BIT_REGISTER__(PINC);
00134         __DECLARE_8BIT_REGISTER__(PORTB);
00135         __DECLARE_8BIT_REGISTER__(DDRB);
00136         __DECLARE_8BIT_REGISTER__(PINB);
00137         __DECLARE_16BIT_REGISTER__(UBRR0);
00138         __DECLARE_16BIT_REGISTER__(OCR1B);
00139         __DECLARE_16BIT_REGISTER__(OCR1A);
00140         __DECLARE_16BIT_REGISTER__(ICR1);
00141         __DECLARE_16BIT_REGISTER__(TCNT1);
00142         __DECLARE_16BIT_REGISTER__(ADC);
00143         __DECLARE_16BIT_REGISTER__(EEAR);
00144 
00145 } // namespace AVRCpp
00146 
00147 
00148 // UCSR0C
00149 #define _UMSEL01 0x80
00150 #define _UMSEL00 0x40
00151 #define _UPM01 0x20
00152 #define _UPM00 0x10
00153 #define _USBS0 0x8
00154 #define _UCSZ01 0x4
00155 #define _UDORD0 0x2
00156 #define _UCSZ00 0x1
00157 
00158 // UCSR0B
00159 #define _RXCIE0 0x80
00160 #define _TXCIE0 0x40
00161 #define _UDRIE0 0x20
00162 #define _RXEN0 0x10
00163 #define _TXEN0 0x8
00164 #define _UCSZ02 0x4
00165 #define _RXB80 0x2
00166 #define _TXB80 0x1
00167 
00168 // UCSR0A
00169 #define _RXC0 0x80
00170 #define _TXC0 0x40
00171 #define _UDRE0 0x20
00172 #define _FE0 0x10
00173 #define _DOR0 0x8
00174 #define _UPE0 0x4
00175 #define _U2X0 0x2
00176 #define _MPCM0 0x1
00177 
00178 // TWAMR
00179 #define _TWAM6 0x80
00180 #define _TWAM5 0x40
00181 #define _TWAM4 0x20
00182 #define _TWAM3 0x10
00183 #define _TWAM2 0x8
00184 #define _TWAM1 0x4
00185 #define _TWAM0 0x2
00186 
00187 // TWCR
00188 #define _TWINT 0x80
00189 #define _TWEA 0x40
00190 #define _TWSTA 0x20
00191 #define _TWSTO 0x10
00192 #define _TWWC 0x8
00193 #define _TWEN 0x4
00194 #define _TWIE 0x1
00195 
00196 // TWAR
00197 #define _TWA6 0x80
00198 #define _TWA5 0x40
00199 #define _TWA4 0x20
00200 #define _TWA3 0x10
00201 #define _TWA2 0x8
00202 #define _TWA1 0x4
00203 #define _TWA0 0x2
00204 #define _TWGCE 0x1
00205 
00206 // TWSR
00207 #define _TWS7 0x80
00208 #define _TWS6 0x40
00209 #define _TWS5 0x20
00210 #define _TWS4 0x10
00211 #define _TWS3 0x8
00212 #define _TWPS1 0x2
00213 #define _TWPS0 0x1
00214 
00215 // ASSR
00216 #define _EXCLK 0x40
00217 #define _AS2 0x20
00218 #define _TCN2UB 0x10
00219 #define _OCR2AUB 0x8
00220 #define _OCR2BUB 0x4
00221 #define _TCR2AUB 0x2
00222 #define _TCR2BUB 0x1
00223 
00224 // TCCR2B
00225 #define _FOC2A 0x80
00226 #define _FOC2B 0x40
00227 #define _WGM22 0x8
00228 #define _CS22 0x4
00229 #define _CS21 0x2
00230 #define _CS20 0x1
00231 
00232 // TCCR2A
00233 #define _COM2A1 0x80
00234 #define _COM2A0 0x40
00235 #define _COM2B1 0x20
00236 #define _COM2B0 0x10
00237 #define _WGM21 0x2
00238 #define _WGM20 0x1
00239 
00240 // TCCR1C
00241 #define _FOC1A 0x80
00242 #define _FOC1B 0x40
00243 
00244 // TCCR1B
00245 #define _ICNC1 0x80
00246 #define _ICES1 0x40
00247 #define _WGM13 0x10
00248 #define _WGM12 0x8
00249 #define _CS12 0x4
00250 #define _CS11 0x2
00251 #define _CS10 0x1
00252 
00253 // TCCR1A
00254 #define _COM1A1 0x80
00255 #define _COM1A0 0x40
00256 #define _COM1B1 0x20
00257 #define _COM1B0 0x10
00258 #define _WGM11 0x2
00259 #define _WGM10 0x1
00260 
00261 // DIDR1
00262 #define _AIN1D 0x2
00263 #define _AIN0D 0x1
00264 
00265 // DIDR0
00266 #define _ADC5D 0x20
00267 #define _ADC4D 0x10
00268 #define _ADC3D 0x8
00269 #define _ADC2D 0x4
00270 #define _ADC1D 0x2
00271 #define _ADC0D 0x1
00272 
00273 // ADMUX
00274 #define _REFS1 0x80
00275 #define _REFS0 0x40
00276 #define _ADLAR 0x20
00277 #define _MUX3 0x8
00278 #define _MUX2 0x4
00279 #define _MUX1 0x2
00280 #define _MUX0 0x1
00281 
00282 // ADCSRB
00283 #define _ACME 0x40
00284 #define _ADTS2 0x4
00285 #define _ADTS1 0x2
00286 #define _ADTS0 0x1
00287 
00288 // ADCSRA
00289 #define _ADEN 0x80
00290 #define _ADSC 0x40
00291 #define _ADATE 0x20
00292 #define _ADIF 0x10
00293 #define _ADIE 0x8
00294 #define _ADPS2 0x4
00295 #define _ADPS1 0x2
00296 #define _ADPS0 0x1
00297 
00298 // TIMSK2
00299 #define _OCIE2B 0x4
00300 #define _OCIE2A 0x2
00301 #define _TOIE2 0x1
00302 
00303 // TIMSK1
00304 #define _ICIE1 0x20
00305 #define _OCIE1B 0x4
00306 #define _OCIE1A 0x2
00307 #define _TOIE1 0x1
00308 
00309 // TIMSK0
00310 #define _OCIE0B 0x4
00311 #define _OCIE0A 0x2
00312 #define _TOIE0 0x1
00313 
00314 // PCMSK2
00315 #define _PCINT23 0x80
00316 #define _PCINT22 0x40
00317 #define _PCINT21 0x20
00318 #define _PCINT20 0x10
00319 #define _PCINT19 0x8
00320 #define _PCINT18 0x4
00321 #define _PCINT17 0x2
00322 #define _PCINT16 0x1
00323 
00324 // PCMSK1
00325 #define _PCINT14 0x40
00326 #define _PCINT13 0x20
00327 #define _PCINT12 0x10
00328 #define _PCINT11 0x8
00329 #define _PCINT10 0x4
00330 #define _PCINT9 0x2
00331 #define _PCINT8 0x1
00332 
00333 // PCMSK0
00334 #define _PCINT7 0x80
00335 #define _PCINT6 0x40
00336 #define _PCINT5 0x20
00337 #define _PCINT4 0x10
00338 #define _PCINT3 0x8
00339 #define _PCINT2 0x4
00340 #define _PCINT1 0x2
00341 #define _PCINT0 0x1
00342 
00343 // EICRA
00344 #define _ISC11 0x8
00345 #define _ISC10 0x4
00346 #define _ISC01 0x2
00347 #define _ISC00 0x1
00348 
00349 // PCICR
00350 #define _PCIE2 0x4
00351 #define _PCIE1 0x2
00352 #define _PCIE0 0x1
00353 
00354 // PRR
00355 #define _PRTWI 0x80
00356 #define _PRTIM2 0x40
00357 #define _PRTIM0 0x20
00358 #define _PRTIM1 0x8
00359 #define _PRSPI 0x4
00360 #define _PRUSART0 0x2
00361 #define _PRADC 0x1
00362 
00363 // CLKPR
00364 #define _CLKPCE 0x80
00365 #define _CLKPS3 0x8
00366 #define _CLKPS2 0x4
00367 #define _CLKPS1 0x2
00368 #define _CLKPS0 0x1
00369 
00370 // WDTCSR
00371 #define _WDIF 0x80
00372 #define _WDIE 0x40
00373 #define _WDP3 0x20
00374 #define _WDCE 0x10
00375 #define _WDE 0x8
00376 #define _WDP2 0x4
00377 #define _WDP1 0x2
00378 #define _WDP0 0x1
00379 
00380 // SREG
00381 #define _SREG_I 0x80
00382 #define _SREG_T 0x40
00383 #define _SREG_H 0x20
00384 #define _SREG_S 0x10
00385 #define _SREG_V 0x8
00386 #define _SREG_N 0x4
00387 #define _SREG_Z 0x2
00388 #define _SREG_C 0x1
00389 
00390 // SPL
00391 #define _SP7 0x80
00392 #define _SP6 0x40
00393 #define _SP5 0x20
00394 #define _SP4 0x10
00395 #define _SP3 0x8
00396 #define _SP2 0x4
00397 #define _SP1 0x2
00398 #define _SP0 0x1
00399 
00400 // SPMCSR
00401 #define _SPMIE 0x80
00402 #define _RWWSB 0x40
00403 #define _RWWSRE 0x10
00404 #define _BLBSET 0x8
00405 #define _PGWRT 0x4
00406 #define _PGERS 0x2
00407 #define _SELFPRGEN 0x1
00408 
00409 // MCUCR
00410 #define _PUD 0x10
00411 #define _IVSEL 0x2
00412 #define _IVCE 0x1
00413 
00414 // MCUSR
00415 #define _WDRF 0x8
00416 #define _BORF 0x4
00417 #define _EXTRF 0x2
00418 #define _PORF 0x1
00419 
00420 // SMCR
00421 #define _SM2 0x8
00422 #define _SM1 0x4
00423 #define _SM0 0x2
00424 #define _SE 0x1
00425 
00426 // ACSR
00427 #define _ACD 0x80
00428 #define _ACBG 0x40
00429 #define _ACO 0x20
00430 #define _ACI 0x10
00431 #define _ACIE 0x8
00432 #define _ACIC 0x4
00433 #define _ACIS1 0x2
00434 #define _ACIS0 0x1
00435 
00436 // SPSR
00437 #define _SPIF 0x80
00438 #define _WCOL 0x40
00439 #define _SPI2X 0x1
00440 
00441 // SPCR
00442 #define _SPIE 0x80
00443 #define _SPE 0x40
00444 #define _DORD 0x20
00445 #define _MSTR 0x10
00446 #define _CPOL 0x8
00447 #define _CPHA 0x4
00448 #define _SPR1 0x2
00449 #define _SPR0 0x1
00450 
00451 // TCCR0B
00452 #define _FOC0A 0x80
00453 #define _FOC0B 0x40
00454 #define _WGM02 0x8
00455 #define _CS02 0x4
00456 #define _CS01 0x2
00457 #define _CS00 0x1
00458 
00459 // TCCR0A
00460 #define _COM0A1 0x80
00461 #define _COM0A0 0x40
00462 #define _COM0B1 0x20
00463 #define _COM0B0 0x10
00464 #define _WGM01 0x2
00465 #define _WGM00 0x1
00466 
00467 // GTCCR
00468 #define _TSM 0x80
00469 #define _PSRASY 0x2
00470 #define _PSRSYNC 0x1
00471 
00472 // EECR
00473 #define _EEPM1 0x20
00474 #define _EEPM0 0x10
00475 #define _EERIE 0x8
00476 #define _EEMPE 0x4
00477 #define _EEPE 0x2
00478 #define _EERE 0x1
00479 
00480 // EIMSK
00481 #define _INT1 0x2
00482 #define _INT0 0x1
00483 
00484 // EIFR
00485 #define _INTF1 0x2
00486 #define _INTF0 0x1
00487 
00488 // PCIFR
00489 #define _PCIF2 0x4
00490 #define _PCIF1 0x2
00491 #define _PCIF0 0x1
00492 
00493 // TIFR2
00494 #define _OCF2B 0x4
00495 #define _OCF2A 0x2
00496 #define _TOV2 0x1
00497 
00498 // TIFR1
00499 #define _ICF1 0x20
00500 #define _OCF1B 0x4
00501 #define _OCF1A 0x2
00502 #define _TOV1 0x1
00503 
00504 // TIFR0
00505 #define _OCF0B 0x4
00506 #define _OCF0A 0x2
00507 #define _TOV0 0x1
00508 
00509 // PORTD
00510 #define _PD7 0x80
00511 #define _PD6 0x40
00512 #define _PD5 0x20
00513 #define _PD4 0x10
00514 #define _PD3 0x8
00515 #define _PD2 0x4
00516 #define _PD1 0x2
00517 #define _PD0 0x1
00518 
00519 // DDRD
00520 #define _DDD7 0x80
00521 #define _DDD6 0x40
00522 #define _DDD5 0x20
00523 #define _DDD4 0x10
00524 #define _DDD3 0x8
00525 #define _DDD2 0x4
00526 #define _DDD1 0x2
00527 #define _DDD0 0x1
00528 
00529 // PIND
00530 #define _PIND7 0x80
00531 #define _PIND6 0x40
00532 #define _PIND5 0x20
00533 #define _PIND4 0x10
00534 #define _PIND3 0x8
00535 #define _PIND2 0x4
00536 #define _PIND1 0x2
00537 #define _PIND0 0x1
00538 
00539 // PORTC
00540 #define _PC6 0x40
00541 #define _PC5 0x20
00542 #define _PC4 0x10
00543 #define _PC3 0x8
00544 #define _PC2 0x4
00545 #define _PC1 0x2
00546 #define _PC0 0x1
00547 
00548 // DDRC
00549 #define _DDC6 0x40
00550 #define _DDC5 0x20
00551 #define _DDC4 0x10
00552 #define _DDC3 0x8
00553 #define _DDC2 0x4
00554 #define _DDC1 0x2
00555 #define _DDC0 0x1
00556 
00557 // PINC
00558 #define _PINC6 0x40
00559 #define _PINC5 0x20
00560 #define _PINC4 0x10
00561 #define _PINC3 0x8
00562 #define _PINC2 0x4
00563 #define _PINC1 0x2
00564 #define _PINC0 0x1
00565 
00566 // PORTB
00567 #define _PB7 0x80
00568 #define _PB6 0x40
00569 #define _PB5 0x20
00570 #define _PB4 0x10
00571 #define _PB3 0x8
00572 #define _PB2 0x4
00573 #define _PB1 0x2
00574 #define _PB0 0x1
00575 
00576 // DDRB
00577 #define _DDB7 0x80
00578 #define _DDB6 0x40
00579 #define _DDB5 0x20
00580 #define _DDB4 0x10
00581 #define _DDB3 0x8
00582 #define _DDB2 0x4
00583 #define _DDB1 0x2
00584 #define _DDB0 0x1
00585 
00586 // PINB
00587 #define _PINB7 0x80
00588 #define _PINB6 0x40
00589 #define _PINB5 0x20
00590 #define _PINB4 0x10
00591 #define _PINB3 0x8
00592 #define _PINB2 0x4
00593 #define _PINB1 0x2
00594 #define _PINB0 0x1
00595 
00596 
00597 // General ports
00598 namespace AVRCpp
00599 {
00600         __DECLARE_PORT__(D);
00601         __DECLARE_PORT__(C);
00602         __DECLARE_PORT__(B);
00603         
00604 } // namespace AVRCpp
00605 
00606 
00607 /**********************************************************************************************************************/
00608 
00609 #endif // ifndef __AVR_CPP_IO_H__
00610 #endif // ifndef __AVR_CPP_ATMEGA168_IO_H__

Generated on Sat Sep 15 23:40:38 2007 for AVR C++ Lib for ATmega168 by  doxygen 1.5.2
SourceForge.net Logo MTÜ TTÜ Robotiklubi