uart: flush the uart buffer when setting the flow control 31/160531/2
authorSegwon <segwon.han@samsung.com>
Thu, 16 Nov 2017 14:35:59 +0000 (23:35 +0900)
committerSegwon <segwon.han@samsung.com>
Fri, 17 Nov 2017 02:54:46 +0000 (11:54 +0900)
Change-Id: Ie1c2609a243242ded2ecc1e4411ca07231a784b9
Signed-off-by: Segwon <segwon.han@samsung.com>
include/interface/peripheral_interface_uart.h
src/interface/peripheral_interface_uart.c

index fb446381ac6d96735f79b2c1481c21a5fd7f4ec8..75748cea7f32bf437b30d6d9ce68d21ca7a82e1a 100644 (file)
@@ -31,9 +31,8 @@ void peripheral_interface_uart_close(peripheral_uart_h uart);
 * @brief uart_flush() flushes uart buffer.
 *
 * @param[in] file_hndl handle of uart_context
-* @return On success, 0 is returned. On failure, a negative value is returned.
 */
-int peripheral_interface_uart_flush(peripheral_uart_h uart);
+void peripheral_interface_uart_flush(peripheral_uart_h uart);
 
 /**
 * @brief uart_set_baudrate() sets uart baud rate.
index eadef4a9289aa0e96b57ffd6addf76bff536832a..45e0690f512b8ee727536620e444e3f7436ceadd 100644 (file)
@@ -35,12 +35,9 @@ void peripheral_interface_uart_close(peripheral_uart_h uart)
        close(uart->fd);
 }
 
-int peripheral_interface_uart_flush(peripheral_uart_h uart)
+void peripheral_interface_uart_flush(peripheral_uart_h uart)
 {
-       int ret = tcflush(uart->fd, TCIOFLUSH);
-       CHECK_ERROR(ret != 0);
-
-       return PERIPHERAL_ERROR_NONE;
+       tcflush(uart->fd, TCIOFLUSH);
 }
 
 int peripheral_interface_uart_set_baud_rate(peripheral_uart_h uart, peripheral_uart_baud_rate_e baud)
@@ -59,6 +56,7 @@ int peripheral_interface_uart_set_baud_rate(peripheral_uart_h uart, peripheral_u
        tio.c_cc[VTIME] = 0;
 
        peripheral_interface_uart_flush(uart);
+
        ret = tcsetattr(uart->fd, TCSANOW, &tio);
        CHECK_ERROR(ret != 0);
 
@@ -79,6 +77,7 @@ int peripheral_interface_uart_set_byte_size(peripheral_uart_h uart, peripheral_u
        tio.c_cflag |= (CLOCAL | CREAD);
 
        peripheral_interface_uart_flush(uart);
+
        ret = tcsetattr(uart->fd, TCSANOW, &tio);
        CHECK_ERROR(ret != 0);
 
@@ -111,6 +110,7 @@ int peripheral_interface_uart_set_parity(peripheral_uart_h uart, peripheral_uart
        }
 
        peripheral_interface_uart_flush(uart);
+
        ret = tcsetattr(uart->fd, TCSANOW, &tio);
        CHECK_ERROR(ret != 0);
 
@@ -139,6 +139,7 @@ int peripheral_interface_uart_set_stop_bits(peripheral_uart_h uart, peripheral_u
        }
 
        peripheral_interface_uart_flush(uart);
+
        ret = tcsetattr(uart->fd, TCSANOW, &tio);
        CHECK_ERROR(ret != 0);
 
@@ -167,6 +168,8 @@ int peripheral_interface_uart_set_flow_control(peripheral_uart_h uart, periphera
        else
                return PERIPHERAL_ERROR_INVALID_PARAMETER;
 
+       peripheral_interface_uart_flush(uart);
+
        ret = tcsetattr(uart->fd, TCSANOW, &tio);
        CHECK_ERROR(ret != 0);