Awake in order to let event processing occur immediately.
This commit is contained in:
parent
a6af72d129
commit
6139885c51
1 changed files with 20 additions and 14 deletions
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue