Awake in order to let event processing occur immediately.

This commit is contained in:
nvt-se 2007-08-02 08:57:58 +00:00
parent a6af72d129
commit 6139885c51

View file

@ -51,12 +51,14 @@ interrupt(DACDMA_VECTOR) irq_dacdma(void)
DMA0CTL &= ~(DMAIFG | DMAIE); DMA0CTL &= ~(DMAIFG | DMAIE);
line = 0; line = 0;
process_post(&cc1020_sender_process, cc1020_event, &line); process_post(&cc1020_sender_process, cc1020_event, &line);
LPM_AWAKE();
} }
if (DMA1CTL & DMAIFG) { if (DMA1CTL & DMAIFG) {
DMA1CTL &= ~(DMAIFG | DMAIE); DMA1CTL &= ~(DMAIFG | DMAIE);
line = 1; line = 1;
process_post(&cc1020_sender_process, cc1020_event, &line); process_post(&cc1020_sender_process, cc1020_event, &line);
LPM_AWAKE();
} }
if (DAC12_0CTL & DAC12IFG) { if (DAC12_0CTL & DAC12IFG) {
@ -78,17 +80,21 @@ dma_transfer(unsigned char *buf, unsigned len)
DMACTL1 = 0x0000; DMACTL1 = 0x0000;
/* /*
* Single transfer mode, dstadr unchanged, srcadr * Set single transfer mode with byte-per-byte transfers.
* incremented, byte access *
* The source address is incremented for each byte, while the
* destination address remains constant.
*
* Important to use DMALEVEL when using USART TX * Important to use DMALEVEL when using USART TX
* interrupts so first edge * interrupts so first edge
* doesn't get lost (hangs every 50. - 100. time)! * doesn't get lost (hangs every 50. - 100. time)!
*/ */
DMA0CTL = DMA0CTL = DMADT_0 | DMADSTINCR_0 | DMASRCINCR_3 | DMASBDB | DMALEVEL | DMAIE;
DMADT_0 | DMADSTINCR_0 | DMASRCINCR_3 | DMASBDB | DMALEVEL | DMAIE;
DMA0SA = (unsigned) buf; DMA0SA = (unsigned) buf;
DMA0DA = (unsigned) &TXBUF0; DMA0DA = (unsigned) &TXBUF0;
DMA0SZ = len; DMA0SZ = len;
DMA0CTL |= DMAEN; // enable DMA DMA0CTL |= DMAEN; // enable DMA
U0CTL &= ~SWRST; // enable UART, starts transfer U0CTL &= ~SWRST; // enable UART state machine, starts transfer
} }