From eca79de4364b2f38bd8b1e77c9a041fa581c33e4 Mon Sep 17 00:00:00 2001 From: patacongo Date: Sat, 6 Nov 2010 02:42:59 +0000 Subject: [PATCH] Progress debugging serial driver git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@3078 42af7a65-404d-4744-a932-0658087f49c3 --- ChangeLog | 5 ++++- Documentation/NuttX.html | 7 +++++-- arch/avr/src/at32uc3/at32uc3_serial.c | 4 ++-- arch/avr/src/common/up_initialize.c | 13 +++++++++++++ 4 files changed, 24 insertions(+), 5 deletions(-) diff --git a/ChangeLog b/ChangeLog index 6790a04c30..315a98d48f 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1323,6 +1323,9 @@ * configs/avr32dev1/ostest - The AVR32 port now successfully passes the examples/ostest. We have a good AVR32 port! * configs/avr32dev1/nsh - Added a configuration to support the NuttShell - (NSH). Testing of this configuration is just beginning. + (NSH). As of this writing, here is a problem receiving serial data (this + is, very likely, my hardware setup). + * lib/lib_open.c - Fix an error in fdopen when a valid file desciptor does + not refer to an open file. diff --git a/Documentation/NuttX.html b/Documentation/NuttX.html index 56817e3ce3..d3fff7c9bb 100644 --- a/Documentation/NuttX.html +++ b/Documentation/NuttX.html @@ -8,7 +8,7 @@

NuttX RTOS

-

Last Updated: November 4, 2010

+

Last Updated: November 5, 2010

@@ -1952,7 +1952,10 @@ nuttx-5.13 2010-xx-xx Gregory Nutt <spudmonkey@racsa.co.cr> * configs/avr32dev1/ostest - The AVR32 port now successfully passes the examples/ostest. We have a good AVR32 port! * configs/avr32dev1/nsh - Added a configuration to support the NuttShell - (NSH). Testing of this configuration is just beginning. + (NSH). As of this writing, here is a problem receiving serial data (this + is, very likely, my hardware setup). + * lib/lib_open.c - Fix an error in fdopen when a valid file desciptor does + not refer to an open file. pascal-2.1 2010-xx-xx Gregory Nutt <spudmonkey@racsa.co.cr> diff --git a/arch/avr/src/at32uc3/at32uc3_serial.c b/arch/avr/src/at32uc3/at32uc3_serial.c index 7ed9d4b951..e0c2bae48b 100644 --- a/arch/avr/src/at32uc3/at32uc3_serial.c +++ b/arch/avr/src/at32uc3/at32uc3_serial.c @@ -336,7 +336,7 @@ static inline void up_disableusartint(struct up_dev_s *priv, uint32_t *imr) { if (imr) { - *imr = up_serialin(priv, AVR32_USART_IDR_OFFSET); + *imr = up_serialin(priv, AVR32_USART_IMR_OFFSET); } /* Disable all interrupts */ @@ -594,7 +594,7 @@ static int up_receive(struct uart_dev_s *dev, uint32_t *status) static void up_rxint(struct uart_dev_s *dev, bool enable) { struct up_dev_s *priv = (struct up_dev_s*)dev->priv; - + if (enable) { /* Receive an interrupt when their is anything in the Rx data register (or an Rx diff --git a/arch/avr/src/common/up_initialize.c b/arch/avr/src/common/up_initialize.c index fde474ec61..abbff8532d 100644 --- a/arch/avr/src/common/up_initialize.c +++ b/arch/avr/src/common/up_initialize.c @@ -51,6 +51,19 @@ /**************************************************************************** * Pre-processor Definitions ****************************************************************************/ +/* Determine which (if any) console driver to use. This will probably cause + * up_serialinit to be incorrectly called if there is no USART configured to + * be an RS-232 device (see as an example arch/avr/src/at32uc23/at32uc3_config.h) + * This will probably have to be revisited someday. + */ + +#if CONFIG_NFILE_DESCRIPTORS == 0 || defined(CONFIG_DEV_LOWCONSOLE) +# undef CONFIG_USE_SERIALDRIVER +# undef CONFIG_USE_EARLYSERIALINIT +#elif defined(CONFIG_DEV_CONSOLE) && CONFIG_NFILE_DESCRIPTORS > 0 +# define CONFIG_USE_SERIALDRIVER 1 +# define CONFIG_USE_EARLYSERIALINIT 1 +#endif /**************************************************************************** * Private Types