SAM3/4 Serial: In NONBLOCKING mode serial does not receive bytes from UART. This happens because RX interrupt was disabled in the setup routine. To fix this I save interrupt configuration before uart shutdown and restore it after. From Max Neklyudov.

This commit is contained in:
Gregory Nutt 2015-05-21 07:06:47 -06:00
parent 0885317600
commit 52bcc7d0ba

View File

@ -1,7 +1,7 @@
/****************************************************************************
* arch/arm/src/sam34/sam_serial.c
*
* Copyright (C) 2010, 2012-2014 Gregory Nutt. All rights reserved.
* Copyright (C) 2010, 2012-2015 Gregory Nutt. All rights reserved.
* Author: Gregory Nutt <gnutt@nuttx.org>
*
* Redistribution and use in source and binary forms, with or without
@ -650,7 +650,9 @@ static inline void up_serialout(struct up_dev_s *priv, int offset, uint32_t valu
static inline void up_restoreusartint(struct up_dev_s *priv, uint32_t imr)
{
/* Restore the previous interrupt state (assuming all interrupts disabled) */
/* Re-enable previously disabled interrupts state (assuming all interrupts
* disabled)
*/
up_serialout(priv, SAM_UART_IER_OFFSET, imr);
}
@ -693,6 +695,7 @@ static int up_setup(struct uart_dev_s *dev)
struct up_dev_s *priv = (struct up_dev_s*)dev->priv;
#ifndef CONFIG_SUPPRESS_UART_CONFIG
uint32_t regval;
uint32_t imr;
/* Note: The logic here depends on the fact that that the USART module
* was enabled and the pins were configured in sam_lowsetup().
@ -700,6 +703,7 @@ static int up_setup(struct uart_dev_s *dev)
/* The shutdown method will put the UART in a known, disabled state */
up_disableallints(priv, &imr);
up_shutdown(dev);
/* Set up the mode register. Start with normal UART mode and the MCK
@ -806,6 +810,8 @@ static int up_setup(struct uart_dev_s *dev)
/* Enable receiver & transmitter */
up_serialout(priv, SAM_UART_CR_OFFSET, (UART_CR_RXEN|UART_CR_TXEN));
up_restoreusartint(priv, imr);
#endif
return OK;