Lines Matching refs:sdio

37 	struct mt76_sdio *sdio = &dev->sdio;  in mt76s_refill_sched_quota()  local
48 sdio->sched.pse_mcu_quota += pse_mcu_quota; in mt76s_refill_sched_quota()
49 sdio->sched.pse_data_quota += pse_data_quota; in mt76s_refill_sched_quota()
50 sdio->sched.ple_data_quota += ple_data_quota; in mt76s_refill_sched_quota()
85 struct mt76_sdio *sdio = &dev->sdio; in mt76s_rx_run_queue() local
96 if (len > sdio->func->cur_blksize) in mt76s_rx_run_queue()
97 len = roundup(len, sdio->func->cur_blksize); in mt76s_rx_run_queue()
105 err = sdio_readsb(sdio->func, buf, MCR_WRDR(qid), len); in mt76s_rx_run_queue()
139 struct mt76_sdio *sdio = &dev->sdio; in mt76s_rx_handler() local
143 ret = sdio->parse_irq(dev, &intr); in mt76s_rx_handler()
152 mt76_worker_schedule(&sdio->net_worker); in mt76s_rx_handler()
160 mt76_worker_schedule(&sdio->net_worker); in mt76s_rx_handler()
171 mt76s_tx_pick_quota(struct mt76_sdio *sdio, bool mcu, int buf_sz, in mt76s_tx_pick_quota() argument
176 pse_sz = DIV_ROUND_UP(buf_sz + sdio->sched.deficit, in mt76s_tx_pick_quota()
177 sdio->sched.pse_page_size); in mt76s_tx_pick_quota()
179 if (mcu && sdio->hw_ver == MT76_CONNAC2_SDIO) in mt76s_tx_pick_quota()
183 if (sdio->sched.pse_mcu_quota < *pse_size + pse_sz) in mt76s_tx_pick_quota()
186 if (sdio->sched.pse_data_quota < *pse_size + pse_sz || in mt76s_tx_pick_quota()
187 sdio->sched.ple_data_quota < *ple_size + 1) in mt76s_tx_pick_quota()
198 mt76s_tx_update_quota(struct mt76_sdio *sdio, bool mcu, int pse_size, in mt76s_tx_update_quota() argument
202 sdio->sched.pse_mcu_quota -= pse_size; in mt76s_tx_update_quota()
204 sdio->sched.pse_data_quota -= pse_size; in mt76s_tx_update_quota()
205 sdio->sched.ple_data_quota -= ple_size; in mt76s_tx_update_quota()
211 struct mt76_sdio *sdio = &dev->sdio; in __mt76s_xmit_queue() local
214 if (len > sdio->func->cur_blksize) in __mt76s_xmit_queue()
215 len = roundup(len, sdio->func->cur_blksize); in __mt76s_xmit_queue()
217 err = sdio_writesb(sdio->func, MCR_WTDR1, data, len); in __mt76s_xmit_queue()
228 struct mt76_sdio *sdio = &dev->sdio; in mt76s_tx_run_queue() local
231 qid = mcu ? ARRAY_SIZE(sdio->xmit_buf) - 1 : q->qid; in mt76s_tx_run_queue()
255 if (mt76s_tx_pick_quota(sdio, mcu, e->buf_sz, &pse_sz, in mt76s_tx_run_queue()
259 memcpy(sdio->xmit_buf[qid] + len, e->skb->data, in mt76s_tx_run_queue()
265 memcpy(sdio->xmit_buf[qid] + len, iter->data, in mt76s_tx_run_queue()
272 memset(sdio->xmit_buf[qid] + len, 0, pad); in mt76s_tx_run_queue()
281 memset(sdio->xmit_buf[qid] + len, 0, 4); in mt76s_tx_run_queue()
282 err = __mt76s_xmit_queue(dev, sdio->xmit_buf[qid], len + 4); in mt76s_tx_run_queue()
286 mt76s_tx_update_quota(sdio, mcu, pse_sz, ple_sz); in mt76s_tx_run_queue()
288 mt76_worker_schedule(&sdio->status_worker); in mt76s_tx_run_queue()
293 void mt76s_txrx_worker(struct mt76_sdio *sdio) in mt76s_txrx_worker() argument
295 struct mt76_dev *dev = container_of(sdio, struct mt76_dev, sdio); in mt76s_txrx_worker()
299 sdio_claim_host(sdio->func); in mt76s_txrx_worker()
300 sdio_writel(sdio->func, WHLPCR_INT_EN_CLR, MCR_WHLPCR, NULL); in mt76s_txrx_worker()
324 wake_up(&sdio->wait); in mt76s_txrx_worker()
329 sdio_writel(sdio->func, WHLPCR_INT_EN_SET, MCR_WHLPCR, NULL); in mt76s_txrx_worker()
330 sdio_release_host(sdio->func); in mt76s_txrx_worker()
337 struct mt76_sdio *sdio = &dev->sdio; in mt76s_sdio_irq() local
343 mt76_worker_schedule(&sdio->txrx_worker); in mt76s_sdio_irq()