TXQ_CTRL
qs->txq[TXQ_CTRL].cntxt_id = FW_CTRL_SGEEC_START + id;
qs->txq[TXQ_CTRL].token = FW_CTRL_TID_START + id;
mbufq_init(&qs->txq[TXQ_CTRL].sendq, INT_MAX);
struct sge_txq *q = &qs->txq[TXQ_CTRL];
ret = check_desc_avail(adap, q, m, 1, TXQ_CTRL);
struct sge_txq *q = &qs->txq[TXQ_CTRL];
setbit(&qs->txq_stopped, TXQ_CTRL);
test_and_clear_bit(TXQ_CTRL, &qs->txq_stopped))
if (isset(&qs->txq_stopped, TXQ_CTRL) &&
should_restart_tx(&qs->txq[TXQ_CTRL]) &&
test_and_clear_bit(TXQ_CTRL, &qs->txq_stopped)) {
qs->txq[TXQ_CTRL].restarts++;
taskqueue_enqueue(sc->tq, &qs->txq[TXQ_CTRL].qresume_task);
size_t sz = i == TXQ_CTRL ? 0 : sizeof(struct tx_sw_desc);
TASK_INIT(&q->txq[TXQ_CTRL].qresume_task, 0, restart_ctrlq, q);
ret = -t3_sge_init_ecntxt(sc, q->txq[TXQ_CTRL].cntxt_id, 0,
q->txq[TXQ_CTRL].phys_addr,
q->txq[TXQ_CTRL].size,
q->txq[TXQ_CTRL].token, 1, 0);
qs->txq[TXQ_CTRL].processed += credits;
qs = txq_to_qset(txq, TXQ_CTRL);
CTLFLAG_RW, &qs->txq[TXQ_CTRL].txq_dump_start,
CTLFLAG_RW, &qs->txq[TXQ_CTRL].txq_dump_count,
&qs->txq[TXQ_CTRL], 0, t3_dump_txq_ctrl, "A",
q->txq_size[TXQ_CTRL] = TX_CTRL_Q_SIZE;