Unverified Commit 85d39cf2 authored by Earle F. Philhower, III's avatar Earle F. Philhower, III Committed by GitHub

Restore GPIO functions on SerialUART::end (#836)

Fix #834
parent 2d777acc
...@@ -171,12 +171,16 @@ void SerialUART::begin(unsigned long baud, uint16_t config) { ...@@ -171,12 +171,16 @@ void SerialUART::begin(unsigned long baud, uint16_t config) {
break; break;
} }
uart_set_format(_uart, bits, stop, parity); uart_set_format(_uart, bits, stop, parity);
_fcnTx = gpio_get_function(_tx);
_fcnRx = gpio_get_function(_rx);
gpio_set_function(_tx, GPIO_FUNC_UART); gpio_set_function(_tx, GPIO_FUNC_UART);
gpio_set_function(_rx, GPIO_FUNC_UART); gpio_set_function(_rx, GPIO_FUNC_UART);
if (_rts != UART_PIN_NOT_DEFINED) { if (_rts != UART_PIN_NOT_DEFINED) {
_fcnRts = gpio_get_function(_rts);
gpio_set_function(_rts, GPIO_FUNC_UART); gpio_set_function(_rts, GPIO_FUNC_UART);
} }
if (_cts != UART_PIN_NOT_DEFINED) { if (_cts != UART_PIN_NOT_DEFINED) {
_fcnCts = gpio_get_function(_cts);
gpio_set_function(_cts, GPIO_FUNC_UART); gpio_set_function(_cts, GPIO_FUNC_UART);
} }
uart_set_hw_flow(_uart, _rts != UART_PIN_NOT_DEFINED, _cts != UART_PIN_NOT_DEFINED); uart_set_hw_flow(_uart, _rts != UART_PIN_NOT_DEFINED, _cts != UART_PIN_NOT_DEFINED);
...@@ -211,6 +215,7 @@ void SerialUART::end() { ...@@ -211,6 +215,7 @@ void SerialUART::end() {
irq_set_enabled(UART1_IRQ, false); irq_set_enabled(UART1_IRQ, false);
} }
} }
// Paranoia - ensure nobody else is using anything here at the same time // Paranoia - ensure nobody else is using anything here at the same time
mutex_enter_blocking(&_mutex); mutex_enter_blocking(&_mutex);
mutex_enter_blocking(&_fifoMutex); mutex_enter_blocking(&_fifoMutex);
...@@ -219,6 +224,16 @@ void SerialUART::end() { ...@@ -219,6 +224,16 @@ void SerialUART::end() {
// Reset the mutexes once all is off/cleaned up // Reset the mutexes once all is off/cleaned up
mutex_exit(&_fifoMutex); mutex_exit(&_fifoMutex);
mutex_exit(&_mutex); mutex_exit(&_mutex);
// Restore pin functions
gpio_set_function(_tx, _fcnTx);
gpio_set_function(_rx, _fcnRx);
if (_rts != UART_PIN_NOT_DEFINED) {
gpio_set_function(_rts, _fcnRts);
}
if (_cts != UART_PIN_NOT_DEFINED) {
gpio_set_function(_cts, _fcnCts);
}
} }
void SerialUART::_pumpFIFO() { void SerialUART::_pumpFIFO() {
......
...@@ -71,6 +71,7 @@ private: ...@@ -71,6 +71,7 @@ private:
uart_inst_t *_uart; uart_inst_t *_uart;
pin_size_t _tx, _rx; pin_size_t _tx, _rx;
pin_size_t _rts, _cts; pin_size_t _rts, _cts;
enum gpio_function _fcnTx, _fcnRx, _fcnRts, _fcnCts;
int _baud; int _baud;
mutex_t _mutex; mutex_t _mutex;
bool _polling = false; bool _polling = false;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment