From 125d9e3548550da7f2e2a4cd7a1533bbdcd54f05 Mon Sep 17 00:00:00 2001 From: Gregory Nutt Date: Tue, 30 Sep 2014 15:49:30 -0600 Subject: [PATCH] Fix a cornercase problem in in the UART simulation --- arch/sim/src/up_simuart.c | 45 ++++++++++++++++++++++----------------- 1 file changed, 26 insertions(+), 19 deletions(-) diff --git a/arch/sim/src/up_simuart.c b/arch/sim/src/up_simuart.c index d3bd202b73..7d48d39877 100644 --- a/arch/sim/src/up_simuart.c +++ b/arch/sim/src/up_simuart.c @@ -232,30 +232,37 @@ int simuart_getc(void) int index; int ch; + /* Locking the scheduler should eliminate the race conditions in the + * unlikely case of mutliple reading threads. + */ + + sched_lock(); for (;;) { /* Wait for a byte to become available */ - simuart_wait(); - - /* The UART buffer show be non-empty... check anyway */ - - if (g_uarthead != g_uarttail) + while (g_uarthead == g_uarttail) { - /* Take the next byte from the tail of the buffer */ - - index = g_uarttail; - ch = (int)g_uartbuffer[index]; - - /* Increment the tai index (with wrapping) */ - - if (++index >= SIMUART_BUFSIZE) - { - index = 0; - } - - g_uarttail = index; - return ch; + simuart_wait(); } + + + /* The UART buffer is non-empty... Take the next byte from the tail + * of the buffer. + */ + + index = g_uarttail; + ch = (int)g_uartbuffer[index]; + + /* Increment the tai index (with wrapping) */ + + if (++index >= SIMUART_BUFSIZE) + { + index = 0; + } + + g_uarttail = index; + sched_unlock(); + return ch; } }