RE: [PATCH 01/11] staging: comedi: core: introduce comedi_dio_insn_bits()

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thursday, August 29, 2013 9:37 AM, Ian Abbott wrote:
> On 2013-08-29 17:20, Hartley Sweeten wrote:
>> On Thursday, August 29, 2013 4:14 AM, Ian Abbott wrote:
>>> On 2013-08-28 21:26, H Hartley Sweeten wrote:
>>>> The (*insn_bits) functions for DIO and DO subdevices typically use
>>>> the subdevice 's->state' to hold the current state of the output
>>>> channels. The 'insn' passed to these functions, INSN_BITS, specifies
>>>> two parameters passed in the 'data'.
>>>>
>>>>     data[0] = 'mask', the channels to update
>>>>     data[1] = 'bits', the new state for the channels
>>>>
>>>> Introduce a helper function to handle this boilerplate.
>>>>
>>>> The function returns:
>>>>
>>>>     0 if there are no changes in the state
>>>>
>>>>     1 if the driver needs to update the hardware to a new state
>>>>
>>>> Signed-off-by: H Hartley Sweeten <hsweeten@xxxxxxxxxxxxxxxxxxx>
>>>> Cc: Ian Abbott <abbotti@xxxxxxxxx>
>>>> Cc: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx>

[snip]

>>>> +/**
>>>> + * comedi_dio_insn_bits() - boilerplate (*insn_bits) for DIO and DO subdevices.
>>>> + * @dev: comedi_device struct
>>>> + * @s: comedi_subdevice struct
>>>> + * @insn: comedi_insn struct
>>>> + * @data: parameters for the @insn
>>>> + */
>>>> +int comedi_dio_insn_bits(struct comedi_device *dev,
>>>> +			 struct comedi_subdevice *s,
>>>> +			 struct comedi_insn *insn,
>>>> +			 unsigned int *data)
>>>> +{
>>>> +	unsigned int mask = data[0];
>>>> +	unsigned int bits = data[1];
>>>> +
>>>> +	if (mask) {
>>>> +		s->state &= ~mask;
>>>> +		s->state |= (bits & mask);
>>>> +
>>>> +		return 1;
>>>> +	}
>>>> +	return 0;
>>>> +}
>>>> +EXPORT_SYMBOL_GPL(comedi_dio_insn_bits);
>>>> +
>>>
>>> I'm not convinced this achieves much.  It doesn't use the insn parameter
>>> at all.
>>
>> Well it does remove 302 lines of boilerplate code.
>>
>> The parameters for the function could be reduced to just.
>>
>> int comedi_dio_insn_bits(struct comedi_subdevice *s,
>> 			 unsigned int mask,
>> 			unsigned int bits)
>>
>> Then the callers could do:
>>
>> 	If (comedi_dio_insn_bits(s, data[0], data[1]) {
>> 		/* Update the hardware */
>> 	}
>>
>> But, I think just passing all the (*insn_bits) parameters is a bit cleaner.
>
> It just seemed a waste passing a parameter that is never used.  You 
> could still pass the data[] array as a pointer with the assumption that 
> it's 2 elements long.  (Or you could declare it as `unsigned int 
> data[2]` in the prototype.  I'm a little wary of using array syntax in 
> function prototypes but I suppose it allows some bounds checking during 
> static analysis.)

I could also add a sanity check of (insn->n) but it adds that overhead to every
call. 

Actually, the only place in the core that calls the (*insn_bits) is in comedi_fops.c
parse_insn(). In that function the sanity check of insn->n is already done.

To reduce the number of parameters I'll modify the patch to the reduced
form above.

>> To address your thought in PATCH 04/11, the return could be either the
>> raw 'mask' (data[0]) or the filtered mask (data[0] & s->io_bits).
>
> I suppose the filtered mask makes more sense, as that is what has been 
> used to mask the s->state changes.

I'll also return the filtered mask and leave all the conditional updates in
the drivers.

Hopefully I will be able to get the updated series posted later today.

Thanks,
Hartley

_______________________________________________
devel mailing list
devel@xxxxxxxxxxxxxxxxxxxxxx
http://driverdev.linuxdriverproject.org/mailman/listinfo/driverdev-devel




[Index of Archives]     [Linux Driver Backports]     [DMA Engine]     [Linux GPIO]     [Linux SPI]     [Video for Linux]     [Linux USB Devel]     [Linux Coverity]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]
  Powered by Linux