Re: [PATCH v3 1/3] iio: add struct declarations for iio types

From: Michael Riesch
Date: Mon Nov 28 2022 - 08:49:04 EST


Hi Gerald, Andy,

On 11/28/22 14:27, Andy Shevchenko wrote:
> On Mon, Nov 28, 2022 at 01:18:04PM +0100, Gerald Loacker wrote:
>> Am 25.11.2022 um 12:01 schrieb Andy Shevchenko:
>>> On Fri, Nov 25, 2022 at 12:45:06PM +0200, Andy Shevchenko wrote:
>>>> On Fri, Nov 25, 2022 at 09:35:24AM +0100, Gerald Loacker wrote:
>
> ...
>
>>>>> +struct iio_val_int_plus_micro {
>>>>> + int val_int;
>>>>> + int val_micro;
>>>>> +};
>>>
>>> Thinking more about naming, why not drop val_ completely?
>>>
>>> int integer;
>>> int micro;
>>>
>>> ?
>>
>> Yes, this sounds good to me. I think of adding only
>>
>> typedef struct {
>> int integer;
>> int micro;
>> } iio_val_int_plus_micro;

I think we actually want

struct iio_val_int_plus_micro {
int integer;
int micro;
};

here, right?

>> for now, and one can add similar structures when needed, like
>>
>> typedef struct {
>> int integer;
>> int nano;
>> } iio_val_int_plus_nano;

+1 for introducing things when they are actually used.

> It's a rule to use _t for typedef:s in the kernel. That's why
> I suggested to leave struct definition and only typedef the same structures
> (existing) to new names (if needed).

Andy, excuse our ignorance but we are not sure how this typedef approach
is supposed to look like...

>> or
>
>> typedef iio_val_int_plus_micro iio_val_int_plus_micro_db;

... because

#include <stdio.h>

struct iio_val_int_plus_micro {
int integer;
int micro;
};

typedef iio_val_int_plus_micro iio_val_int_plus_micro_db;

int main()
{
struct iio_val_int_plus_micro a = { .integer = 100, .micro = 10, };
struct iio_val_int_plus_micro_db b = { .integer = 20, .micro = 10, };
return 0;
}

won't compile.

> This is better as explained above.
>
>> If you think it's better to add them all, I can do that, of course.

Anyway, seeing that only struct iio_val_int_plus_micro is used at the
moment, I believe the best path forward is to introduce only this struct
and move on.

Best regards,
Michael

>>>>> +struct iio_val_int_plus_nano {
>>>>> + int val_int;
>>>>> + int val_nano;
>>>>> +};
>>>>> +
>>>>> +struct iio_val_int_plus_micro_db {
>>>>> + int val_int;
>>>>
>>>> int val_int_db; ?
>>>>
>>>>> + int val_micro_db;
>>>>> +};
>>>>
>>>> Actually why can't we simply do
>>>>
>>>> typedef iio_val_int_plus_micro_db iio_val_int_plus_micro;
>>>>
>>>> ?
>