cxgbe(4): Avoid unnecessary work in the firmware during netmap tx.
Bind the netmap tx queues to a special '0xff' scheduling class which makes the firmware skip some processing related to rate limiting on the outgoing traffic. Future firmwares will do this automatically. MFC after: 1 week Sponsored by: Chelsio Communications
This commit is contained in:
parent
7efe256233
commit
822967e7e5
@ -329,6 +329,22 @@ alloc_nm_txq_hwq(struct vi_info *vi, struct sge_nm_txq *nm_txq)
|
||||
nm_txq->udb = (volatile void *)udb;
|
||||
}
|
||||
|
||||
if (sc->params.fw_vers < FW_VERSION32(1, 25, 1, 0)) {
|
||||
uint32_t param, val;
|
||||
|
||||
param = V_FW_PARAMS_MNEM(FW_PARAMS_MNEM_DMAQ) |
|
||||
V_FW_PARAMS_PARAM_X(FW_PARAMS_PARAM_DMAQ_EQ_SCHEDCLASS_ETH) |
|
||||
V_FW_PARAMS_PARAM_YZ(nm_txq->cntxt_id);
|
||||
val = 0xff;
|
||||
rc = -t4_set_params(sc, sc->mbox, sc->pf, 0, 1, ¶m, &val);
|
||||
if (rc != 0) {
|
||||
device_printf(vi->dev,
|
||||
"failed to bind netmap txq %d to class 0xff: %d\n",
|
||||
nm_txq->cntxt_id, rc);
|
||||
rc = 0;
|
||||
}
|
||||
}
|
||||
|
||||
return (rc);
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user