mirror of
https://github.com/FEX-Emu/linux.git
synced 2024-12-28 20:37:27 +00:00
serial: ifx6x60: ifx_spi_write don't need to do mrdy_assert when fifo is not empty
This patch check whether the fifo lenth is empty before writing new data to fifo.If condition is true,ifx_spi_write need to trigger one mrdy_assert. If condition is false,the mrdy_assert will be trigger by the next ifx_spi_io. Cc: Bi Chao <chao.bi@intel.com> Signed-off-by: Chen Jun <jun.d.chen@intel.com> Acked-by: Alan Cox <alan@linux.intel.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
1b2f8a9550
commit
e8823f1ca8
@ -508,9 +508,16 @@ static int ifx_spi_write(struct tty_struct *tty, const unsigned char *buf,
|
|||||||
{
|
{
|
||||||
struct ifx_spi_device *ifx_dev = tty->driver_data;
|
struct ifx_spi_device *ifx_dev = tty->driver_data;
|
||||||
unsigned char *tmp_buf = (unsigned char *)buf;
|
unsigned char *tmp_buf = (unsigned char *)buf;
|
||||||
int tx_count = kfifo_in_locked(&ifx_dev->tx_fifo, tmp_buf, count,
|
unsigned long flags;
|
||||||
&ifx_dev->fifo_lock);
|
bool is_fifo_empty;
|
||||||
mrdy_assert(ifx_dev);
|
|
||||||
|
spin_lock_irqsave(&ifx_dev->fifo_lock, flags);
|
||||||
|
is_fifo_empty = kfifo_is_empty(&ifx_dev->tx_fifo);
|
||||||
|
int tx_count = kfifo_in(&ifx_dev->tx_fifo, tmp_buf, count);
|
||||||
|
spin_unlock_irqrestore(&ifx_dev->fifo_lock, flags);
|
||||||
|
if (is_fifo_empty)
|
||||||
|
mrdy_assert(ifx_dev);
|
||||||
|
|
||||||
return tx_count;
|
return tx_count;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user