Commit a2a93548 authored by Lorenzo Bianconi's avatar Lorenzo Bianconi Committed by Felix Fietkau

mt76: sdio: introduce mt76s_alloc_tx_queue

This is a preliminary patch to move hw data queues in mt76_phy for
mt7915 dbdc support
Signed-off-by: default avatarLorenzo Bianconi <lorenzo@kernel.org>
Signed-off-by: default avatarFelix Fietkau <nbd@nbd.name>
parent b671da33
...@@ -36,28 +36,46 @@ mt76s_alloc_rx_queue(struct mt76_dev *dev, enum mt76_rxq_id qid) ...@@ -36,28 +36,46 @@ mt76s_alloc_rx_queue(struct mt76_dev *dev, enum mt76_rxq_id qid)
return 0; return 0;
} }
static struct mt76_queue *mt76s_alloc_tx_queue(struct mt76_dev *dev)
{
struct mt76_queue *q;
q = devm_kzalloc(dev->dev, sizeof(*q), GFP_KERNEL);
if (!q)
return ERR_PTR(-ENOMEM);
spin_lock_init(&q->lock);
q->entry = devm_kcalloc(dev->dev,
MT_NUM_TX_ENTRIES, sizeof(*q->entry),
GFP_KERNEL);
if (!q->entry)
return ERR_PTR(-ENOMEM);
q->ndesc = MT_NUM_TX_ENTRIES;
return q;
}
static int mt76s_alloc_tx(struct mt76_dev *dev) static int mt76s_alloc_tx(struct mt76_dev *dev)
{ {
struct mt76_queue *q; struct mt76_queue *q;
int i; int i;
for (i = 0; i < MT_TXQ_MCU_WA; i++) { for (i = 0; i <= MT_TXQ_PSD; i++) {
q = devm_kzalloc(dev->dev, sizeof(*q), GFP_KERNEL); q = mt76s_alloc_tx_queue(dev);
if (!q) if (IS_ERR(q))
return -ENOMEM; return PTR_ERR(q);
spin_lock_init(&q->lock); q->qid = i;
q->hw_idx = i;
dev->q_tx[i] = q; dev->q_tx[i] = q;
}
q->entry = devm_kcalloc(dev->dev, q = mt76s_alloc_tx_queue(dev);
MT_NUM_TX_ENTRIES, sizeof(*q->entry), if (IS_ERR(q))
GFP_KERNEL); return PTR_ERR(q);
if (!q->entry)
return -ENOMEM;
q->ndesc = MT_NUM_TX_ENTRIES; q->qid = MT_TXQ_MCU;
} dev->q_tx[MT_TXQ_MCU] = q;
return 0; return 0;
} }
......
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