mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-23 21:19:56 +07:00
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: Denis Bolotin <dbolotin@marvell.com> Signed-off-by: Michal Kalderon <mkalderon@marvell.com> Signed-off-by: Ariel Elior <aelior@marvell.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
c543cb4a5f
commit
9ac6bb1414
@ -920,8 +920,7 @@ u16 qed_get_cm_pq_idx_llt_mtc(struct qed_hwfn *p_hwfn, u8 tc);
|
||||
|
||||
/* doorbell recovery mechanism */
|
||||
void qed_db_recovery_dp(struct qed_hwfn *p_hwfn);
|
||||
void qed_db_recovery_execute(struct qed_hwfn *p_hwfn,
|
||||
enum qed_db_rec_exec db_exec);
|
||||
void qed_db_recovery_execute(struct qed_hwfn *p_hwfn);
|
||||
bool qed_edpm_enabled(struct qed_hwfn *p_hwfn);
|
||||
|
||||
/* Other Linux specific common definitions */
|
||||
|
@ -300,26 +300,19 @@ void qed_db_recovery_dp(struct qed_hwfn *p_hwfn)
|
||||
|
||||
/* Ring the doorbell of a single doorbell recovery entry */
|
||||
static void qed_db_recovery_ring(struct qed_hwfn *p_hwfn,
|
||||
struct qed_db_recovery_entry *db_entry,
|
||||
enum qed_db_rec_exec db_exec)
|
||||
struct qed_db_recovery_entry *db_entry)
|
||||
{
|
||||
if (db_exec != DB_REC_ONCE) {
|
||||
/* Print according to width */
|
||||
if (db_entry->db_width == DB_REC_WIDTH_32B) {
|
||||
DP_VERBOSE(p_hwfn, QED_MSG_SPQ,
|
||||
"%s doorbell address %p data %x\n",
|
||||
db_exec == DB_REC_DRY_RUN ?
|
||||
"would have rung" : "ringing",
|
||||
db_entry->db_addr,
|
||||
*(u32 *)db_entry->db_data);
|
||||
} else {
|
||||
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));
|
||||
}
|
||||
/* Print according to width */
|
||||
if (db_entry->db_width == DB_REC_WIDTH_32B) {
|
||||
DP_VERBOSE(p_hwfn, QED_MSG_SPQ,
|
||||
"ringing doorbell address %p data %x\n",
|
||||
db_entry->db_addr,
|
||||
*(u32 *)db_entry->db_data);
|
||||
} else {
|
||||
DP_VERBOSE(p_hwfn, QED_MSG_SPQ,
|
||||
"ringing doorbell address %p data %llx\n",
|
||||
db_entry->db_addr,
|
||||
*(u64 *)(db_entry->db_data));
|
||||
}
|
||||
|
||||
/* Sanity */
|
||||
@ -334,14 +327,12 @@ static void qed_db_recovery_ring(struct qed_hwfn *p_hwfn,
|
||||
wmb();
|
||||
|
||||
/* Ring the doorbell */
|
||||
if (db_exec == DB_REC_REAL_DEAL || db_exec == DB_REC_ONCE) {
|
||||
if (db_entry->db_width == DB_REC_WIDTH_32B)
|
||||
DIRECT_REG_WR(db_entry->db_addr,
|
||||
*(u32 *)(db_entry->db_data));
|
||||
else
|
||||
DIRECT_REG_WR64(db_entry->db_addr,
|
||||
*(u64 *)(db_entry->db_data));
|
||||
}
|
||||
if (db_entry->db_width == DB_REC_WIDTH_32B)
|
||||
DIRECT_REG_WR(db_entry->db_addr,
|
||||
*(u32 *)(db_entry->db_data));
|
||||
else
|
||||
DIRECT_REG_WR64(db_entry->db_addr,
|
||||
*(u64 *)(db_entry->db_data));
|
||||
|
||||
/* Flush the write combined buffer. Next doorbell may come from a
|
||||
* different entity to the same address...
|
||||
@ -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 */
|
||||
void qed_db_recovery_execute(struct qed_hwfn *p_hwfn,
|
||||
enum qed_db_rec_exec db_exec)
|
||||
void qed_db_recovery_execute(struct qed_hwfn *p_hwfn)
|
||||
{
|
||||
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",
|
||||
p_hwfn->db_recovery_info.db_recovery_counter);
|
||||
DP_NOTICE(p_hwfn, "Executing doorbell recovery. Counter was %d\n",
|
||||
p_hwfn->db_recovery_info.db_recovery_counter);
|
||||
|
||||
/* Track amount of times recovery was executed */
|
||||
p_hwfn->db_recovery_info.db_recovery_counter++;
|
||||
}
|
||||
/* Track amount of times recovery was executed */
|
||||
p_hwfn->db_recovery_info.db_recovery_counter++;
|
||||
|
||||
/* Protect the list */
|
||||
spin_lock_bh(&p_hwfn->db_recovery_info.lock);
|
||||
list_for_each_entry(db_entry,
|
||||
&p_hwfn->db_recovery_info.list, list_entry) {
|
||||
qed_db_recovery_ring(p_hwfn, db_entry, db_exec);
|
||||
if (db_exec == DB_REC_ONCE)
|
||||
break;
|
||||
}
|
||||
|
||||
&p_hwfn->db_recovery_info.list, list_entry)
|
||||
qed_db_recovery_ring(p_hwfn, db_entry);
|
||||
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)
|
||||
|
||||
overflow = qed_rd(p_hwfn, p_ptt, DORQ_REG_PF_OVFL_STICKY);
|
||||
DP_NOTICE(p_hwfn, "PF Overflow sticky 0x%x\n", overflow);
|
||||
if (!overflow) {
|
||||
qed_db_recovery_execute(p_hwfn, DB_REC_ONCE);
|
||||
if (!overflow)
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (qed_edpm_enabled(p_hwfn)) {
|
||||
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)
|
||||
qed_wr(p_hwfn, p_ptt, DORQ_REG_PF_OVFL_STICKY, 0x0);
|
||||
|
||||
/* 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;
|
||||
}
|
||||
|
@ -192,8 +192,8 @@ void qed_int_disable_post_isr_release(struct qed_dev *cdev);
|
||||
|
||||
/**
|
||||
* @brief - Doorbell Recovery handler.
|
||||
* Run DB_REAL_DEAL doorbell recovery in case of PF overflow
|
||||
* (and flush DORQ if needed), otherwise run DB_REC_ONCE.
|
||||
* Run doorbell recovery in case of PF overflow (and flush DORQ if
|
||||
* needed).
|
||||
*
|
||||
* @param p_hwfn
|
||||
* @param p_ptt
|
||||
|
Loading…
Reference in New Issue
Block a user