summaryrefslogtreecommitdiffstats
path: root/drivers/bus
diff options
context:
space:
mode:
authorManivannan Sadhasivam <manivannan.sadhasivam@linaro.org>2021-01-27 12:15:59 +0100
committerManivannan Sadhasivam <manivannan.sadhasivam@linaro.org>2021-01-27 12:15:59 +0100
commit77f2cb28ae5219decf9067e62907d3ecee839779 (patch)
treee833eb95fa6ed756110cdba5831613af22e01061 /drivers/bus
parentmhi: core: Factorize mhi queuing (diff)
parentbus: mhi: core: Add helper API to return number of free TREs (diff)
downloadlinux-77f2cb28ae5219decf9067e62907d3ecee839779.tar.xz
linux-77f2cb28ae5219decf9067e62907d3ecee839779.zip
Merge branch 'mhi-net-immutable' into mhi-next
Diffstat (limited to 'drivers/bus')
-rw-r--r--drivers/bus/mhi/core/main.c12
1 files changed, 12 insertions, 0 deletions
diff --git a/drivers/bus/mhi/core/main.c b/drivers/bus/mhi/core/main.c
index b67c25491069..4e0131b94056 100644
--- a/drivers/bus/mhi/core/main.c
+++ b/drivers/bus/mhi/core/main.c
@@ -280,6 +280,18 @@ int mhi_destroy_device(struct device *dev, void *data)
return 0;
}
+int mhi_get_free_desc_count(struct mhi_device *mhi_dev,
+ enum dma_data_direction dir)
+{
+ struct mhi_controller *mhi_cntrl = mhi_dev->mhi_cntrl;
+ struct mhi_chan *mhi_chan = (dir == DMA_TO_DEVICE) ?
+ mhi_dev->ul_chan : mhi_dev->dl_chan;
+ struct mhi_ring *tre_ring = &mhi_chan->tre_ring;
+
+ return get_nr_avail_ring_elements(mhi_cntrl, tre_ring);
+}
+EXPORT_SYMBOL_GPL(mhi_get_free_desc_count);
+
void mhi_notify(struct mhi_device *mhi_dev, enum mhi_callback cb_reason)
{
struct mhi_driver *mhi_drv;