* [PATCH] drm/bridge: Add null pointer check for ITE IT6263
@ 2025-07-22 20:41 Chenyuan Yang
2025-07-23 5:19 ` Biju Das
2025-07-23 6:57 ` Maxime Ripard
0 siblings, 2 replies; 5+ messages in thread
From: Chenyuan Yang @ 2025-07-22 20:41 UTC (permalink / raw)
To: victor.liu, andrzej.hajda, neil.armstrong, rfoss,
laurent.pinchart, jonas, jernej.skrabec, maarten.lankhorst,
mripard, tzimmermann, airlied, simona, lumag, biju.das.jz
Cc: dri-devel, linux-kernel, Chenyuan Yang
drm_atomic_get_new_connector_for_encoder and
drm_atomic_get_new_connector_state could return Null.
Thus, add the null pointer check for them with a similar format with
it6505_bridge_atomic_enable in ITE IT6505.
Signed-off-by: Chenyuan Yang <chenyuan0y@gmail.com>
Fixes: 049723628716 ("drm/bridge: Add ITE IT6263 LVDS to HDMI converter")
---
drivers/gpu/drm/bridge/ite-it6263.c | 15 ++++++++++++++-
1 file changed, 14 insertions(+), 1 deletion(-)
diff --git a/drivers/gpu/drm/bridge/ite-it6263.c b/drivers/gpu/drm/bridge/ite-it6263.c
index a3a63a977b0a..3a20b2088bf9 100644
--- a/drivers/gpu/drm/bridge/ite-it6263.c
+++ b/drivers/gpu/drm/bridge/ite-it6263.c
@@ -590,15 +590,28 @@ static void it6263_bridge_atomic_enable(struct drm_bridge *bridge,
struct drm_connector *connector;
bool is_stable = false;
struct drm_crtc *crtc;
+ struct drm_connector_state *conn_state;
unsigned int val;
bool pclk_high;
int i, ret;
connector = drm_atomic_get_new_connector_for_encoder(state,
bridge->encoder);
- crtc = drm_atomic_get_new_connector_state(state, connector)->crtc;
+ if (WARN_ON(!connector))
+ return;
+
+ conn_state = drm_atomic_get_new_connector_state(state, connector);
+ if (WARN_ON(!conn_state))
+ return;
+
+ crtc = conn_state->crtc;
crtc_state = drm_atomic_get_new_crtc_state(state, crtc);
+ if (WARN_ON(!crtc_state))
+ return;
+
mode = &crtc_state->adjusted_mode;
+ if (WARN_ON(!mode))
+ return;
regmap_write(regmap, HDMI_REG_HDMI_MODE, TX_HDMI_MODE);
--
2.34.1
^ permalink raw reply related [flat|nested] 5+ messages in thread
* RE: [PATCH] drm/bridge: Add null pointer check for ITE IT6263
2025-07-22 20:41 [PATCH] drm/bridge: Add null pointer check for ITE IT6263 Chenyuan Yang
@ 2025-07-23 5:19 ` Biju Das
2025-07-23 6:57 ` Maxime Ripard
1 sibling, 0 replies; 5+ messages in thread
From: Biju Das @ 2025-07-23 5:19 UTC (permalink / raw)
To: Chenyuan Yang, victor.liu@nxp.com, andrzej.hajda@intel.com,
neil.armstrong@linaro.org, rfoss@kernel.org, laurent.pinchart,
jonas@kwiboo.se, jernej.skrabec@gmail.com,
maarten.lankhorst@linux.intel.com, mripard@kernel.org,
tzimmermann@suse.de, airlied@gmail.com, simona@ffwll.ch,
lumag@kernel.org
Cc: dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org
Hi Chenyuan Yang,
Thanks for the patch.
> -----Original Message-----
> From: Chenyuan Yang <chenyuan0y@gmail.com>
> Sent: 22 July 2025 21:41
> Subject: [PATCH] drm/bridge: Add null pointer check for ITE IT6263
>
> drm_atomic_get_new_connector_for_encoder and drm_atomic_get_new_connector_state could return Null.
> Thus, add the null pointer check for them with a similar format with it6505_bridge_atomic_enable in
> ITE IT6505.
>
> Signed-off-by: Chenyuan Yang <chenyuan0y@gmail.com>
> Fixes: 049723628716 ("drm/bridge: Add ITE IT6263 LVDS to HDMI converter")
Normally Fixes should be above Sb tag.
> ---
> drivers/gpu/drm/bridge/ite-it6263.c | 15 ++++++++++++++-
> 1 file changed, 14 insertions(+), 1 deletion(-)
>
> diff --git a/drivers/gpu/drm/bridge/ite-it6263.c b/drivers/gpu/drm/bridge/ite-it6263.c
> index a3a63a977b0a..3a20b2088bf9 100644
> --- a/drivers/gpu/drm/bridge/ite-it6263.c
> +++ b/drivers/gpu/drm/bridge/ite-it6263.c
> @@ -590,15 +590,28 @@ static void it6263_bridge_atomic_enable(struct drm_bridge *bridge,
> struct drm_connector *connector;
> bool is_stable = false;
> struct drm_crtc *crtc;
> + struct drm_connector_state *conn_state;
Please arrange it in reverse X-mas tree fashion.
> unsigned int val;
> bool pclk_high;
> int i, ret;
>
> connector = drm_atomic_get_new_connector_for_encoder(state,
> bridge->encoder);
> - crtc = drm_atomic_get_new_connector_state(state, connector)->crtc;
> + if (WARN_ON(!connector))
Why WARN_ON everywhere? Can we use dev_err instead?
Cheers,
Biju
> + return;
> +
> + conn_state = drm_atomic_get_new_connector_state(state, connector);
> + if (WARN_ON(!conn_state))
> + return;
> +
> + crtc = conn_state->crtc;
> crtc_state = drm_atomic_get_new_crtc_state(state, crtc);
> + if (WARN_ON(!crtc_state))
> + return;
> +
> mode = &crtc_state->adjusted_mode;
> + if (WARN_ON(!mode))
> + return;
>
> regmap_write(regmap, HDMI_REG_HDMI_MODE, TX_HDMI_MODE);
>
> --
> 2.34.1
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] drm/bridge: Add null pointer check for ITE IT6263
2025-07-22 20:41 [PATCH] drm/bridge: Add null pointer check for ITE IT6263 Chenyuan Yang
2025-07-23 5:19 ` Biju Das
@ 2025-07-23 6:57 ` Maxime Ripard
2025-07-23 16:09 ` Chenyuan Yang
[not found] ` <CALGdzuoprX2Q=vwOENrmAbPbJb+XeBjQqG90YEOApSbW9uKeZg@mail.gmail.com>
1 sibling, 2 replies; 5+ messages in thread
From: Maxime Ripard @ 2025-07-23 6:57 UTC (permalink / raw)
To: Chenyuan Yang
Cc: victor.liu, andrzej.hajda, neil.armstrong, rfoss,
laurent.pinchart, jonas, jernej.skrabec, maarten.lankhorst,
tzimmermann, airlied, simona, lumag, biju.das.jz, dri-devel,
linux-kernel
[-- Attachment #1: Type: text/plain, Size: 1836 bytes --]
On Tue, Jul 22, 2025 at 03:41:14PM -0500, Chenyuan Yang wrote:
> drm_atomic_get_new_connector_for_encoder and
> drm_atomic_get_new_connector_state could return Null.
They can, but not in that scenario. atomic_enable will never be called
if either would return NULL.
In which situation did you trigger this bug?
> Thus, add the null pointer check for them with a similar format with
> it6505_bridge_atomic_enable in ITE IT6505.
>
> Signed-off-by: Chenyuan Yang <chenyuan0y@gmail.com>
> Fixes: 049723628716 ("drm/bridge: Add ITE IT6263 LVDS to HDMI converter")
> ---
> drivers/gpu/drm/bridge/ite-it6263.c | 15 ++++++++++++++-
> 1 file changed, 14 insertions(+), 1 deletion(-)
>
> diff --git a/drivers/gpu/drm/bridge/ite-it6263.c b/drivers/gpu/drm/bridge/ite-it6263.c
> index a3a63a977b0a..3a20b2088bf9 100644
> --- a/drivers/gpu/drm/bridge/ite-it6263.c
> +++ b/drivers/gpu/drm/bridge/ite-it6263.c
> @@ -590,15 +590,28 @@ static void it6263_bridge_atomic_enable(struct drm_bridge *bridge,
> struct drm_connector *connector;
> bool is_stable = false;
> struct drm_crtc *crtc;
> + struct drm_connector_state *conn_state;
> unsigned int val;
> bool pclk_high;
> int i, ret;
>
> connector = drm_atomic_get_new_connector_for_encoder(state,
> bridge->encoder);
> - crtc = drm_atomic_get_new_connector_state(state, connector)->crtc;
> + if (WARN_ON(!connector))
> + return;
> +
> + conn_state = drm_atomic_get_new_connector_state(state, connector);
> + if (WARN_ON(!conn_state))
> + return;
> +
> + crtc = conn_state->crtc;
> crtc_state = drm_atomic_get_new_crtc_state(state, crtc);
> + if (WARN_ON(!crtc_state))
> + return;
> +
> mode = &crtc_state->adjusted_mode;
> + if (WARN_ON(!mode))
> + return;
And that condition can never be true.
Maxime
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 273 bytes --]
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] drm/bridge: Add null pointer check for ITE IT6263
2025-07-23 6:57 ` Maxime Ripard
@ 2025-07-23 16:09 ` Chenyuan Yang
[not found] ` <CALGdzuoprX2Q=vwOENrmAbPbJb+XeBjQqG90YEOApSbW9uKeZg@mail.gmail.com>
1 sibling, 0 replies; 5+ messages in thread
From: Chenyuan Yang @ 2025-07-23 16:09 UTC (permalink / raw)
To: Maxime Ripard
Cc: victor.liu, andrzej.hajda, neil.armstrong, rfoss,
laurent.pinchart, jonas, jernej.skrabec, maarten.lankhorst,
tzimmermann, airlied, simona, lumag, biju.das.jz, dri-devel,
linux-kernel
Apologies for the second email.
I am resending this message as the formatting in the previous version
was incorrect
On Tue, Jul 22, 2025 at 11:57 PM Maxime Ripard <mripard@kernel.org> wrote:
>
> On Tue, Jul 22, 2025 at 03:41:14PM -0500, Chenyuan Yang wrote:
> > drm_atomic_get_new_connector_for_encoder and
> > drm_atomic_get_new_connector_state could return Null.
>
> They can, but not in that scenario. atomic_enable will never be called
> if either would return NULL.
>
> In which situation did you trigger this bug?
This is found by our static analysis tool based on the fact that
drm_atomic_get_new_connector_state() could return NULL.
We also noticed that under the same dir, the ITE IT6505 transmitter
has such checks.
Thus, we assume it would be good to have similar checks here.
> > Thus, add the null pointer check for them with a similar format with
> > it6505_bridge_atomic_enable in ITE IT6505.
> >
> > Signed-off-by: Chenyuan Yang <chenyuan0y@gmail.com>
> > Fixes: 049723628716 ("drm/bridge: Add ITE IT6263 LVDS to HDMI converter")
> > ---
> > drivers/gpu/drm/bridge/ite-it6263.c | 15 ++++++++++++++-
> > 1 file changed, 14 insertions(+), 1 deletion(-)
> >
> > diff --git a/drivers/gpu/drm/bridge/ite-it6263.c b/drivers/gpu/drm/bridge/ite-it6263.c
> > index a3a63a977b0a..3a20b2088bf9 100644
> > --- a/drivers/gpu/drm/bridge/ite-it6263.c
> > +++ b/drivers/gpu/drm/bridge/ite-it6263.c
> > @@ -590,15 +590,28 @@ static void it6263_bridge_atomic_enable(struct drm_bridge *bridge,
> > struct drm_connector *connector;
> > bool is_stable = false;
> > struct drm_crtc *crtc;
> > + struct drm_connector_state *conn_state;
> > unsigned int val;
> > bool pclk_high;
> > int i, ret;
> >
> > connector = drm_atomic_get_new_connector_for_encoder(state,
> > bridge->encoder);
> > - crtc = drm_atomic_get_new_connector_state(state, connector)->crtc;
> > + if (WARN_ON(!connector))
> > + return;
> > +
> > + conn_state = drm_atomic_get_new_connector_state(state, connector);
> > + if (WARN_ON(!conn_state))
> > + return;
> > +
> > + crtc = conn_state->crtc;
> > crtc_state = drm_atomic_get_new_crtc_state(state, crtc);
> > + if (WARN_ON(!crtc_state))
> > + return;
> > +
> > mode = &crtc_state->adjusted_mode;
> > + if (WARN_ON(!mode))
> > + return;
>
> And that condition can never be true.
>
> Maxime
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] drm/bridge: Add null pointer check for ITE IT6263
[not found] ` <CALGdzuoprX2Q=vwOENrmAbPbJb+XeBjQqG90YEOApSbW9uKeZg@mail.gmail.com>
@ 2025-07-24 2:01 ` Liu Ying
0 siblings, 0 replies; 5+ messages in thread
From: Liu Ying @ 2025-07-24 2:01 UTC (permalink / raw)
To: Chenyuan Yang, Maxime Ripard
Cc: airlied, andrzej.hajda, biju.das.jz, dri-devel, jernej.skrabec,
jonas, laurent.pinchart, linux-kernel, lumag, maarten.lankhorst,
neil.armstrong, rfoss, simona, tzimmermann, victor.liu
Hi Chenyuan,
On 07/23/2025, Chenyuan Yang wrote:
> On Tue, Jul 22, 2025 at 23:57 Maxime Ripard <mripard@kernel.org> wrote:
>
>> On Tue, Jul 22, 2025 at 03:41:14PM -0500, Chenyuan Yang wrote:
>>> drm_atomic_get_new_connector_for_encoder and
>>> drm_atomic_get_new_connector_state could return Null.
>>
>> They can, but not in that scenario. atomic_enable will never be called
>> if either would return NULL.
>>
>> In which situation did you trigger this bug?
>
>
> This is found by our static analysis tool based on the fact that
> drm_atomic_get_new_connector_state() could return NULL. We also noticed
> that under the same dir, ITE IT6505 transmitter has such checks. Thus, we
> assume it would be good to have similar checks here.
You need to properly triage the tool's report, which means if there is
no real case that could produce those NULL pointers, then the report
should be false-positive, otherwise show us any real case that could in
commit message. Assuming the checks are needed is not good enough.
Please do your home work before sending the patch.
>
>
>>> Thus, add the null pointer check for them with a similar format with
>>> it6505_bridge_atomic_enable in ITE IT6505.
>>>
>>> Signed-off-by: Chenyuan Yang <chenyuan0y@gmail.com>
>>> Fixes: 049723628716 ("drm/bridge: Add ITE IT6263 LVDS to HDMI converter")
>>> ---
>>> drivers/gpu/drm/bridge/ite-it6263.c | 15 ++++++++++++++-
>>> 1 file changed, 14 insertions(+), 1 deletion(-)
>>>
>>> diff --git a/drivers/gpu/drm/bridge/ite-it6263.c
>> b/drivers/gpu/drm/bridge/ite-it6263.c
>>> index a3a63a977b0a..3a20b2088bf9 100644
>>> --- a/drivers/gpu/drm/bridge/ite-it6263.c
>>> +++ b/drivers/gpu/drm/bridge/ite-it6263.c
>>> @@ -590,15 +590,28 @@ static void it6263_bridge_atomic_enable(struct
>> drm_bridge *bridge,
>>> struct drm_connector *connector;
>>> bool is_stable = false;
>>> struct drm_crtc *crtc;
>>> + struct drm_connector_state *conn_state;
>>> unsigned int val;
>>> bool pclk_high;
>>> int i, ret;
>>>
>>> connector = drm_atomic_get_new_connector_for_encoder(state,
>>>
>> bridge->encoder);
>>> - crtc = drm_atomic_get_new_connector_state(state, connector)->crtc;
>>> + if (WARN_ON(!connector))
>>> + return;
>>> +
>>> + conn_state = drm_atomic_get_new_connector_state(state, connector);
>>> + if (WARN_ON(!conn_state))
>>> + return;
>>> +
>>> + crtc = conn_state->crtc;
>>> crtc_state = drm_atomic_get_new_crtc_state(state, crtc);
>>> + if (WARN_ON(!crtc_state))
>>> + return;
>>> +
>>> mode = &crtc_state->adjusted_mode;
>>> + if (WARN_ON(!mode))
>>> + return;
>>
>> And that condition can never be true.
>>
>> Maxime
>>
>
--
Regards,
Liu Ying
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2025-07-24 2:00 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-07-22 20:41 [PATCH] drm/bridge: Add null pointer check for ITE IT6263 Chenyuan Yang
2025-07-23 5:19 ` Biju Das
2025-07-23 6:57 ` Maxime Ripard
2025-07-23 16:09 ` Chenyuan Yang
[not found] ` <CALGdzuoprX2Q=vwOENrmAbPbJb+XeBjQqG90YEOApSbW9uKeZg@mail.gmail.com>
2025-07-24 2:01 ` Liu Ying
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).