mirror of
https://github.com/oliverschmidt/contiki.git
synced 2024-12-23 01:29:33 +00:00
cleared lock semantics
This commit is contained in:
parent
7ca33e2285
commit
44c93fcd93
@ -143,17 +143,19 @@ uart_set_handler(unsigned mode, fp_uart_handler fpHandler)
|
||||
int
|
||||
uart_lock(unsigned mode)
|
||||
{
|
||||
// already locked?
|
||||
if (uart_mode != mode && uart_lockcnt > 0) {
|
||||
return 0;
|
||||
if (uart_mode == mode) {
|
||||
uart_lockcnt++;
|
||||
return 1;
|
||||
}
|
||||
|
||||
// increase lock count
|
||||
uart_lockcnt++;
|
||||
// switch mode (if neccessary)
|
||||
if (uart_lockcnt == 0) {
|
||||
uart_set_mode(mode);
|
||||
uart_lockcnt++;
|
||||
return 1;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
/*---------------------------------------------------------------------------*/
|
||||
int
|
||||
uart_lock_wait(unsigned mode)
|
||||
@ -167,23 +169,15 @@ uart_lock_wait(unsigned mode)
|
||||
int
|
||||
uart_unlock(unsigned mode)
|
||||
{
|
||||
if ((uart_lockcnt == 0) || (mode != uart_mode)) {
|
||||
uart_lockcnt = 0;
|
||||
uart_set_mode(UART_MODE_DEFAULT);
|
||||
if (uart_lockcnt == 0 || mode != uart_mode) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
// decrement lock
|
||||
if (uart_lockcnt > 0) {
|
||||
uart_lockcnt--;
|
||||
// if no more locks, switch back to default mode
|
||||
if (uart_lockcnt == 0) {
|
||||
if (--uart_lockcnt == 0) {
|
||||
uart_set_mode(UART_MODE_DEFAULT);
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
/*---------------------------------------------------------------------------*/
|
||||
void
|
||||
uart_set_mode(unsigned mode)
|
||||
@ -196,7 +190,6 @@ uart_set_mode(unsigned mode)
|
||||
IE2 &= ~(URXIE1 | UTXIE1); // disable irq
|
||||
uart_configure(mode); // configure uart parameters
|
||||
uart_mode = mode;
|
||||
uart_lockcnt = 0;
|
||||
|
||||
if (uart_handler[mode] != NULL) {
|
||||
IE2 |= URXIE1; // Enable USART1 RX interrupt
|
||||
|
Loading…
Reference in New Issue
Block a user