[Intel-gfx] [PATCH i-g-t 2/2] lib/igt_aux: define actual functions for kmstest_*_str

Jani Nikula jani.nikula at intel.com
Tue May 17 10:05:13 UTC 2016


On Tue, 17 May 2016, Daniel Vetter <daniel at ffwll.ch> wrote:
> On Wed, May 11, 2016 at 12:42:06PM +0300, Jani Nikula wrote:
>> Macro generated function definitions considered harmful. You can't find
>> them with code search tools or grep. There may be places where such
>> things might be useful, but this is not it.
>> 
>> Define actual functions for kmstest_encoder_type_str(),
>> kmstest_connector_status_str() and kmstest_connector_type_str(). While
>> at it, make the arrays static const.
>> 
>> Signed-off-by: Jani Nikula <jani.nikula at intel.com>
>> ---
>>  lib/igt_aux.c | 41 ++++++++++++++++++++++++++---------------
>>  1 file changed, 26 insertions(+), 15 deletions(-)
>> 
>> diff --git a/lib/igt_aux.c b/lib/igt_aux.c
>> index 5dbbe4dd4a85..22962dcf2be4 100644
>> --- a/lib/igt_aux.c
>> +++ b/lib/igt_aux.c
>> @@ -941,17 +941,17 @@ struct type_name {
>>  	const char *name;
>>  };
>>  
>> -#define type_name_fn(res) \
>> -const char * kmstest_##res##_str(int type) {		\
>> -	unsigned int i;					\
>> -	for (i = 0; i < ARRAY_SIZE(res##_names); i++) { \
>> -		if (res##_names[i].type == type)	\
>> -			return res##_names[i].name;	\
>> -	}						\
>> -	return "(invalid)";				\
>> +static const char *find_type_name(const struct type_name *names, int type)
>> +{
>> +	for (; names->name; names++) {
>> +		if (names->type == type)
>> +			return names->name;
>> +	}
>> +
>> +	return "(invalid)";
>>  }
>>  
>> -struct type_name encoder_type_names[] = {
>> +static const struct type_name encoder_type_names[] = {
>>  	{ DRM_MODE_ENCODER_NONE, "none" },
>>  	{ DRM_MODE_ENCODER_DAC, "DAC" },
>>  	{ DRM_MODE_ENCODER_TMDS, "TMDS" },
>> @@ -960,19 +960,27 @@ struct type_name encoder_type_names[] = {
>>  	{ DRM_MODE_ENCODER_VIRTUAL, "Virtual" },
>>  	{ DRM_MODE_ENCODER_DSI, "DSI" },
>>  	{ DRM_MODE_ENCODER_DPMST, "DP MST" },
>> +	{}
>>  };
>>  
>> -type_name_fn(encoder_type)
>> +const char *kmstest_encoder_type_str(int type)
>> +{
>> +	return find_type_name(encoder_type_names, type);
>> +}
>
> We should have gtkdoc for these now too, or maybe we had but somewhere
> else?

We still do, in igt_kms.h, where they didn't help me in the least
finding the definitions...

BR,
Jani.

> -Daniel
>
>>  
>> -struct type_name connector_status_names[] = {
>> +static const struct type_name connector_status_names[] = {
>>  	{ DRM_MODE_CONNECTED, "connected" },
>>  	{ DRM_MODE_DISCONNECTED, "disconnected" },
>>  	{ DRM_MODE_UNKNOWNCONNECTION, "unknown" },
>> +	{}
>>  };
>>  
>> -type_name_fn(connector_status)
>> +const char *kmstest_connector_status_str(int status)
>> +{
>> +	return find_type_name(connector_status_names, status);
>> +}
>>  
>> -struct type_name connector_type_names[] = {
>> +static const struct type_name connector_type_names[] = {
>>  	{ DRM_MODE_CONNECTOR_Unknown, "unknown" },
>>  	{ DRM_MODE_CONNECTOR_VGA, "VGA" },
>>  	{ DRM_MODE_CONNECTOR_DVII, "DVI-I" },
>> @@ -990,10 +998,13 @@ struct type_name connector_type_names[] = {
>>  	{ DRM_MODE_CONNECTOR_eDP, "eDP" },
>>  	{ DRM_MODE_CONNECTOR_VIRTUAL, "Virtual" },
>>  	{ DRM_MODE_CONNECTOR_DSI, "DSI" },
>> +	{}
>>  };
>>  
>> -type_name_fn(connector_type)
>> -
>> +const char *kmstest_connector_type_str(int type)
>> +{
>> +	return find_type_name(connector_type_names, type);
>> +}
>>  
>>  /**
>>   * igt_lock_mem:
>> -- 
>> 2.1.4
>> 
>> _______________________________________________
>> Intel-gfx mailing list
>> Intel-gfx at lists.freedesktop.org
>> https://lists.freedesktop.org/mailman/listinfo/intel-gfx

-- 
Jani Nikula, Intel Open Source Technology Center


More information about the Intel-gfx mailing list