[Intel-gfx] [RFC 1/3] component: alloc component_match without any comp to match

Ramalingam C ramalingam.c at intel.com
Thu Jul 12 08:53:15 UTC 2018



On Thursday 12 July 2018 01:51 PM, Daniel Vetter wrote:
> On Wed, Jul 11, 2018 at 07:41:26PM +0530, Ramalingam C wrote:
>> If all the components associated to a component master is not added
>> to the component framework due to the HW capability or Kconfig
>> selection, component_match will be NULL at
>> component_master_add_with_match().
>>
>> To avoid this, component_match_alloc() is added to the framework,
>> to allcoate the struct component_match with zero associated components.
>> Hence component master can be added with a component_match with zero
>> associated components.
>>
>> This helps the component master bind call to get triggered always,
>> even if no component is registered for that particular master.
>>
>> This is useful if we use the component master for waiting for few
>> components(features), only if they are registered, else proceed with
>> the normal flow.
> registered is a bit confusing here, I'd go with "supported by the
> underlying hw". And maybe also explain that this is for big pci device
> drivers where only some small/optional things are external components, so
> different use-case from SoC drivers where the entire driver is always
> built up from lots of small components.
>
> When you submit this for real please also run script/get_maintainers.pl
> for the full Cc: list.
sure.
>
>> Signed-off-by: Ramalingam C <ramalingam.c at intel.com>
>> Signed-off-by: Daniel Vetter <daniel.vetter at ffwll.ch>
> Uh, don't do this, ever. I didn't put my s-o-b onto this patch. If you
> want to credit me for the suggestion, use
>
> Suggested-by: ...
>
> s-o-b has legal meaning and is like signing a contract, you've just forged
> my signature here. Same applies to reviewed-by tags btw.

Since the idea is suggested by you, thought that its my responsibility
to give the credit. Sure got your point.

I will add Suggested-by: instead.

Thanks,
Ram.

> -Daniel
>
>> ---
>>   drivers/base/component.c  | 30 ++++++++++++++++++++++++++++++
>>   include/linux/component.h |  2 ++
>>   2 files changed, 32 insertions(+)
>>
>> diff --git a/drivers/base/component.c b/drivers/base/component.c
>> index 8946dfee4768..007fb738263a 100644
>> --- a/drivers/base/component.c
>> +++ b/drivers/base/component.c
>> @@ -312,6 +312,36 @@ static int component_match_realloc(struct device *dev,
>>   }
>>   
>>   /*
>> + * Allocate the match without any component_match_array elements.
>> + *
>> + * This function is useful when the component master might end up
>> + * registering itself without any matching components.
>> + */
>> +void component_match_alloc(struct device *master,
>> +	struct component_match **matchptr)
>> +{
>> +	struct component_match *match = *matchptr;
>> +
>> +	if (IS_ERR(match))
>> +		return;
>> +
>> +	if (match)
>> +		return;
>> +
>> +	match = devres_alloc(devm_component_match_release,
>> +			     sizeof(*match), GFP_KERNEL);
>> +	if (!match) {
>> +		*matchptr = ERR_PTR(-ENOMEM);
>> +		return;
>> +	}
>> +
>> +	devres_add(master, match);
>> +
>> +	*matchptr = match;
>> +}
>> +EXPORT_SYMBOL(component_match_alloc);
>> +
>> +/*
>>    * Add a component to be matched, with a release function.
>>    *
>>    * The match array is first created or extended if necessary.
>> diff --git a/include/linux/component.h b/include/linux/component.h
>> index e71fbbbc74e2..3f6b420a58f8 100644
>> --- a/include/linux/component.h
>> +++ b/include/linux/component.h
>> @@ -37,6 +37,8 @@ void component_match_add_release(struct device *master,
>>   	struct component_match **matchptr,
>>   	void (*release)(struct device *, void *),
>>   	int (*compare)(struct device *, void *), void *compare_data);
>> +void component_match_alloc(struct device *master,
>> +	struct component_match **matchptr);
>>   
>>   static inline void component_match_add(struct device *master,
>>   	struct component_match **matchptr,
>> -- 
>> 2.7.4
>>



More information about the Intel-gfx mailing list