Rainbow-electronics ATmega128L Bedienungsanleitung Seite 110

  • Herunterladen
  • Zu meinen Handbüchern hinzufügen
  • Drucken
  • Seite
    / 331
  • Inhaltsverzeichnis
  • LESEZEICHEN
  • Bewertet. / 5. Basierend auf Kundenbewertungen
Seitenansicht 109
110
ATmega128(L)
2467B09/01
It is important to notice that accessing 16-bit registers are atomic operations. If an inter-
rupt occurs between the two instructions accessing the 16-bit register, and the interrupt
code updates the temporary register by accessing the same or any other of the 16-bit
timer registers, then the result of the access outside the interrupt will be corrupted.
Therefore, when both the main code and the interrupt code update the temporary regis-
ter, the main code must disable the interrupts during the 16-bit access.
The following code examples show how to do an atomic read of the TCNTn register con-
tents. Reading any of the OCRnA/B/C or ICRn registers can be done by using the same
principle.
Note: 1. The example code assumes that the part specific header file is included.
For I/O registers located in extended I/O map, IN, OUT, SBIS, SBIC, CBI, and
SBI instructions must be replaced with instructions that allow access to extended
I/O. Typically LDS and STS combined with SBRS, SBRC, SBR, and CBR.
The assembly code example returns the TCNTn value in the r17:r16 register pair.
Assembly Code Example
(1)
TIM16_ReadTCNTn:
; Save global interrupt flag
in r18,SREG
; Disable interrupts
cli
; Read TCNTn into r17:r16
in r16,TCNTnL
in r17,TCNTnH
; Restore global interrupt flag
out SREG,r18
ret
C Code Example
(1)
unsigned int TIM16_ReadTCNTn( void )
{
unsigned char sreg;
unsigned int i;
/* Save global interrupt flag */
sreg = SREG;
/* Disable interrupts */
_CLI();
/* Read TCNTn into i */
i = TCNTn;
/* Restore global interrupt flag */
SREG = sreg;
return i;
}
Seitenansicht 109
1 2 ... 105 106 107 108 109 110 111 112 113 114 115 ... 330 331

Kommentare zu diesen Handbüchern

Keine Kommentare