AtMega8 - problem s externim prerusenim
Zdeněk lada
zdenek023ster@gmail.com
Sobota Únor 6 11:40:33 CET 2010
Dobrý den,
možná mi unikají souvislosti ale proč v programu nemáte funci main?
SwUart_Init se spustí automaticky po resetu Atmega8?
Já dávám inicializace registrů do funce main a na jejím konci vkládám
nekonečnou smyčku(pak už to jede podle přerušení)...
Zdeněk
2010/2/6 Kamil Rezac <krezac@gmail.com>
> Ahoj, pokousim se tu prihnout sw seriak (je to zalozene na rutine z
> avrlib) a deje se mi to, ze i kdyz na konci zpracovani bytu (interrupt
> z output compare casovace) vymazu (zapisem 1) flag pro externi
> preruseni, tak stejne nastane... V errate jsem nic nenasel, takze to
> urcite bude mezi zidli a klavesnici.... Na obrazku z osciloskopu je
> horni stopa vstup ('i' na 9600bps), dolni (PB4) se meni pri preruseni
> (at uz casovace nebo INT1 - viz kod). Jak je videt, nastane falesna
> detekce sestupne hrany - startbitu (ta spicka uprostred dolni stopy
> jsou dve preruseni po sobe - casovac a pak ext, odzkouseno) a tak se
> prijme jeste falesny byte 0xff. KJoukam do toho uz vcera cely vecer a
> dneska od rana a nic... :( Samozrejme by se to dalo ahakovat, ale
> zajima me, co je blbe...
>
> Kod a obrazek z osciloskopu prikladam
> Predem dik za nakopnuti
> KR
>
> // UART receive pin defines
> // This pin must correspond to the
> // External Interrupt 1 (INT1) pin for your processor
> #define UARTSW_RX_PORT PORTD ///< UART Receive Port
> #define UARTSW_RX_DDR DDRD ///< UART Receive DDR
> #define UARTSW_RX_PORTIN PIND ///< UART Receive Port
> Input
> #define UARTSW_RX_PIN PD3 ///< UART Receive Pin
>
> // calculate division factor for requested baud rate, and set it
> //UartswBaudRateDiv = (u08)(((F_CPU/256L)+(baudrate/2L))/(baudrate*1L));
> #define BAUDRATE_DIV
>
> (uint8_t)(((ROBBUS_CPU_FREQ/64)+(ROBBUS_SWUART_BAUDRATE/2L))/(ROBBUS_SWUART_BAUDRATE*1L))
>
> static PtrSwUartHandler_t g_handler;
>
> // uartsw receive status and data variables
> static volatile uint8_t UartswRxData;
> static volatile uint8_t UartswRxBitNum;
>
> static volatile uint8_t first = 1;
>
>
> void SwUart_Init(PtrSwUartHandler_t handler) {
>
> // initialize ports
> UARTSW_RX_DDR &= ~(1<<UARTSW_RX_PIN);
> UARTSW_RX_PORT &= ~(1<<UARTSW_RX_PIN);
>
> // initialize timer 2
> TCNT2 = 0;
> TCCR2 = (1<<CS22); // normal mode 1:64 prescaler
>
> //PORTD |= (1<< PD2);
> // setup the receiver
> // OC2 interrupt disabled
> TIMSK &= ~(1<<OCIE2);
> // INT0 trigger on rising/falling edge
> MCUCSR |= (1<<ISC11); // non-invert: falling edge
> // enable INT1 interrupt
> GICR |= (1<<INT1);
> }
>
> ISR(INT1_vect) {
> PORTB ^= (1<<PB4);
> // this must be is a start bit
>
> // disable INT1 interrupt
> GICR &= ~(1<<INT1);
> // schedule data bit sampling 1.5 bit periods from now
> OCR2 = TCNT2 + BAUDRATE_DIV + BAUDRATE_DIV/2;
> // clear OC0 interrupt flag
> TIFR = (1<<OCF2);
> // enable OC0 interrupt
> TIMSK |= (1<<OCIE2);
> // reset bit counter
> UartswRxBitNum = 0;
> // reset data
> UartswRxData = 0;
> }
>
> ISR(TIMER2_COMP_vect) {
> PORTB ^= (1<<PB4);
> // start bit has already been received
> // we're in the data bits
>
> // shift data byte to make room for new bit
> UartswRxData = UartswRxData>>1;
>
> // sample the data line
> if( (UARTSW_RX_PORTIN & (1<<UARTSW_RX_PIN)) ) // non-inverting
> {
> // serial line is marking
> // record '1' bit
> UartswRxData |= 0x80;
> }
>
> // increment bit counter
> UartswRxBitNum++;
> // schedule next bit sample
> OCR2 += BAUDRATE_DIV;
>
> // check if we have a full byte
> if(UartswRxBitNum >= 8)
> {
> // call handler
> // g_handler(UartswRxData);
> UDR = UartswRxData;
> // disable OC0 interrupt
> TIMSK &= ~(1<<OCIE2);
> // clear INT1 interrupt flag
> GIFR = (1<<INTF1);
> // enable INT interrupt
> GICR |= (1<<INT1);
> }
> }
>
> _______________________________________________
> HW-list mailing list - sponsored by www.HW.cz
> Hw-list@list.hw.cz
> http://list.hw.cz/mailman/listinfo/hw-list
>
>
------------- další část ---------------
HTML příloha byla odstraněna...
URL: <http://list.hw.cz/pipermail/hw-list/attachments/20100206/ca8e10ef/attachment-0001.htm>
More information about the Hw-list
mailing list