diff options
| author | Keith Packard <keithp@keithp.com> | 2010-11-26 16:14:15 -0800 | 
|---|---|---|
| committer | Keith Packard <keithp@keithp.com> | 2010-12-22 20:39:40 -0800 | 
| commit | 07213dc34fa20470a4b36a327a83d75b0f010ebb (patch) | |
| tree | a85d444ab7d2ccf01153c15e6fb2adf8473b602f /src/ao_dma.c | |
| parent | b62580855c5144f5bc7e0172289bce08814d9472 (diff) | |
altos: clean up radio abort paths. Share radio code.
Instead of aborting the DMA and radio operation and expecting that to
be handled reasonably by the radio receiving task, rewrite things so
that the abort function just wakes the receiving task while that
terminates the DMA and cleans up the radio.
This eliminates all kinds of nasty bugs dealing with radio abort
smashing the radio registers at the wrong time, or interrupting a
radio transmission.
Signed-off-by: Keith Packard <keithp@keithp.com>
Diffstat (limited to 'src/ao_dma.c')
| -rw-r--r-- | src/ao_dma.c | 4 | 
1 files changed, 1 insertions, 3 deletions
| diff --git a/src/ao_dma.c b/src/ao_dma.c index 946666ab..6052964a 100644 --- a/src/ao_dma.c +++ b/src/ao_dma.c @@ -107,8 +107,6 @@ ao_dma_abort(uint8_t id)  	uint8_t	mask = (1 << id);  	DMAARM = 0x80 | mask;  	DMAIRQ &= ~mask; -	*(ao_dma_done[id]) |= AO_DMA_ABORTED; -	ao_wakeup(ao_dma_done[id]);  }  void @@ -124,7 +122,7 @@ ao_dma_isr(void) __interrupt 8  			DMAIF = 0;  			/* Clear the completed ID */  			DMAIRQ = ~mask; -			*(ao_dma_done[id]) |= AO_DMA_DONE; +			*(ao_dma_done[id]) = 1;  			ao_wakeup(ao_dma_done[id]);  			break;  		} | 
