Commit 08eb1fb0 authored by Michal Kalderon's avatar Michal Kalderon Committed by David S. Miller

qed*: Change hwfn used for sb initialization

When initializing status blocks use the affined hwfn
instead of the leading one for RDMA / Storage
Signed-off-by: default avatarAriel Elior <ariel.elior@marvell.com>
Signed-off-by: default avatarMichal Kalderon <michal.kalderon@marvell.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 79284ade
...@@ -312,7 +312,8 @@ static void qedr_free_mem_sb(struct qedr_dev *dev, ...@@ -312,7 +312,8 @@ static void qedr_free_mem_sb(struct qedr_dev *dev,
struct qed_sb_info *sb_info, int sb_id) struct qed_sb_info *sb_info, int sb_id)
{ {
if (sb_info->sb_virt) { if (sb_info->sb_virt) {
dev->ops->common->sb_release(dev->cdev, sb_info, sb_id); dev->ops->common->sb_release(dev->cdev, sb_info, sb_id,
QED_SB_TYPE_CNQ);
dma_free_coherent(&dev->pdev->dev, sizeof(*sb_info->sb_virt), dma_free_coherent(&dev->pdev->dev, sizeof(*sb_info->sb_virt),
(void *)sb_info->sb_virt, sb_info->sb_phys); (void *)sb_info->sb_virt, sb_info->sb_phys);
} }
......
...@@ -1301,26 +1301,21 @@ static u32 qed_sb_init(struct qed_dev *cdev, ...@@ -1301,26 +1301,21 @@ static u32 qed_sb_init(struct qed_dev *cdev,
{ {
struct qed_hwfn *p_hwfn; struct qed_hwfn *p_hwfn;
struct qed_ptt *p_ptt; struct qed_ptt *p_ptt;
int hwfn_index;
u16 rel_sb_id; u16 rel_sb_id;
u8 n_hwfns;
u32 rc; u32 rc;
/* RoCE uses single engine and CMT uses two engines. When using both /* RoCE/Storage use a single engine in CMT mode while L2 uses both */
* we force only a single engine. Storage uses only engine 0 too. if (type == QED_SB_TYPE_L2_QUEUE) {
*/ p_hwfn = &cdev->hwfns[sb_id % cdev->num_hwfns];
if (type == QED_SB_TYPE_L2_QUEUE) rel_sb_id = sb_id / cdev->num_hwfns;
n_hwfns = cdev->num_hwfns; } else {
else p_hwfn = QED_AFFIN_HWFN(cdev);
n_hwfns = 1; rel_sb_id = sb_id;
}
hwfn_index = sb_id % n_hwfns;
p_hwfn = &cdev->hwfns[hwfn_index];
rel_sb_id = sb_id / n_hwfns;
DP_VERBOSE(cdev, NETIF_MSG_INTR, DP_VERBOSE(cdev, NETIF_MSG_INTR,
"hwfn [%d] <--[init]-- SB %04x [0x%04x upper]\n", "hwfn [%d] <--[init]-- SB %04x [0x%04x upper]\n",
hwfn_index, rel_sb_id, sb_id); IS_LEAD_HWFN(p_hwfn) ? 0 : 1, rel_sb_id, sb_id);
if (IS_PF(p_hwfn->cdev)) { if (IS_PF(p_hwfn->cdev)) {
p_ptt = qed_ptt_acquire(p_hwfn); p_ptt = qed_ptt_acquire(p_hwfn);
...@@ -1339,20 +1334,26 @@ static u32 qed_sb_init(struct qed_dev *cdev, ...@@ -1339,20 +1334,26 @@ static u32 qed_sb_init(struct qed_dev *cdev,
} }
static u32 qed_sb_release(struct qed_dev *cdev, static u32 qed_sb_release(struct qed_dev *cdev,
struct qed_sb_info *sb_info, u16 sb_id) struct qed_sb_info *sb_info,
u16 sb_id,
enum qed_sb_type type)
{ {
struct qed_hwfn *p_hwfn; struct qed_hwfn *p_hwfn;
int hwfn_index;
u16 rel_sb_id; u16 rel_sb_id;
u32 rc; u32 rc;
hwfn_index = sb_id % cdev->num_hwfns; /* RoCE/Storage use a single engine in CMT mode while L2 uses both */
p_hwfn = &cdev->hwfns[hwfn_index]; if (type == QED_SB_TYPE_L2_QUEUE) {
p_hwfn = &cdev->hwfns[sb_id % cdev->num_hwfns];
rel_sb_id = sb_id / cdev->num_hwfns; rel_sb_id = sb_id / cdev->num_hwfns;
} else {
p_hwfn = QED_AFFIN_HWFN(cdev);
rel_sb_id = sb_id;
}
DP_VERBOSE(cdev, NETIF_MSG_INTR, DP_VERBOSE(cdev, NETIF_MSG_INTR,
"hwfn [%d] <--[init]-- SB %04x [0x%04x upper]\n", "hwfn [%d] <--[init]-- SB %04x [0x%04x upper]\n",
hwfn_index, rel_sb_id, sb_id); IS_LEAD_HWFN(p_hwfn) ? 0 : 1, rel_sb_id, sb_id);
rc = qed_int_sb_release(p_hwfn, sb_info, rel_sb_id); rc = qed_int_sb_release(p_hwfn, sb_info, rel_sb_id);
...@@ -2372,6 +2373,11 @@ static int qed_read_module_eeprom(struct qed_dev *cdev, char *buf, ...@@ -2372,6 +2373,11 @@ static int qed_read_module_eeprom(struct qed_dev *cdev, char *buf,
return rc; return rc;
} }
static u8 qed_get_affin_hwfn_idx(struct qed_dev *cdev)
{
return QED_AFFIN_HWFN_IDX(cdev);
}
static struct qed_selftest_ops qed_selftest_ops_pass = { static struct qed_selftest_ops qed_selftest_ops_pass = {
.selftest_memory = &qed_selftest_memory, .selftest_memory = &qed_selftest_memory,
.selftest_interrupt = &qed_selftest_interrupt, .selftest_interrupt = &qed_selftest_interrupt,
...@@ -2419,6 +2425,7 @@ const struct qed_common_ops qed_common_ops_pass = { ...@@ -2419,6 +2425,7 @@ const struct qed_common_ops qed_common_ops_pass = {
.db_recovery_add = &qed_db_recovery_add, .db_recovery_add = &qed_db_recovery_add,
.db_recovery_del = &qed_db_recovery_del, .db_recovery_del = &qed_db_recovery_del,
.read_module_eeprom = &qed_read_module_eeprom, .read_module_eeprom = &qed_read_module_eeprom,
.get_affin_hwfn_idx = &qed_get_affin_hwfn_idx,
}; };
void qed_get_protocol_stats(struct qed_dev *cdev, void qed_get_protocol_stats(struct qed_dev *cdev,
......
...@@ -1306,7 +1306,8 @@ static void qede_free_mem_sb(struct qede_dev *edev, struct qed_sb_info *sb_info, ...@@ -1306,7 +1306,8 @@ static void qede_free_mem_sb(struct qede_dev *edev, struct qed_sb_info *sb_info,
u16 sb_id) u16 sb_id)
{ {
if (sb_info->sb_virt) { if (sb_info->sb_virt) {
edev->ops->common->sb_release(edev->cdev, sb_info, sb_id); edev->ops->common->sb_release(edev->cdev, sb_info, sb_id,
QED_SB_TYPE_L2_QUEUE);
dma_free_coherent(&edev->pdev->dev, sizeof(*sb_info->sb_virt), dma_free_coherent(&edev->pdev->dev, sizeof(*sb_info->sb_virt),
(void *)sb_info->sb_virt, sb_info->sb_phys); (void *)sb_info->sb_virt, sb_info->sb_phys);
memset(sb_info, 0, sizeof(*sb_info)); memset(sb_info, 0, sizeof(*sb_info));
......
...@@ -907,7 +907,8 @@ struct qed_common_ops { ...@@ -907,7 +907,8 @@ struct qed_common_ops {
u32 (*sb_release)(struct qed_dev *cdev, u32 (*sb_release)(struct qed_dev *cdev,
struct qed_sb_info *sb_info, struct qed_sb_info *sb_info,
u16 sb_id); u16 sb_id,
enum qed_sb_type type);
void (*simd_handler_config)(struct qed_dev *cdev, void (*simd_handler_config)(struct qed_dev *cdev,
void *token, void *token,
...@@ -1123,6 +1124,13 @@ struct qed_common_ops { ...@@ -1123,6 +1124,13 @@ struct qed_common_ops {
*/ */
int (*read_module_eeprom)(struct qed_dev *cdev, int (*read_module_eeprom)(struct qed_dev *cdev,
char *buf, u8 dev_addr, u32 offset, u32 len); char *buf, u8 dev_addr, u32 offset, u32 len);
/**
* @brief get_affin_hwfn_idx
*
* @param cdev
*/
u8 (*get_affin_hwfn_idx)(struct qed_dev *cdev);
}; };
#define MASK_FIELD(_name, _value) \ #define MASK_FIELD(_name, _value) \
......
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