Hi Bryan,

On Sat May 2, 2026 at 12:32 AM CEST, Bryan O'Donoghue wrote:
> On 01/05/2026 11:12, Luca Weiss wrote:
>> Hi Bryan,
>> 
>> On Fri Apr 3, 2026 at 5:07 PM CEST, Bryan O'Donoghue wrote:
>>> On 03/04/2026 09:09, Luca Weiss wrote:
>>>> Hi Vladimir,
>>>>
>>>> On Tue Mar 31, 2026 at 12:49 AM CEST, Vladimir Zapolskiy wrote:
>>>>> Hi Luca,
>>>>>
>>>>> On 2/16/26 10:54, Luca Weiss wrote:
>>>>>> Add bindings, driver and dts to support the Camera Subsystem on the
>>>>>> SM6350 SoC.
>>>>>>
>>>>>> These patches were tested on a Fairphone 4 smartphone with WIP sensor
>>>>>> drivers (Sony IMX576 and IMX582), the camera pipeline works properly as
>>>>>> far as I can tell.
>>>>>>
>>>>>> Though when stopping the camera stream, the following clock warning
>>>>>> appears in dmesg. But it does not interfere with any functionality,
>>>>>> starting and stopping the stream works and debugcc is showing 426.4 MHz
>>>>>> while the clock is on, and 'off' while it's off.
>>>>>>
>>>>>> Any suggestion how to fix this, is appreciated.
>>>>>
>>>>> I've looked at CAMCC recently, and I do notice that SM6350 CAMCC does not
>>>>> set '.use_rpm = true' flag for whatever reason.
>>>>>
>>>>> If you find a free minute, can you test the change below?..
>>>>
>>>> Unfortunately that change does not resolve the "gcc_camera_axi_clk
>>>> status stuck at 'on'" warning.
>>>>
>>>> fairphone-fp4:~$ cat 
>>>> /sys/bus/platform/drivers/sm6350-camcc/ad00000.clock-controller/power/runtime_status
>>>> active
>>>>
>>>> fairphone-fp4:~$ cat 
>>>> /sys/bus/platform/drivers/sm6350-camcc/ad00000.clock-controller/power/runtime_status
>>>> suspended
>>>>
>>>>>
>>>>> ----8<----
>>>>> diff --git a/drivers/clk/qcom/camcc-sm6350.c 
>>>>> b/drivers/clk/qcom/camcc-sm6350.c
>>>>> index 7df12c1311c6..ba880e4edcaf 100644
>>>>> --- a/drivers/clk/qcom/camcc-sm6350.c
>>>>> +++ b/drivers/clk/qcom/camcc-sm6350.c
>>>>> @@ -1880,6 +1880,7 @@ static const struct qcom_cc_desc camcc_sm6350_desc 
>>>>> = {
>>>>>           .num_clks = ARRAY_SIZE(camcc_sm6350_clocks),
>>>>>           .gdscs = camcc_sm6350_gdscs,
>>>>>           .num_gdscs = ARRAY_SIZE(camcc_sm6350_gdscs),
>>>>> + .use_rpm = true,
>>>>>     };
>>>>>
>>>>>     static const struct of_device_id camcc_sm6350_match_table[] = {
>>>>> ----8<----
>>>>>
>>>>> This change could be considered to be included in any case, I believe.
>>>>
>>>> I guess this change is now the way to enable pm_runtime, I had this
>>>> series 3 years ago in February 2023:
>>>> https://lore.kernel.org/linux-arm-msm/[email protected]/
>>>>
>>>> But I never followed up due to me not understanding pm_runtime well and
>>>> no direct need for it.
>>>>
>>>> But I guess reviving that with use_rpm = true, add power-domains &
>>>> required-opps to dt-bindings and sm6350.dtsi should be a good idea?
>>>>
>>>> Regards
>>>> Luca
>>>>
>>>>>
>>>>>> [ 5738.590980] ------------[ cut here ]------------
>>>>>> [ 5738.591009] gcc_camera_axi_clk status stuck at 'on'
>>>>>> [ 5738.591049] WARNING: CPU: 0 PID: 6918 at 
>>>>>> drivers/clk/qcom/clk-branch.c:87 clk_branch_toggle+0x170/0x190
>>>>>> [ 5738.591081] Modules linked in:
>>>>>> [ 5738.591099] CPU: 0 UID: 10000 PID: 6918 Comm: plasma-camera Tainted: 
>>>>>> G        W           6.17.0-00057-ge6b67db49622 #71 NONE
>>>>>> [ 5738.591118] Tainted: [W]=WARN
>>>>>> [ 5738.591126] Hardware name: Fairphone 4 (DT)
>>>>>> [ 5738.591136] pstate: 604000c5 (nZCv daIF +PAN -UAO -TCO -DIT -SSBS 
>>>>>> BTYPE=--)
>>>>>> [ 5738.591150] pc : clk_branch_toggle+0x170/0x190
>>>>>> [ 5738.591164] lr : clk_branch_toggle+0x170/0x190
>>>>>> [ 5738.591177] sp : ffff800086ed3980
>>>>>> [ 5738.591184] x29: ffff800086ed3990 x28: 0000000000000001 x27: 
>>>>>> ffff800086ed3cd8
>>>>>> [ 5738.591208] x26: 0000000000000000 x25: ffffda14fcfbd250 x24: 
>>>>>> 0000000000000000
>>>>>> [ 5738.591230] x23: 0000000000000000 x22: ffffda14fc38bce0 x21: 
>>>>>> 0000000000000000
>>>>>> [ 5738.591252] x20: ffffda14fd33e618 x19: 0000000000000000 x18: 
>>>>>> 00000000000064c8
>>>>>> [ 5738.591274] x17: 0000000000000000 x16: 00001ae003667e9e x15: 
>>>>>> ffffda14fd2a07b0
>>>>>> [ 5738.591295] x14: 0000000000000000 x13: 6f27207461206b63 x12: 
>>>>>> 7574732073757461
>>>>>> [ 5738.591317] x11: 0000000000000058 x10: 0000000000000018 x9 : 
>>>>>> ffffda14fd2a0838
>>>>>> [ 5738.591338] x8 : 0000000000057fa8 x7 : 0000000000000a16 x6 : 
>>>>>> ffffda14fd2f8838
>>>>>> [ 5738.591360] x5 : ffff0001f6f59788 x4 : 0000000000000a15 x3 : 
>>>>>> ffff25ecf9d7e000
>>>>>> [ 5738.591381] x2 : 0000000000000000 x1 : 0000000000000000 x0 : 
>>>>>> ffff0000baf5c100
>>>>>> [ 5738.591403] Call trace:
>>>>>> [ 5738.591412]  clk_branch_toggle+0x170/0x190 (P)
>>>>>> [ 5738.591429]  clk_branch2_disable+0x1c/0x30
>>>>>> [ 5738.591445]  clk_core_disable+0x5c/0xb4
>>>>>> [ 5738.591462]  clk_disable+0x38/0x60
>>>>>> [ 5738.591478]  camss_disable_clocks+0x44/0x78
>>>>>> [ 5738.591496]  vfe_put+0x7c/0xc0
>>>>>> [ 5738.591512]  vfe_set_power+0x40/0x50
>>>>>> [ 5738.591528]  pipeline_pm_power_one+0x14c/0x150
>>>>>> [ 5738.591546]  pipeline_pm_power+0x74/0xf4
>>>>>> [ 5738.591561]  v4l2_pipeline_pm_use+0x54/0x9c
>>>>>> [ 5738.591577]  v4l2_pipeline_pm_put+0x14/0x40
>>>>>> [ 5738.591592]  video_unprepare_streaming+0x18/0x24
>>>>>> [ 5738.591608]  __vb2_queue_cancel+0x4c/0x314
>>>>>> [ 5738.591626]  vb2_core_streamoff+0x24/0xc8
>>>>>> [ 5738.591643]  vb2_ioctl_streamoff+0x58/0x98
>>>>>> [ 5738.591657]  v4l_streamoff+0x24/0x30
>>>>>> [ 5738.591672]  __video_do_ioctl+0x430/0x4a8
>>>>>> [ 5738.591689]  video_usercopy+0x2ac/0x680
>>>>>> [ 5738.591705]  video_ioctl2+0x18/0x40
>>>>>> [ 5738.591720]  v4l2_ioctl+0x40/0x60
>>>>>> [ 5738.591734]  __arm64_sys_ioctl+0x90/0xf0
>>>>>> [ 5738.591750]  invoke_syscall.constprop.0+0x40/0xf0
>>>>>> [ 5738.591769]  el0_svc_common.constprop.0+0x38/0xd8
>>>>>> [ 5738.591785]  do_el0_svc+0x1c/0x28
>>>>>> [ 5738.591801]  el0_svc+0x34/0xe8
>>>>>> [ 5738.591820]  el0t_64_sync_handler+0xa0/0xe4
>>>>>> [ 5738.591838]  el0t_64_sync+0x198/0x19c
>>>>>> [ 5738.591854] ---[ end trace 0000000000000000 ]---
>>>>>>
>>>>>> Signed-off-by: Luca Weiss <[email protected]>
>>>>>> ---
>>>>>> Changes in v4:
>>>>>> - Update power-domain-names order (Krzysztof)
>>>>>> - Make hex numbers lower case in init seq (David)
>>>>>> - Pick up tags
>>>>>> - Link to v3: 
>>>>>> https://lore.kernel.org/r/[email protected]
>>>>>
>>>>> Should find some time myself to issue RBs, sorry for the delay.
>>>>>
>>>>>> Changes in v3:
>>>>>> - Update dt-bindings to include everything related to camss
>>>>>> - Update regulator names
>>>>>> - Remove slow_ahb_src
>>>>>> - Link to v2: 
>>>>>> https://lore.kernel.org/r/[email protected]
>>>>>>
>>>>>> Changes in v2:
>>>>>> - Remove prefix from interconnect-names
>>>>>> - Move 'top' power-domain to the top of list
>>>>>> - Update regulator supply names
>>>>>> - Link to v1: 
>>>>>> https://lore.kernel.org/r/[email protected]
>>>>>>
>>>>>> ---
>>>>>> Luca Weiss (3):
>>>>>>          dt-bindings: media: camss: Add qcom,sm6350-camss
>>>>>>          media: qcom: camss: Add SM6350 support
>>>>>>          arm64: dts: qcom: sm6350: Add CAMSS node
>>>>>>
>>>>>>     .../bindings/media/qcom,sm6350-camss.yaml          | 471 
>>>>>> +++++++++++++++++++++
>>>>>>     arch/arm64/boot/dts/qcom/sm6350.dtsi               | 233 ++++++++++
>>>>>>     .../platform/qcom/camss/camss-csiphy-3ph-1-0.c     | 125 ++++++
>>>>>>     drivers/media/platform/qcom/camss/camss-vfe.c      |   2 +
>>>>>>     drivers/media/platform/qcom/camss/camss.c          | 261 ++++++++++++
>>>>>>     drivers/media/platform/qcom/camss/camss.h          |   1 +
>>>>>>     6 files changed, 1093 insertions(+)
>>>>>> ---
>>>>>> base-commit: 3daf23347bb5f4a375d0101ed29c97ce1a99721b
>>>>>> change-id: 20251024-sm6350-camss-9c404bf9cfdd
>>>>>>
>>>>>> Best regards,
>>>>
>>>
>>> What about taking the clock out of hardware gated mode ?
>>>
>>> ┌─[deckard@sagittarius-a] - [~/Development/qualcomm/qlt-kernel] - [Fri
>>> Apr 03, 16:05]
>>> └─[$]> git diff
>>> diff --git a/drivers/clk/qcom/gcc-sm6350.c b/drivers/clk/qcom/gcc-sm6350.c
>>> index a4d6dff9d0f7f..f98cb35bcd408 100644
>>> --- a/drivers/clk/qcom/gcc-sm6350.c
>>> +++ b/drivers/clk/qcom/gcc-sm6350.c
>>> @@ -909,8 +909,6 @@ static struct clk_branch gcc_camera_ahb_clk = {
>>>    static struct clk_branch gcc_camera_axi_clk = {
>>>           .halt_reg = 0x17018,
>>>           .halt_check = BRANCH_HALT,
>>> -       .hwcg_reg = 0x17018,
>>> -       .hwcg_bit = 1,
>> 
>> Unfortunately this change has no effect, still getting the same error
>> 
>> [  192.154311] ------------[ cut here ]------------
>> [  192.154339] gcc_camera_axi_clk status stuck at 'on'
>> [  192.154364] WARNING: drivers/clk/qcom/clk-branch.c:87 at 
>> clk_branch_toggle+0x170/0x190, CPU#5: CameraManager/5996
>> [  192.154387] Modules linked in:
>> [  192.154403] CPU: 5 UID: 10000 PID: 5996 Comm: CameraManager Tainted: G    
>>     W           7.0.0-00074-gb9262f98394c-dirty #31 PREEMPTLAZY
>> 
>> Regards
>> Luca
>
> Sorry wait a second did you say you had a fix for this around CX ?
>
> https://lore.kernel.org/linux-arm-msm/[email protected]/
>
> Is this series adding or missing power-domains = <CX> ?
>
> Shouldn't this be in the gcc node ?
>
> +                     power-domains = <&rpmhpd SM6350_CX>;
> +                     required-opps = <&rpmhpd_opp_low_svs>;

In this thread I've tried ".use_rpm = true" for *camcc* - which I
believe is the modern equivalent to all the code added in the linked
series.

For gcc I don't believe I've tried adding anything.

But practically, isn't CX always on anyways, especially with screen on
and everthing, so practically it shouldn't make any difference?

Regards
Luca

Reply via email to