Commit 9ac6bb14 authored by Denis Bolotin's avatar Denis Bolotin Committed by David S. Miller

qed: Delete redundant doorbell recovery types

DB_REC_DRY_RUN (running doorbell recovery without sending doorbells) is
never used. DB_REC_ONCE (send a single doorbell from the doorbell recovery)
is not needed anymore because by running the periodic handler we make sure
we check the overflow status later instead.
This patch is needed because in the next patches, the only doorbell
recovery type being used is DB_REC_REAL_DEAL, and the fixes are much
cleaner without this enum.
Signed-off-by: default avatarDenis Bolotin <dbolotin@marvell.com>
Signed-off-by: default avatarMichal Kalderon <mkalderon@marvell.com>
Signed-off-by: default avatarAriel Elior <aelior@marvell.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent c543cb4a
...@@ -920,8 +920,7 @@ u16 qed_get_cm_pq_idx_llt_mtc(struct qed_hwfn *p_hwfn, u8 tc); ...@@ -920,8 +920,7 @@ u16 qed_get_cm_pq_idx_llt_mtc(struct qed_hwfn *p_hwfn, u8 tc);
/* doorbell recovery mechanism */ /* doorbell recovery mechanism */
void qed_db_recovery_dp(struct qed_hwfn *p_hwfn); void qed_db_recovery_dp(struct qed_hwfn *p_hwfn);
void qed_db_recovery_execute(struct qed_hwfn *p_hwfn, void qed_db_recovery_execute(struct qed_hwfn *p_hwfn);
enum qed_db_rec_exec db_exec);
bool qed_edpm_enabled(struct qed_hwfn *p_hwfn); bool qed_edpm_enabled(struct qed_hwfn *p_hwfn);
/* Other Linux specific common definitions */ /* Other Linux specific common definitions */
......
...@@ -300,26 +300,19 @@ void qed_db_recovery_dp(struct qed_hwfn *p_hwfn) ...@@ -300,26 +300,19 @@ void qed_db_recovery_dp(struct qed_hwfn *p_hwfn)
/* Ring the doorbell of a single doorbell recovery entry */ /* Ring the doorbell of a single doorbell recovery entry */
static void qed_db_recovery_ring(struct qed_hwfn *p_hwfn, static void qed_db_recovery_ring(struct qed_hwfn *p_hwfn,
struct qed_db_recovery_entry *db_entry, struct qed_db_recovery_entry *db_entry)
enum qed_db_rec_exec db_exec) {
{ /* Print according to width */
if (db_exec != DB_REC_ONCE) { if (db_entry->db_width == DB_REC_WIDTH_32B) {
/* Print according to width */ DP_VERBOSE(p_hwfn, QED_MSG_SPQ,
if (db_entry->db_width == DB_REC_WIDTH_32B) { "ringing doorbell address %p data %x\n",
DP_VERBOSE(p_hwfn, QED_MSG_SPQ, db_entry->db_addr,
"%s doorbell address %p data %x\n", *(u32 *)db_entry->db_data);
db_exec == DB_REC_DRY_RUN ? } else {
"would have rung" : "ringing", DP_VERBOSE(p_hwfn, QED_MSG_SPQ,
db_entry->db_addr, "ringing doorbell address %p data %llx\n",
*(u32 *)db_entry->db_data); db_entry->db_addr,
} else { *(u64 *)(db_entry->db_data));
DP_VERBOSE(p_hwfn, QED_MSG_SPQ,
"%s doorbell address %p data %llx\n",
db_exec == DB_REC_DRY_RUN ?
"would have rung" : "ringing",
db_entry->db_addr,
*(u64 *)(db_entry->db_data));
}
} }
/* Sanity */ /* Sanity */
...@@ -334,14 +327,12 @@ static void qed_db_recovery_ring(struct qed_hwfn *p_hwfn, ...@@ -334,14 +327,12 @@ static void qed_db_recovery_ring(struct qed_hwfn *p_hwfn,
wmb(); wmb();
/* Ring the doorbell */ /* Ring the doorbell */
if (db_exec == DB_REC_REAL_DEAL || db_exec == DB_REC_ONCE) { if (db_entry->db_width == DB_REC_WIDTH_32B)
if (db_entry->db_width == DB_REC_WIDTH_32B) DIRECT_REG_WR(db_entry->db_addr,
DIRECT_REG_WR(db_entry->db_addr, *(u32 *)(db_entry->db_data));
*(u32 *)(db_entry->db_data)); else
else DIRECT_REG_WR64(db_entry->db_addr,
DIRECT_REG_WR64(db_entry->db_addr, *(u64 *)(db_entry->db_data));
*(u64 *)(db_entry->db_data));
}
/* Flush the write combined buffer. Next doorbell may come from a /* Flush the write combined buffer. Next doorbell may come from a
* different entity to the same address... * different entity to the same address...
...@@ -350,29 +341,21 @@ static void qed_db_recovery_ring(struct qed_hwfn *p_hwfn, ...@@ -350,29 +341,21 @@ static void qed_db_recovery_ring(struct qed_hwfn *p_hwfn,
} }
/* Traverse the doorbell recovery entry list and ring all the doorbells */ /* Traverse the doorbell recovery entry list and ring all the doorbells */
void qed_db_recovery_execute(struct qed_hwfn *p_hwfn, void qed_db_recovery_execute(struct qed_hwfn *p_hwfn)
enum qed_db_rec_exec db_exec)
{ {
struct qed_db_recovery_entry *db_entry = NULL; struct qed_db_recovery_entry *db_entry = NULL;
if (db_exec != DB_REC_ONCE) { DP_NOTICE(p_hwfn, "Executing doorbell recovery. Counter was %d\n",
DP_NOTICE(p_hwfn, p_hwfn->db_recovery_info.db_recovery_counter);
"Executing doorbell recovery. Counter was %d\n",
p_hwfn->db_recovery_info.db_recovery_counter);
/* Track amount of times recovery was executed */ /* Track amount of times recovery was executed */
p_hwfn->db_recovery_info.db_recovery_counter++; p_hwfn->db_recovery_info.db_recovery_counter++;
}
/* Protect the list */ /* Protect the list */
spin_lock_bh(&p_hwfn->db_recovery_info.lock); spin_lock_bh(&p_hwfn->db_recovery_info.lock);
list_for_each_entry(db_entry, list_for_each_entry(db_entry,
&p_hwfn->db_recovery_info.list, list_entry) { &p_hwfn->db_recovery_info.list, list_entry)
qed_db_recovery_ring(p_hwfn, db_entry, db_exec); qed_db_recovery_ring(p_hwfn, db_entry);
if (db_exec == DB_REC_ONCE)
break;
}
spin_unlock_bh(&p_hwfn->db_recovery_info.lock); spin_unlock_bh(&p_hwfn->db_recovery_info.lock);
} }
......
...@@ -411,10 +411,8 @@ int qed_db_rec_handler(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt) ...@@ -411,10 +411,8 @@ int qed_db_rec_handler(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt)
overflow = qed_rd(p_hwfn, p_ptt, DORQ_REG_PF_OVFL_STICKY); overflow = qed_rd(p_hwfn, p_ptt, DORQ_REG_PF_OVFL_STICKY);
DP_NOTICE(p_hwfn, "PF Overflow sticky 0x%x\n", overflow); DP_NOTICE(p_hwfn, "PF Overflow sticky 0x%x\n", overflow);
if (!overflow) { if (!overflow)
qed_db_recovery_execute(p_hwfn, DB_REC_ONCE);
return 0; return 0;
}
if (qed_edpm_enabled(p_hwfn)) { if (qed_edpm_enabled(p_hwfn)) {
rc = qed_db_rec_flush_queue(p_hwfn, p_ptt); rc = qed_db_rec_flush_queue(p_hwfn, p_ptt);
...@@ -429,7 +427,7 @@ int qed_db_rec_handler(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt) ...@@ -429,7 +427,7 @@ int qed_db_rec_handler(struct qed_hwfn *p_hwfn, struct qed_ptt *p_ptt)
qed_wr(p_hwfn, p_ptt, DORQ_REG_PF_OVFL_STICKY, 0x0); qed_wr(p_hwfn, p_ptt, DORQ_REG_PF_OVFL_STICKY, 0x0);
/* Repeat all last doorbells (doorbell drop recovery) */ /* Repeat all last doorbells (doorbell drop recovery) */
qed_db_recovery_execute(p_hwfn, DB_REC_REAL_DEAL); qed_db_recovery_execute(p_hwfn);
return 0; return 0;
} }
......
...@@ -192,8 +192,8 @@ void qed_int_disable_post_isr_release(struct qed_dev *cdev); ...@@ -192,8 +192,8 @@ void qed_int_disable_post_isr_release(struct qed_dev *cdev);
/** /**
* @brief - Doorbell Recovery handler. * @brief - Doorbell Recovery handler.
* Run DB_REAL_DEAL doorbell recovery in case of PF overflow * Run doorbell recovery in case of PF overflow (and flush DORQ if
* (and flush DORQ if needed), otherwise run DB_REC_ONCE. * needed).
* *
* @param p_hwfn * @param p_hwfn
* @param p_ptt * @param p_ptt
......
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