configurable line buffer size + simplified interrupt handler + overflow check on line buffer

This commit is contained in:
fros4943 2009-11-02 12:47:06 +00:00
parent 5aab2eb77d
commit 5f71e9914e

View file

@ -28,7 +28,7 @@
* *
* This file is part of the Contiki operating system. * This file is part of the Contiki operating system.
* *
* @(#)$Id: serial-line.c,v 1.2 2009/10/27 16:20:31 fros4943 Exp $ * @(#)$Id: serial-line.c,v 1.3 2009/11/02 12:47:06 fros4943 Exp $
*/ */
#include "dev/serial-line.h" #include "dev/serial-line.h"
#include <string.h> /* for memcpy() */ #include <string.h> /* for memcpy() */
@ -56,44 +56,37 @@ PROCESS(serial_line_process, "Serial driver");
process_event_t serial_line_event_message; process_event_t serial_line_event_message;
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
int int
serial_line_input_byte(unsigned char c) serial_line_input_byte(unsigned char c)
{ {
static uint8_t overflow = 0; /* Buffer overflow: ignore until END */ static uint8_t overflow = 0; /* Buffer overflow: ignore until END */
if (IGNORE_CHAR(c)) {
return 0;
}
if(!IGNORE_CHAR(c)) {
if(!overflow) { if(!overflow) {
/* Add character */ /* Add character */
if(ringbuf_put(&rxbuf, c) == 0) { if(ringbuf_put(&rxbuf, c) == 0) {
/* Buffer overflow: ignore the rest of the line */ /* Buffer overflow: ignore the rest of the line */
overflow = 1; overflow = 1;
process_poll(&serial_line_process);
} }
} else { } else {
/* Buffer overflowed: /* Buffer overflowed:
* Only (try to) add terminator characters, otherwise skip */ * Only (try to) add terminator characters, otherwise skip */
if(c == END && ringbuf_put(&rxbuf, c) != 0) { if(c == END && ringbuf_put(&rxbuf, c) != 0) {
overflow = 0; overflow = 0;
} else {
process_poll(&serial_line_process);
} }
} }
if(c == END && !overflow) { /* Wake up consumer process */
/* Tell process at least one (potentially cropped due to overflow)
* line exists in the buffer */
process_poll(&serial_line_process); process_poll(&serial_line_process);
return 1; return 1;
} }
}
return 0;
}
/*---------------------------------------------------------------------------*/ /*---------------------------------------------------------------------------*/
PROCESS_THREAD(serial_line_process, ev, data) PROCESS_THREAD(serial_line_process, ev, data)
{ {
static char buf[128]; static char buf[BUFSIZE];
static int ptr; static int ptr;
PROCESS_BEGIN(); PROCESS_BEGIN();
@ -110,12 +103,15 @@ PROCESS_THREAD(serial_line_process, ev, data)
PROCESS_YIELD(); PROCESS_YIELD();
} else { } else {
if(c != END) { if(c != END) {
if(ptr < BUFSIZE-1) {
buf[ptr++] = (uint8_t)c; buf[ptr++] = (uint8_t)c;
} else {
/* Ignore character (wait for EOL) */
}
} else { } else {
/* Terminate */ /* Terminate */
buf[ptr++] = (uint8_t)'\0'; buf[ptr++] = (uint8_t)'\0';
if (ptr > 1) {
/* Broadcast event */ /* Broadcast event */
process_post(PROCESS_BROADCAST, serial_line_event_message, buf); process_post(PROCESS_BROADCAST, serial_line_event_message, buf);
@ -124,7 +120,6 @@ PROCESS_THREAD(serial_line_process, ev, data)
process_post(PROCESS_CURRENT(), PROCESS_EVENT_CONTINUE, NULL)) { process_post(PROCESS_CURRENT(), PROCESS_EVENT_CONTINUE, NULL)) {
PROCESS_WAIT_EVENT_UNTIL(ev == PROCESS_EVENT_CONTINUE); PROCESS_WAIT_EVENT_UNTIL(ev == PROCESS_EVENT_CONTINUE);
} }
}
ptr = 0; ptr = 0;
} }
} }