Commit 750fa7c2 authored by Furong Zhou's avatar Furong Zhou Committed by Herbert Xu

crypto: qat - limit heartbeat notifications

When the driver detects an heartbeat failure, it starts the recovery
flow. Set a limit so that the number of events is limited in case the
heartbeat status is read too frequently.
Signed-off-by: default avatarFurong Zhou <furong.zhou@intel.com>
Reviewed-by: default avatarAhsan Atta <ahsan.atta@intel.com>
Reviewed-by: default avatarMarkas Rapoportas <markas.rapoportas@intel.com>
Reviewed-by: default avatarGiovanni Cabiddu <giovanni.cabiddu@intel.com>
Signed-off-by: default avatarMun Chun Yep <mun.chun.yep@intel.com>
Signed-off-by: default avatarHerbert Xu <herbert@gondor.apana.org.au>
parent f5419a42
...@@ -205,6 +205,19 @@ static int adf_hb_get_status(struct adf_accel_dev *accel_dev) ...@@ -205,6 +205,19 @@ static int adf_hb_get_status(struct adf_accel_dev *accel_dev)
return ret; return ret;
} }
static void adf_heartbeat_reset(struct adf_accel_dev *accel_dev)
{
u64 curr_time = adf_clock_get_current_time();
u64 time_since_reset = curr_time - accel_dev->heartbeat->last_hb_reset_time;
if (time_since_reset < ADF_CFG_HB_RESET_MS)
return;
accel_dev->heartbeat->last_hb_reset_time = curr_time;
if (adf_notify_fatal_error(accel_dev))
dev_err(&GET_DEV(accel_dev), "Failed to notify fatal error\n");
}
void adf_heartbeat_status(struct adf_accel_dev *accel_dev, void adf_heartbeat_status(struct adf_accel_dev *accel_dev,
enum adf_device_heartbeat_status *hb_status) enum adf_device_heartbeat_status *hb_status)
{ {
...@@ -229,9 +242,7 @@ void adf_heartbeat_status(struct adf_accel_dev *accel_dev, ...@@ -229,9 +242,7 @@ void adf_heartbeat_status(struct adf_accel_dev *accel_dev,
"Heartbeat ERROR: QAT is not responding.\n"); "Heartbeat ERROR: QAT is not responding.\n");
*hb_status = HB_DEV_UNRESPONSIVE; *hb_status = HB_DEV_UNRESPONSIVE;
hb->hb_failed_counter++; hb->hb_failed_counter++;
if (adf_notify_fatal_error(accel_dev)) adf_heartbeat_reset(accel_dev);
dev_err(&GET_DEV(accel_dev),
"Failed to notify fatal error\n");
return; return;
} }
......
...@@ -13,6 +13,8 @@ struct dentry; ...@@ -13,6 +13,8 @@ struct dentry;
#define ADF_CFG_HB_TIMER_DEFAULT_MS 500 #define ADF_CFG_HB_TIMER_DEFAULT_MS 500
#define ADF_CFG_HB_COUNT_THRESHOLD 3 #define ADF_CFG_HB_COUNT_THRESHOLD 3
#define ADF_CFG_HB_RESET_MS 5000
enum adf_device_heartbeat_status { enum adf_device_heartbeat_status {
HB_DEV_UNRESPONSIVE = 0, HB_DEV_UNRESPONSIVE = 0,
HB_DEV_ALIVE, HB_DEV_ALIVE,
...@@ -30,6 +32,7 @@ struct adf_heartbeat { ...@@ -30,6 +32,7 @@ struct adf_heartbeat {
unsigned int hb_failed_counter; unsigned int hb_failed_counter;
unsigned int hb_timer; unsigned int hb_timer;
u64 last_hb_check_time; u64 last_hb_check_time;
u64 last_hb_reset_time;
bool ctrs_cnt_checked; bool ctrs_cnt_checked;
struct hb_dma_addr { struct hb_dma_addr {
dma_addr_t phy_addr; dma_addr_t phy_addr;
......
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