提交 6195c71d 编写于 作者: D Divy Le Ray 提交者: Jeff Garzik

cxgb3 - remove SW Tx credits coalescing

Remove tx credit coalescing done in SW.
The HW is caring care of it already.
Signed-off-by: NDivy Le Ray <divy@chelsio.com>
Signed-off-by: NJeff Garzik <jeff@garzik.org>
上级 14ab9892
...@@ -1549,33 +1549,6 @@ static inline int rx_offload(struct t3cdev *tdev, struct sge_rspq *rq, ...@@ -1549,33 +1549,6 @@ static inline int rx_offload(struct t3cdev *tdev, struct sge_rspq *rq,
return gather_idx; return gather_idx;
} }
/**
* update_tx_completed - update the number of processed Tx descriptors
* @qs: the queue set to update
* @idx: which Tx queue within the set to update
* @credits: number of new processed descriptors
* @tx_completed: accumulates credits for the queues
*
* Updates the number of completed Tx descriptors for a queue set's Tx
* queue. On UP systems we updated the information immediately but on
* MP we accumulate the credits locally and update the Tx queue when we
* reach a threshold to avoid cache-line bouncing.
*/
static inline void update_tx_completed(struct sge_qset *qs, int idx,
unsigned int credits,
unsigned int tx_completed[])
{
#ifdef CONFIG_SMP
tx_completed[idx] += credits;
if (tx_completed[idx] > 32) {
qs->txq[idx].processed += tx_completed[idx];
tx_completed[idx] = 0;
}
#else
qs->txq[idx].processed += credits;
#endif
}
/** /**
* restart_tx - check whether to restart suspended Tx queues * restart_tx - check whether to restart suspended Tx queues
* @qs: the queue set to resume * @qs: the queue set to resume
...@@ -1656,13 +1629,12 @@ static void rx_eth(struct adapter *adap, struct sge_rspq *rq, ...@@ -1656,13 +1629,12 @@ static void rx_eth(struct adapter *adap, struct sge_rspq *rq,
* handle_rsp_cntrl_info - handles control information in a response * handle_rsp_cntrl_info - handles control information in a response
* @qs: the queue set corresponding to the response * @qs: the queue set corresponding to the response
* @flags: the response control flags * @flags: the response control flags
* @tx_completed: accumulates completion credits for the Tx queues
* *
* Handles the control information of an SGE response, such as GTS * Handles the control information of an SGE response, such as GTS
* indications and completion credits for the queue set's Tx queues. * indications and completion credits for the queue set's Tx queues.
* HW coalesces credits, we don't do any extra SW coalescing.
*/ */
static inline void handle_rsp_cntrl_info(struct sge_qset *qs, u32 flags, static inline void handle_rsp_cntrl_info(struct sge_qset *qs, u32 flags)
unsigned int tx_completed[])
{ {
unsigned int credits; unsigned int credits;
...@@ -1671,37 +1643,21 @@ static inline void handle_rsp_cntrl_info(struct sge_qset *qs, u32 flags, ...@@ -1671,37 +1643,21 @@ static inline void handle_rsp_cntrl_info(struct sge_qset *qs, u32 flags,
clear_bit(TXQ_RUNNING, &qs->txq[TXQ_ETH].flags); clear_bit(TXQ_RUNNING, &qs->txq[TXQ_ETH].flags);
#endif #endif
/* ETH credits are already coalesced, return them immediately. */
credits = G_RSPD_TXQ0_CR(flags); credits = G_RSPD_TXQ0_CR(flags);
if (credits) if (credits)
qs->txq[TXQ_ETH].processed += credits; qs->txq[TXQ_ETH].processed += credits;
credits = G_RSPD_TXQ2_CR(flags);
if (credits)
qs->txq[TXQ_CTRL].processed += credits;
# if USE_GTS # if USE_GTS
if (flags & F_RSPD_TXQ1_GTS) if (flags & F_RSPD_TXQ1_GTS)
clear_bit(TXQ_RUNNING, &qs->txq[TXQ_OFLD].flags); clear_bit(TXQ_RUNNING, &qs->txq[TXQ_OFLD].flags);
# endif # endif
update_tx_completed(qs, TXQ_OFLD, G_RSPD_TXQ1_CR(flags), tx_completed); credits = G_RSPD_TXQ1_CR(flags);
update_tx_completed(qs, TXQ_CTRL, G_RSPD_TXQ2_CR(flags), tx_completed); if (credits)
} qs->txq[TXQ_OFLD].processed += credits;
/**
* flush_tx_completed - returns accumulated Tx completions to Tx queues
* @qs: the queue set to update
* @tx_completed: pending completion credits to return to Tx queues
*
* Updates the number of completed Tx descriptors for a queue set's Tx
* queues with the credits pending in @tx_completed. This does something
* only on MP systems as on UP systems we return the credits immediately.
*/
static inline void flush_tx_completed(struct sge_qset *qs,
unsigned int tx_completed[])
{
#if defined(CONFIG_SMP)
if (tx_completed[TXQ_OFLD])
qs->txq[TXQ_OFLD].processed += tx_completed[TXQ_OFLD];
if (tx_completed[TXQ_CTRL])
qs->txq[TXQ_CTRL].processed += tx_completed[TXQ_CTRL];
#endif
} }
/** /**
...@@ -1784,7 +1740,7 @@ static int process_responses(struct adapter *adap, struct sge_qset *qs, ...@@ -1784,7 +1740,7 @@ static int process_responses(struct adapter *adap, struct sge_qset *qs,
struct sge_rspq *q = &qs->rspq; struct sge_rspq *q = &qs->rspq;
struct rsp_desc *r = &q->desc[q->cidx]; struct rsp_desc *r = &q->desc[q->cidx];
int budget_left = budget; int budget_left = budget;
unsigned int sleeping = 0, tx_completed[3] = { 0, 0, 0 }; unsigned int sleeping = 0;
struct sk_buff *offload_skbs[RX_BUNDLE_SIZE]; struct sk_buff *offload_skbs[RX_BUNDLE_SIZE];
int ngathered = 0; int ngathered = 0;
...@@ -1837,7 +1793,7 @@ static int process_responses(struct adapter *adap, struct sge_qset *qs, ...@@ -1837,7 +1793,7 @@ static int process_responses(struct adapter *adap, struct sge_qset *qs,
if (flags & RSPD_CTRL_MASK) { if (flags & RSPD_CTRL_MASK) {
sleeping |= flags & RSPD_GTS_MASK; sleeping |= flags & RSPD_GTS_MASK;
handle_rsp_cntrl_info(qs, flags, tx_completed); handle_rsp_cntrl_info(qs, flags);
} }
r++; r++;
...@@ -1868,7 +1824,6 @@ static int process_responses(struct adapter *adap, struct sge_qset *qs, ...@@ -1868,7 +1824,6 @@ static int process_responses(struct adapter *adap, struct sge_qset *qs,
--budget_left; --budget_left;
} }
flush_tx_completed(qs, tx_completed);
deliver_partial_bundle(&adap->tdev, q, offload_skbs, ngathered); deliver_partial_bundle(&adap->tdev, q, offload_skbs, ngathered);
if (sleeping) if (sleeping)
check_ring_db(adap, qs, sleeping); check_ring_db(adap, qs, sleeping);
...@@ -1953,7 +1908,7 @@ static int process_pure_responses(struct adapter *adap, struct sge_qset *qs, ...@@ -1953,7 +1908,7 @@ static int process_pure_responses(struct adapter *adap, struct sge_qset *qs,
struct rsp_desc *r) struct rsp_desc *r)
{ {
struct sge_rspq *q = &qs->rspq; struct sge_rspq *q = &qs->rspq;
unsigned int sleeping = 0, tx_completed[3] = { 0, 0, 0 }; unsigned int sleeping = 0;
do { do {
u32 flags = ntohl(r->flags); u32 flags = ntohl(r->flags);
...@@ -1968,7 +1923,7 @@ static int process_pure_responses(struct adapter *adap, struct sge_qset *qs, ...@@ -1968,7 +1923,7 @@ static int process_pure_responses(struct adapter *adap, struct sge_qset *qs,
if (flags & RSPD_CTRL_MASK) { if (flags & RSPD_CTRL_MASK) {
sleeping |= flags & RSPD_GTS_MASK; sleeping |= flags & RSPD_GTS_MASK;
handle_rsp_cntrl_info(qs, flags, tx_completed); handle_rsp_cntrl_info(qs, flags);
} }
q->pure_rsps++; q->pure_rsps++;
...@@ -1978,8 +1933,6 @@ static int process_pure_responses(struct adapter *adap, struct sge_qset *qs, ...@@ -1978,8 +1933,6 @@ static int process_pure_responses(struct adapter *adap, struct sge_qset *qs,
} }
} while (is_new_response(r, q) && is_pure_response(r)); } while (is_new_response(r, q) && is_pure_response(r));
flush_tx_completed(qs, tx_completed);
if (sleeping) if (sleeping)
check_ring_db(adap, qs, sleeping); check_ring_db(adap, qs, sleeping);
...@@ -2630,7 +2583,7 @@ void t3_sge_init(struct adapter *adap, struct sge_params *p) ...@@ -2630,7 +2583,7 @@ void t3_sge_init(struct adapter *adap, struct sge_params *p)
V_LORCQDRBTHRSH(512)); V_LORCQDRBTHRSH(512));
t3_write_reg(adap, A_SG_TIMER_TICK, core_ticks_per_usec(adap) / 10); t3_write_reg(adap, A_SG_TIMER_TICK, core_ticks_per_usec(adap) / 10);
t3_write_reg(adap, A_SG_CMDQ_CREDIT_TH, V_THRESHOLD(32) | t3_write_reg(adap, A_SG_CMDQ_CREDIT_TH, V_THRESHOLD(32) |
V_TIMEOUT(100 * core_ticks_per_usec(adap))); V_TIMEOUT(200 * core_ticks_per_usec(adap)));
t3_write_reg(adap, A_SG_HI_DRB_HI_THRSH, 1000); t3_write_reg(adap, A_SG_HI_DRB_HI_THRSH, 1000);
t3_write_reg(adap, A_SG_HI_DRB_LO_THRSH, 256); t3_write_reg(adap, A_SG_HI_DRB_LO_THRSH, 256);
t3_write_reg(adap, A_SG_LO_DRB_HI_THRSH, 1000); t3_write_reg(adap, A_SG_LO_DRB_HI_THRSH, 1000);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册