diff options
| author | Bdale Garbee <bdale@gag.com> | 2013-05-16 00:36:23 -0600 | 
|---|---|---|
| committer | Bdale Garbee <bdale@gag.com> | 2013-05-16 00:36:23 -0600 | 
| commit | 02d111b1b53ef01fc6e9ab6c4bc60b8af1be0067 (patch) | |
| tree | 8356f4a019969ee99a45e264c87d38555cf316cc /src/avr/ao_serial_avr.c | |
| parent | 7a2e1f05adad990a6b161865267abf07ffec7a7e (diff) | |
| parent | 7699a55aed3a9a7daeb4c6a5a9a280f43edf455f (diff) | |
Merge branch 'branch-1.2' into debian
Diffstat (limited to 'src/avr/ao_serial_avr.c')
| -rw-r--r-- | src/avr/ao_serial_avr.c | 43 | 
1 files changed, 21 insertions, 22 deletions
| diff --git a/src/avr/ao_serial_avr.c b/src/avr/ao_serial_avr.c index dcee246c..e0f813d5 100644 --- a/src/avr/ao_serial_avr.c +++ b/src/avr/ao_serial_avr.c @@ -59,52 +59,51 @@ ISR(USART1_UDRE_vect)  	ao_wakeup(&ao_serial1_tx_fifo);  } -char -ao_serial1_getchar(void) __critical -{ -	char	c; -	cli(); -	while (ao_fifo_empty(ao_serial1_rx_fifo)) -		ao_sleep(&ao_serial1_rx_fifo); -	ao_fifo_remove(ao_serial1_rx_fifo, c); -	sei(); -	return c; -} -  #if USE_SERIAL_1_STDIN -char -ao_serial1_pollchar(void) __critical +int +_ao_serial1_pollchar(void)  {  	char	c; -	cli();  	if (ao_fifo_empty(ao_serial1_rx_fifo)) {  		sei();  		return AO_READ_AGAIN;  	}  	ao_fifo_remove(ao_serial1_rx_fifo,c); -	sei();  	return c;  }  #endif +char +ao_serial1_getchar(void) __critical +{ +	char	c; + +	ao_arch_block_interrupts(); +	while (ao_fifo_empty(ao_serial1_rx_fifo)) +		ao_sleep(&ao_serial1_rx_fifo); +	ao_fifo_remove(ao_serial1_rx_fifo, c); +	ao_arch_release_interrupts(); +	return c; +} +  void -ao_serial1_putchar(char c) __critical +ao_serial1_putchar(char c)  { -	cli(); +	ao_arch_block_interrupts();  	while (ao_fifo_full(ao_serial1_tx_fifo))  		ao_sleep(&ao_serial1_tx_fifo);  	ao_fifo_insert(ao_serial1_tx_fifo, c);  	ao_serial_tx1_start(); -	sei(); +	ao_arch_release_interrupts();  }  void  ao_serial1_drain(void) __critical  { -	cli(); +	ao_arch_block_interrupts();  	while (!ao_fifo_empty(ao_serial1_tx_fifo))  		ao_sleep(&ao_serial1_tx_fifo); -	sei(); +	ao_arch_release_interrupts();  }  static const struct { @@ -155,7 +154,7 @@ ao_serial_init(void)  		  (1 << RXCIE1) |	/* Enable receive interrupts */  		  (1 << UDRIE1));	/* Enable transmit empty interrupts */  #if USE_SERIAL_1_STDIN -	ao_add_stdio(ao_serial1_pollchar, +	ao_add_stdio(_ao_serial1_pollchar,  		     ao_serial1_putchar,  		     NULL);  #endif | 
