Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net
Several cases of overlapping changes, except the packet scheduler conflicts which deal with the addition of the free list parameter to qdisc_enqueue(). Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
@@ -72,6 +72,7 @@ int qed_sp_eth_vport_start(struct qed_hwfn *p_hwfn,
|
||||
p_ramrod->mtu = cpu_to_le16(p_params->mtu);
|
||||
p_ramrod->inner_vlan_removal_en = p_params->remove_inner_vlan;
|
||||
p_ramrod->drop_ttl0_en = p_params->drop_ttl0;
|
||||
p_ramrod->untagged = p_params->only_untagged;
|
||||
|
||||
SET_FIELD(rx_mode, ETH_VPORT_RX_MODE_UCAST_DROP_ALL, 1);
|
||||
SET_FIELD(rx_mode, ETH_VPORT_RX_MODE_MCAST_DROP_ALL, 1);
|
||||
@@ -247,10 +248,6 @@ qed_sp_update_accept_mode(struct qed_hwfn *p_hwfn,
|
||||
SET_FIELD(state, ETH_VPORT_TX_MODE_UCAST_DROP_ALL,
|
||||
!!(accept_filter & QED_ACCEPT_NONE));
|
||||
|
||||
SET_FIELD(state, ETH_VPORT_TX_MODE_UCAST_ACCEPT_ALL,
|
||||
(!!(accept_filter & QED_ACCEPT_UCAST_MATCHED) &&
|
||||
!!(accept_filter & QED_ACCEPT_UCAST_UNMATCHED)));
|
||||
|
||||
SET_FIELD(state, ETH_VPORT_TX_MODE_MCAST_DROP_ALL,
|
||||
!!(accept_filter & QED_ACCEPT_NONE));
|
||||
|
||||
@@ -1756,7 +1753,8 @@ static int qed_start_vport(struct qed_dev *cdev,
|
||||
start.vport_id, start.mtu);
|
||||
}
|
||||
|
||||
qed_reset_vport_stats(cdev);
|
||||
if (params->clear_stats)
|
||||
qed_reset_vport_stats(cdev);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
@@ -1088,6 +1088,7 @@ static int qed_get_port_type(u32 media_type)
|
||||
case MEDIA_SFPP_10G_FIBER:
|
||||
case MEDIA_SFP_1G_FIBER:
|
||||
case MEDIA_XFP_FIBER:
|
||||
case MEDIA_MODULE_FIBER:
|
||||
case MEDIA_KR:
|
||||
port_type = PORT_FIBRE;
|
||||
break;
|
||||
|
@@ -213,19 +213,15 @@ static int qed_spq_hw_post(struct qed_hwfn *p_hwfn,
|
||||
SET_FIELD(db.params, CORE_DB_DATA_AGG_VAL_SEL,
|
||||
DQ_XCM_CORE_SPQ_PROD_CMD);
|
||||
db.agg_flags = DQ_XCM_CORE_DQ_CF_CMD;
|
||||
|
||||
/* validate producer is up to-date */
|
||||
rmb();
|
||||
|
||||
db.spq_prod = cpu_to_le16(qed_chain_get_prod_idx(p_chain));
|
||||
|
||||
/* do not reorder */
|
||||
barrier();
|
||||
/* make sure the SPQE is updated before the doorbell */
|
||||
wmb();
|
||||
|
||||
DOORBELL(p_hwfn, qed_db_addr(p_spq->cid, DQ_DEMS_LEGACY), *(u32 *)&db);
|
||||
|
||||
/* make sure doorbell is rang */
|
||||
mmiowb();
|
||||
wmb();
|
||||
|
||||
DP_VERBOSE(p_hwfn, QED_MSG_SPQ,
|
||||
"Doorbelled [0x%08x, CID 0x%08x] with Flags: %02x agg_params: %02x, prod: %04x\n",
|
||||
@@ -620,7 +616,9 @@ qed_spq_add_entry(struct qed_hwfn *p_hwfn,
|
||||
|
||||
*p_en2 = *p_ent;
|
||||
|
||||
kfree(p_ent);
|
||||
/* EBLOCK responsible to free the allocated p_ent */
|
||||
if (p_ent->comp_mode != QED_SPQ_MODE_EBLOCK)
|
||||
kfree(p_ent);
|
||||
|
||||
p_ent = p_en2;
|
||||
}
|
||||
@@ -755,6 +753,15 @@ int qed_spq_post(struct qed_hwfn *p_hwfn,
|
||||
* Thus, after gaining the answer perform the cleanup here.
|
||||
*/
|
||||
rc = qed_spq_block(p_hwfn, p_ent, fw_return_code);
|
||||
|
||||
if (p_ent->queue == &p_spq->unlimited_pending) {
|
||||
/* This is an allocated p_ent which does not need to
|
||||
* return to pool.
|
||||
*/
|
||||
kfree(p_ent);
|
||||
return rc;
|
||||
}
|
||||
|
||||
if (rc)
|
||||
goto spq_post_fail2;
|
||||
|
||||
@@ -850,8 +857,12 @@ int qed_spq_completion(struct qed_hwfn *p_hwfn,
|
||||
found->comp_cb.function(p_hwfn, found->comp_cb.cookie, p_data,
|
||||
fw_return_code);
|
||||
|
||||
if (found->comp_mode != QED_SPQ_MODE_EBLOCK)
|
||||
/* EBLOCK is responsible for freeing its own entry */
|
||||
if ((found->comp_mode != QED_SPQ_MODE_EBLOCK) ||
|
||||
(found->queue == &p_spq->unlimited_pending))
|
||||
/* EBLOCK is responsible for returning its own entry into the
|
||||
* free list, unless it originally added the entry into the
|
||||
* unlimited pending list.
|
||||
*/
|
||||
qed_spq_return_entry(p_hwfn, found);
|
||||
|
||||
/* Attempt to post pending requests */
|
||||
|
@@ -3222,7 +3222,7 @@ static int qede_stop_queues(struct qede_dev *edev)
|
||||
return rc;
|
||||
}
|
||||
|
||||
static int qede_start_queues(struct qede_dev *edev)
|
||||
static int qede_start_queues(struct qede_dev *edev, bool clear_stats)
|
||||
{
|
||||
int rc, tc, i;
|
||||
int vlan_removal_en = 1;
|
||||
@@ -3453,6 +3453,7 @@ out:
|
||||
|
||||
enum qede_load_mode {
|
||||
QEDE_LOAD_NORMAL,
|
||||
QEDE_LOAD_RELOAD,
|
||||
};
|
||||
|
||||
static int qede_load(struct qede_dev *edev, enum qede_load_mode mode)
|
||||
@@ -3491,7 +3492,7 @@ static int qede_load(struct qede_dev *edev, enum qede_load_mode mode)
|
||||
goto err3;
|
||||
DP_INFO(edev, "Setup IRQs succeeded\n");
|
||||
|
||||
rc = qede_start_queues(edev);
|
||||
rc = qede_start_queues(edev, mode != QEDE_LOAD_RELOAD);
|
||||
if (rc)
|
||||
goto err4;
|
||||
DP_INFO(edev, "Start VPORT, RXQ and TXQ succeeded\n");
|
||||
@@ -3546,7 +3547,7 @@ void qede_reload(struct qede_dev *edev,
|
||||
if (func)
|
||||
func(edev, args);
|
||||
|
||||
qede_load(edev, QEDE_LOAD_NORMAL);
|
||||
qede_load(edev, QEDE_LOAD_RELOAD);
|
||||
|
||||
mutex_lock(&edev->qede_lock);
|
||||
qede_config_rx_mode(edev->ndev);
|
||||
|
@@ -2220,7 +2220,7 @@ void qlcnic_83xx_process_rcv_ring_diag(struct qlcnic_host_sds_ring *sds_ring)
|
||||
if (!opcode)
|
||||
return;
|
||||
|
||||
ring = QLCNIC_FETCH_RING_ID(qlcnic_83xx_hndl(sts_data[0]));
|
||||
ring = QLCNIC_FETCH_RING_ID(sts_data[0]);
|
||||
qlcnic_83xx_process_rcv_diag(adapter, ring, sts_data);
|
||||
desc = &sds_ring->desc_head[consumer];
|
||||
desc->status_desc_data[0] = cpu_to_le64(STATUS_OWNER_PHANTOM);
|
||||
|
Reference in New Issue
Block a user