Commit 10b8e0fd authored by Amelie Delaunay's avatar Amelie Delaunay Committed by Vinod Koul

dmaengine: add channel device name to channel registration

Channel device name is used for sysfs, but also by dmatest filter function.

With dynamic channel registration, channels can be registered after dma
controller registration. Users may want to have specific channel names.

If name is NULL, the channel name relies on previous implementation,
dma<controller_device_id>chan<channel_device_id>.
Signed-off-by: default avatarAmelie Delaunay <amelie.delaunay@foss.st.com>
Link: https://lore.kernel.org/r/20240531150712.2503554-11-amelie.delaunay@foss.st.comSigned-off-by: default avatarVinod Koul <vkoul@kernel.org>
parent 20884738
...@@ -1037,7 +1037,8 @@ static int get_dma_id(struct dma_device *device) ...@@ -1037,7 +1037,8 @@ static int get_dma_id(struct dma_device *device)
} }
static int __dma_async_device_channel_register(struct dma_device *device, static int __dma_async_device_channel_register(struct dma_device *device,
struct dma_chan *chan) struct dma_chan *chan,
const char *name)
{ {
int rc; int rc;
...@@ -1066,8 +1067,10 @@ static int __dma_async_device_channel_register(struct dma_device *device, ...@@ -1066,8 +1067,10 @@ static int __dma_async_device_channel_register(struct dma_device *device,
chan->dev->device.parent = device->dev; chan->dev->device.parent = device->dev;
chan->dev->chan = chan; chan->dev->chan = chan;
chan->dev->dev_id = device->dev_id; chan->dev->dev_id = device->dev_id;
dev_set_name(&chan->dev->device, "dma%dchan%d", if (!name)
device->dev_id, chan->chan_id); dev_set_name(&chan->dev->device, "dma%dchan%d", device->dev_id, chan->chan_id);
else
dev_set_name(&chan->dev->device, name);
rc = device_register(&chan->dev->device); rc = device_register(&chan->dev->device);
if (rc) if (rc)
goto err_out_ida; goto err_out_ida;
...@@ -1087,11 +1090,12 @@ static int __dma_async_device_channel_register(struct dma_device *device, ...@@ -1087,11 +1090,12 @@ static int __dma_async_device_channel_register(struct dma_device *device,
} }
int dma_async_device_channel_register(struct dma_device *device, int dma_async_device_channel_register(struct dma_device *device,
struct dma_chan *chan) struct dma_chan *chan,
const char *name)
{ {
int rc; int rc;
rc = __dma_async_device_channel_register(device, chan); rc = __dma_async_device_channel_register(device, chan, name);
if (rc < 0) if (rc < 0)
return rc; return rc;
...@@ -1203,7 +1207,7 @@ int dma_async_device_register(struct dma_device *device) ...@@ -1203,7 +1207,7 @@ int dma_async_device_register(struct dma_device *device)
/* represent channels in sysfs. Probably want devs too */ /* represent channels in sysfs. Probably want devs too */
list_for_each_entry(chan, &device->channels, device_node) { list_for_each_entry(chan, &device->channels, device_node) {
rc = __dma_async_device_channel_register(device, chan); rc = __dma_async_device_channel_register(device, chan, NULL);
if (rc < 0) if (rc < 0)
goto err_out; goto err_out;
} }
......
...@@ -269,7 +269,7 @@ static int idxd_register_dma_channel(struct idxd_wq *wq) ...@@ -269,7 +269,7 @@ static int idxd_register_dma_channel(struct idxd_wq *wq)
desc->txd.tx_submit = idxd_dma_tx_submit; desc->txd.tx_submit = idxd_dma_tx_submit;
} }
rc = dma_async_device_channel_register(dma, chan); rc = dma_async_device_channel_register(dma, chan, NULL);
if (rc < 0) { if (rc < 0) {
kfree(idxd_chan); kfree(idxd_chan);
return rc; return rc;
......
...@@ -1575,7 +1575,8 @@ int dma_async_device_register(struct dma_device *device); ...@@ -1575,7 +1575,8 @@ int dma_async_device_register(struct dma_device *device);
int dmaenginem_async_device_register(struct dma_device *device); int dmaenginem_async_device_register(struct dma_device *device);
void dma_async_device_unregister(struct dma_device *device); void dma_async_device_unregister(struct dma_device *device);
int dma_async_device_channel_register(struct dma_device *device, int dma_async_device_channel_register(struct dma_device *device,
struct dma_chan *chan); struct dma_chan *chan,
const char *name);
void dma_async_device_channel_unregister(struct dma_device *device, void dma_async_device_channel_unregister(struct dma_device *device,
struct dma_chan *chan); struct dma_chan *chan);
void dma_run_dependencies(struct dma_async_tx_descriptor *tx); void dma_run_dependencies(struct dma_async_tx_descriptor *tx);
......
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