[PATCH v2] drm/bridge: adv7511: Remove unused code blocks

Laurent Pinchart laurent.pinchart at ideasonboard.com
Thu Oct 20 07:35:48 UTC 2016


Hi Jitendra,

On Wednesday 19 Oct 2016 19:11:27 Sharma, Jitendra wrote:
> On 10/19/2016 7:03 PM, Laurent Pinchart wrote:
> > On Wednesday 19 Oct 2016 18:37:38 Sharma, Jitendra wrote:
> >> On 10/19/2016 5:21 PM, Laurent Pinchart wrote:
> >>> On Wednesday 19 Oct 2016 17:12:48 Jitendra Sharma wrote:
> >>>> Remove redundant condition check
> >>>> Remove not necessary if-else block for checking DT entry because else
> >>>> part will never be picked as in absence of device node, probe will
> >>>> fail in initial stage only.
> >>>> 
> >>>> Remove unused id->driver_data entries
> >>>> As id->driver_data is not used in driver source. So no need in
> >>>> Keeping these entries in id_table
> >>>> 
> >>>> Signed-off-by: Jitendra Sharma <shajit at codeaurora.org>
> >>>> ---
> >>>> Probe was not happening in Patch v1 due to removal of .id_table.As the
> >>>> intention of this patch is not to change any functionality, also
> >>>> changes looks simple enough.So, didn't verified Patch v1 over hardware
> >>> 
> >>> You should *ALWAYS* verify patches before sending them out.
> >> 
> >> Will keep in mind
> >> 
> >>> I assume you've now properly tested this one ?
> >>> 
> >>>> Hence fixing the issues in Patch v1 and posting patch v2
> >>>> 
> >>>> Changes for v2:
> >>>>    - Keep the id_table entries
> >>>>    - Keep the id->driver_data to 0
> >>>> 
> >>>> ---
> >>>> 
> >>>>    drivers/gpu/drm/bridge/adv7511/adv7511_drv.c | 13 +++++--------
> >>>>    1 file changed, 5 insertions(+), 8 deletions(-)
> >>>> 
> >>>> diff --git a/drivers/gpu/drm/bridge/adv7511/adv7511_drv.c
> >>>> b/drivers/gpu/drm/bridge/adv7511/adv7511_drv.c index 8ed3906..3279059
> >>>> 100644
> >>>> --- a/drivers/gpu/drm/bridge/adv7511/adv7511_drv.c
> >>>> +++ b/drivers/gpu/drm/bridge/adv7511/adv7511_drv.c
> >>>> @@ -942,10 +942,7 @@ static int adv7511_probe(struct i2c_client *i2c,
> >>>> const struct i2c_device_id *id)
> >>>> 		adv7511->powered = false;
> >>>>    	adv7511->status = connector_status_disconnected;
> >>>> 
> >>>> -	if (dev->of_node)
> >>>> -		adv7511->type = (enum
> >>>> adv7511_type)of_device_get_match_data(dev);
> >>>> -	else
> >>>> -		adv7511->type = id->driver_data;
> >>>> +	adv7511->type = (enum
> >>>> adv7511_type)of_device_get_match_data(dev);
> >>>> 
> >>>>    	memset(&link_config, 0, sizeof(link_config));
> >>>> 
> >>>> @@ -1066,11 +1063,11 @@ static int adv7511_remove(struct i2c_client
> >>>> *i2c)
> >>>>    }
> >>>>    
> >>>>    static const struct i2c_device_id adv7511_i2c_ids[] = {
> >>>> -	{ "adv7511", ADV7511 },
> >>>> -	{ "adv7511w", ADV7511 },
> >>>> -	{ "adv7513", ADV7511 },
> >>>> +	{ "adv7511", 0 },
> >>>> +	{ "adv7511w", 0 },
> >>>> +	{ "adv7513", 0 },
> >>>>    #ifdef CONFIG_DRM_I2C_ADV7533
> >>>> -	{ "adv7533", ADV7533 },
> >>>> +	{ "adv7533", 0 },
> >>>>    #endif
> >>> 
> >>> What's the purpose of this ? It doesn't save any memory or CPU cycle.
> >> 
> >> Idea is to remove unnecessary code, variables and if possible to reduce
> >> lines of code for example here by eliminating obvious branching.
> >> Regarding memory or cpu cyles, no difference could be because of
> >> compiler optimization
> > 
> > For the code block in the probe function I understand, but for the
> > initializers here I don't see the point.
> > 
> > And one might argue that using id->driver_data unconditionally would be
> > better as it would save a call to of_device_get_match_data()...
> 
> Agreed.
> So, there could be two ways round either use id->driver_data
> unconditionally or use of_device_get_match_data().
> IMO it would be better to use id->driver_data unconditionally and save a
> call to of_device_get_match_data()
> What would you suggest to move ahead?

I'd suggest using id->driver_data unconditionally, but I'd like Wolfram's 
opinion on this (CC'ed).


-- 
Regards,

Laurent Pinchart



More information about the dri-devel mailing list