On Sun, Feb 14, 2016 at 05:31:14PM +0800, Jiang Qiu wrote: > 在 2016/2/5 19:09, Mark Brown 写道: > >On Fri, Feb 05, 2016 at 03:11:20PM +0800, qiujiang wrote: Please fix your mail client to word wrap within paragraphs at something substantially less than 80 columns. Doing this makes your messages much easier to read and reply to. Your mail has lines wrapped alternately at normal length and half length which is difficult to read, I've reflowed this time. > >>+ char propname[32]; > >That's a magic number, where did it come from and why is it a magic > >nummber? > I'm sorry for here without any comments. This number define is come from > gpiolib.c. It means the max size of gpio property name. The reference code > located in line 1815 of gpiolib.c. That really isn't helping here. The problem is that you've got a random magic number thrown in here with no documentation. > >I'm not seeing anywhere where we store the GPIO in this loop. It is > >therefore unclear to me how the chip select is going to work? > In DT binding, of_get_named_gpio and devm_gpio_request were used to > parse gpio pins defined in DTs and then request these pins. Similarly, > for ACPI, devm_gpiod_get can do that two operation in a single > function. It is a unified interface to ACPI and DT binding. > If the gpiod is valid, the corresponding gpio pins has been requested. > We do not need to save this gpiod any more. No, that makes no sense at all. If we're requesting a GPIO to use as chip select we can't just then ignore the GPIO, we need to control it at some point and... > which gpio pin was used is defined in spi_device, named cs_gpio, the > configuration to the gpio pins will be done in the setup callback > routine of each device. What the spi master should do is just request > these pins to the gpio subsystem. ...this would be a complete failure of abstraction - you appear to be suggesting that the client devices should also separately request the GPIOs and set them up. That's at best going to be redundant and is likely to introduce bugs.
Attachment:
signature.asc
Description: PGP signature