From: Vishnu Reddy <busanna.reddy@oss.qualcomm.com>
To: Dmitry Baryshkov <dmitry.baryshkov@oss.qualcomm.com>
Cc: Bryan O'Donoghue <bod@kernel.org>,
Vikash Garodia <vikash.garodia@oss.qualcomm.com>,
Dikshita Agarwal <dikshita.agarwal@oss.qualcomm.com>,
Abhinav Kumar <abhinav.kumar@linux.dev>,
Mauro Carvalho Chehab <mchehab@kernel.org>,
Rob Herring <robh@kernel.org>,
Krzysztof Kozlowski <krzk+dt@kernel.org>,
Conor Dooley <conor+dt@kernel.org>,
Joerg Roedel <joro@8bytes.org>, Will Deacon <will@kernel.org>,
Robin Murphy <robin.murphy@arm.com>,
Bjorn Andersson <andersson@kernel.org>,
Konrad Dybcio <konradybcio@kernel.org>,
Stefan Schmidt <stefan.schmidt@linaro.org>,
Hans Verkuil <hverkuil@kernel.org>,
linux-media@vger.kernel.org, linux-arm-msm@vger.kernel.org,
devicetree@vger.kernel.org, linux-kernel@vger.kernel.org,
iommu@lists.linux.dev
Subject: Re: [PATCH 04/11] media: iris: Add helper to create a context bank device on iris vpu bus
Date: Wed, 22 Apr 2026 11:49:00 +0530 [thread overview]
Message-ID: <9c76be4a-e907-b5b6-e50f-0f37738752da@oss.qualcomm.com> (raw)
In-Reply-To: <cucl4m3h2wkosvzuyxdwyjec3v5n6vpa5g3osvo5y4farpewtn@jw6kzf3f3eyj>
On 4/20/2026 11:26 PM, Dmitry Baryshkov wrote:
> On Mon, Apr 20, 2026 at 07:33:01PM +0530, Vishnu Reddy wrote:
>> On 4/17/2026 11:53 PM, Dmitry Baryshkov wrote:
>>> On Fri, Apr 17, 2026 at 08:49:44PM +0530, Vishnu Reddy wrote:
>>>> On 4/14/2026 8:48 PM, Dmitry Baryshkov wrote:
>>>>> On Tue, Apr 14, 2026 at 10:30:00AM +0530, Vishnu Reddy wrote:
>>>>>> From: Vikash Garodia<vikash.garodia@oss.qualcomm.com>
>>>>>>
>>>>>> Add a helper function to allocate and register context bank (CB) device
>>>>>> on the iris vpu bus. The function ID associated with the CB is specified
>>>>>> from the platform data, allowing the bus dma_configure callback to apply
>>>>>> correct stream ID mapping when device is registered.
>>>>>>
>>>>>> Signed-off-by: Vikash Garodia<vikash.garodia@oss.qualcomm.com>
>>>>>> Signed-off-by: Vishnu Reddy<busanna.reddy@oss.qualcomm.com>
>>>>>> ---
>>>>>> drivers/media/platform/qcom/iris/iris_resources.c | 33 +++++++++++++++++++++++
>>>>>> drivers/media/platform/qcom/iris/iris_resources.h | 1 +
>>>>>> 2 files changed, 34 insertions(+)
>>>>>>
>>>>>> diff --git a/drivers/media/platform/qcom/iris/iris_resources.c b/drivers/media/platform/qcom/iris/iris_resources.c
>>>>>> index 773f6548370a..a25e0f2e9d26 100644
>>>>>> --- a/drivers/media/platform/qcom/iris/iris_resources.c
>>>>>> +++ b/drivers/media/platform/qcom/iris/iris_resources.c
>>>>>> @@ -6,6 +6,7 @@
>>>>>> #include <linux/clk.h>
>>>>>> #include <linux/devfreq.h>
>>>>>> #include <linux/interconnect.h>
>>>>>> +#include <linux/iris_vpu_bus.h>
>>>>>> #include <linux/pm_domain.h>
>>>>>> #include <linux/pm_opp.h>
>>>>>> #include <linux/pm_runtime.h>
>>>>>> @@ -141,3 +142,35 @@ int iris_disable_unprepare_clock(struct iris_core *core, enum platform_clk_type
>>>>>> return 0;
>>>>>> }
>>>>>> +
>>>>>> +static void iris_release_cb_dev(struct device *dev)
>>>>>> +{
>>>>>> + kfree(dev);
>>>>>> +}
>>>>>> +
>>>>>> +struct device *iris_create_cb_dev(struct iris_core *core, const char *name, const u32 *f_id)
>>>>> Please move into the bus code and make it generic enough.
>>>> Do you suggest to add a wrapper to pass the varying inputs to the generic
>>>> bus, something like this
>>>> struct device* create_and_register_device(dma_mask, parent_dev, *release,
>>>> dev_name,...)
>>> Definitely not the release function. The devname is also not that
>>> important. The rest, yes, you are correct.
>>>
>>>>>> +{
>>>>>> + struct device *dev;
>>>>>> + int ret;
>>>>>> +
>>>>>> + dev = kzalloc_obj(*dev);
>>>>>> + if (!dev)
>>>>>> + return ERR_PTR(-ENOMEM);
>>>>>> +
>>>>>> + dev->release = iris_release_cb_dev;
>>>>>> + dev->bus = &iris_vpu_bus_type;
>>>>>> + dev->parent = core->dev;
>>>>>> + dev->coherent_dma_mask = core->iris_platform_data->dma_mask;
>>>>>> + dev->dma_mask = &dev->coherent_dma_mask;
>>>>> Would you also need to set the of_node? See
>>>>> device_set_of_node_from_dev()
>>>> It might be needed for FastRPC as they are following sub node approach, Iris
>>>> does not need.
>>> Wouldn't it save you from passing it to of_dma_configure_id()?
>> Iris will pass parent device of_node, setting parent device is enough.
> Set the of node and pass NULL to of_dma_configure_id.
Passing of_node as NULL to of_dma_configure_id() won’t map the SID to device,
If a dt sub node exists with iommus, the child’s of_node can be used.
Otherwise, the parent’s of_node must be passed with a valid function ID present
in iommu-map.
>>>>>> +
>>>>>> + dev_set_name(dev, "%s", name);
>>>>>> + dev_set_drvdata(dev, (void *)f_id);
>>>>>> +
>>>>>> + ret = device_register(dev);
>>>>>> + if (ret) {
>>>>>> + put_device(dev);
>>>>>> + return ERR_PTR(ret);
>>>>>> + }
>>>>>> +
>>>>>> + return dev;
>>>>>> +}
>>>>>> diff --git a/drivers/media/platform/qcom/iris/iris_resources.h b/drivers/media/platform/qcom/iris/iris_resources.h
>>>>>> index 6bfbd2dc6db0..4a494627ff23 100644
>>>>>> --- a/drivers/media/platform/qcom/iris/iris_resources.h
>>>>>> +++ b/drivers/media/platform/qcom/iris/iris_resources.h
>>>>>> @@ -15,5 +15,6 @@ int iris_unset_icc_bw(struct iris_core *core);
>>>>>> int iris_set_icc_bw(struct iris_core *core, unsigned long icc_bw);
>>>>>> int iris_disable_unprepare_clock(struct iris_core *core, enum platform_clk_type clk_type);
>>>>>> int iris_prepare_enable_clock(struct iris_core *core, enum platform_clk_type clk_type);
>>>>>> +struct device *iris_create_cb_dev(struct iris_core *core, const char *name, const u32 *f_id);
>>>>>> #endif
>>>>>>
>>>>>> --
>>>>>> 2.34.1
>>>>>>
next prev parent reply other threads:[~2026-04-22 6:19 UTC|newest]
Thread overview: 53+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-04-14 4:59 [PATCH 00/11] media: iris: Add support for glymur platform Vishnu Reddy
2026-04-14 4:59 ` [PATCH 01/11] dt-bindings: media: qcom,glymur-iris: Add glymur video codec Vishnu Reddy
2026-04-14 7:25 ` Krzysztof Kozlowski
2026-04-14 9:46 ` Vishnu Reddy
2026-04-14 4:59 ` [PATCH 02/11] media: iris: Add iris vpu bus support and register it with iommu_buses Vishnu Reddy
2026-04-14 15:14 ` Dmitry Baryshkov
[not found] ` <5dee6da0-9170-d9e0-5ff7-f8436331c6a9@oss.qualcomm.com>
2026-04-17 14:59 ` Vishnu Reddy
2026-04-17 18:19 ` Dmitry Baryshkov
2026-04-20 14:02 ` Vishnu Reddy
2026-04-20 17:56 ` Dmitry Baryshkov
2026-04-14 4:59 ` [PATCH 03/11] media: iris: Add context bank hooks for platform specific initialization Vishnu Reddy
2026-04-14 15:16 ` Dmitry Baryshkov
2026-04-17 15:03 ` Vishnu Reddy
2026-04-14 5:00 ` [PATCH 04/11] media: iris: Add helper to create a context bank device on iris vpu bus Vishnu Reddy
2026-04-14 15:18 ` Dmitry Baryshkov
2026-04-17 15:19 ` Vishnu Reddy
2026-04-17 18:23 ` Dmitry Baryshkov
2026-04-20 14:03 ` Vishnu Reddy
2026-04-20 17:56 ` Dmitry Baryshkov
2026-04-22 6:19 ` Vishnu Reddy [this message]
2026-04-14 5:00 ` [PATCH 05/11] media: iris: Enable Secure PAS support with IOMMU managed by Linux Vishnu Reddy
2026-04-14 6:31 ` Mukesh Ojha
2026-04-14 9:33 ` Mukesh Ojha
2026-04-15 7:36 ` Mukesh Ojha
2026-04-15 7:41 ` Mukesh Ojha
2026-04-17 15:20 ` Vishnu Reddy
2026-04-14 14:09 ` Konrad Dybcio
2026-04-17 15:27 ` Vishnu Reddy
2026-04-14 5:00 ` [PATCH 06/11] media: iris: Fix VM count passed to firmware Vishnu Reddy
2026-04-14 6:33 ` Mukesh Ojha
2026-04-17 15:28 ` Vishnu Reddy
2026-04-14 9:29 ` Konrad Dybcio
2026-04-17 14:35 ` Vishnu Reddy
2026-04-14 15:20 ` Dmitry Baryshkov
2026-04-17 15:29 ` Vishnu Reddy
2026-04-22 7:37 ` Vikash Garodia
2026-04-14 5:00 ` [PATCH 07/11] media: iris: Rename clock and power domain macros to use vcodec prefix Vishnu Reddy
2026-04-14 6:38 ` Mukesh Ojha
2026-04-14 7:20 ` Vishnu Reddy
2026-04-14 5:00 ` [PATCH 08/11] media: iris: Add power sequence for Glymur Vishnu Reddy
2026-04-14 9:49 ` Konrad Dybcio
2026-04-17 16:04 ` Vishnu Reddy
2026-04-14 15:23 ` Dmitry Baryshkov
2026-04-14 5:00 ` [PATCH 09/11] media: iris: Add support to select core for dual core platforms Vishnu Reddy
2026-04-14 9:51 ` Konrad Dybcio
2026-04-17 15:36 ` Vishnu Reddy
2026-04-14 16:02 ` Dmitry Baryshkov
2026-04-22 6:04 ` Vikash Garodia
2026-04-14 5:00 ` [PATCH 10/11] media: iris: Add platform data for glymur Vishnu Reddy
2026-04-14 16:05 ` Dmitry Baryshkov
2026-04-17 15:52 ` Vishnu Reddy
2026-04-14 5:00 ` [PATCH 11/11] arm64: dts: qcom: glymur: Add iris video node Vishnu Reddy
2026-04-14 14:10 ` Konrad Dybcio
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=9c76be4a-e907-b5b6-e50f-0f37738752da@oss.qualcomm.com \
--to=busanna.reddy@oss.qualcomm.com \
--cc=abhinav.kumar@linux.dev \
--cc=andersson@kernel.org \
--cc=bod@kernel.org \
--cc=conor+dt@kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=dikshita.agarwal@oss.qualcomm.com \
--cc=dmitry.baryshkov@oss.qualcomm.com \
--cc=hverkuil@kernel.org \
--cc=iommu@lists.linux.dev \
--cc=joro@8bytes.org \
--cc=konradybcio@kernel.org \
--cc=krzk+dt@kernel.org \
--cc=linux-arm-msm@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-media@vger.kernel.org \
--cc=mchehab@kernel.org \
--cc=robh@kernel.org \
--cc=robin.murphy@arm.com \
--cc=stefan.schmidt@linaro.org \
--cc=vikash.garodia@oss.qualcomm.com \
--cc=will@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox