Commit 687b13e9 authored by Daniel Martensson's avatar Daniel Martensson Committed by David S. Miller

caif-hsi: Making read and writes asynchronous.

Some platforms do not allow to put HSI block into low-power
mode when FIFO is not empty. The patch flushes (by reading)
FIFO at wake down sequence. Asynchronous read and write is
implemented for that. As a side effect this will also greatly
improve performance.
Signed-off-by: default avatarSjur Brændeland <sjur.brandeland@stericsson.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 73033c98
This diff is collapsed.
...@@ -75,18 +75,21 @@ struct cfhsi_desc { ...@@ -75,18 +75,21 @@ struct cfhsi_desc {
#define CFHSI_WAKE_UP_ACK 1 #define CFHSI_WAKE_UP_ACK 1
#define CFHSI_WAKE_DOWN_ACK 2 #define CFHSI_WAKE_DOWN_ACK 2
#define CFHSI_AWAKE 3 #define CFHSI_AWAKE 3
#define CFHSI_PENDING_RX 4 #define CFHSI_WAKELOCK_HELD 4
#define CFHSI_SHUTDOWN 6 #define CFHSI_SHUTDOWN 5
#define CFHSI_FLUSH_FIFO 7 #define CFHSI_FLUSH_FIFO 6
#ifndef CFHSI_INACTIVITY_TOUT #ifndef CFHSI_INACTIVITY_TOUT
#define CFHSI_INACTIVITY_TOUT (1 * HZ) #define CFHSI_INACTIVITY_TOUT (1 * HZ)
#endif /* CFHSI_INACTIVITY_TOUT */ #endif /* CFHSI_INACTIVITY_TOUT */
#ifndef CFHSI_WAKEUP_TOUT #ifndef CFHSI_WAKE_TOUT
#define CFHSI_WAKEUP_TOUT (3 * HZ) #define CFHSI_WAKE_TOUT (3 * HZ)
#endif /* CFHSI_WAKEUP_TOUT */ #endif /* CFHSI_WAKE_TOUT */
#ifndef CFHSI_MAX_RX_RETRIES
#define CFHSI_MAX_RX_RETRIES (10 * HZ)
#endif
/* Structure implemented by the CAIF HSI driver. */ /* Structure implemented by the CAIF HSI driver. */
struct cfhsi_drv { struct cfhsi_drv {
...@@ -109,6 +112,15 @@ struct cfhsi_dev { ...@@ -109,6 +112,15 @@ struct cfhsi_dev {
struct cfhsi_drv *drv; struct cfhsi_drv *drv;
}; };
/* Structure holds status of received CAIF frames processing */
struct cfhsi_rx_state {
int state;
int nfrms;
int pld_len;
int retries;
bool piggy_desc;
};
/* Structure implemented by CAIF HSI drivers. */ /* Structure implemented by CAIF HSI drivers. */
struct cfhsi { struct cfhsi {
struct caif_dev_common cfdev; struct caif_dev_common cfdev;
...@@ -118,7 +130,7 @@ struct cfhsi { ...@@ -118,7 +130,7 @@ struct cfhsi {
struct cfhsi_drv drv; struct cfhsi_drv drv;
struct cfhsi_dev *dev; struct cfhsi_dev *dev;
int tx_state; int tx_state;
int rx_state; struct cfhsi_rx_state rx_state;
int rx_len; int rx_len;
u8 *rx_ptr; u8 *rx_ptr;
u8 *tx_buf; u8 *tx_buf;
...@@ -130,13 +142,12 @@ struct cfhsi { ...@@ -130,13 +142,12 @@ struct cfhsi {
struct list_head list; struct list_head list;
struct work_struct wake_up_work; struct work_struct wake_up_work;
struct work_struct wake_down_work; struct work_struct wake_down_work;
struct work_struct rx_done_work;
struct work_struct tx_done_work;
struct workqueue_struct *wq; struct workqueue_struct *wq;
wait_queue_head_t wake_up_wait; wait_queue_head_t wake_up_wait;
wait_queue_head_t wake_down_wait; wait_queue_head_t wake_down_wait;
wait_queue_head_t flush_fifo_wait; wait_queue_head_t flush_fifo_wait;
struct timer_list timer; struct timer_list timer;
struct timer_list rx_slowpath_timer;
unsigned long bits; unsigned long bits;
}; };
......
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