gpiospi modification
Details
Diff Detail
- Lint
- Lint Passed 
- Unit
- No Test Coverage 
- Build Status
- Buildable 6207 - Build 6455: arc lint + arc unit 
Event Timeline
| sys/dev/gpio/gpiospi.c | ||
|---|---|---|
| 159 | If driver do not support PullUp/PullDown, then why it makes problem? | |
gpiobus_pin_setflags() in gpibus.c have check gpio_check_flags(). This code check pin capabirity. If low driver not support GPIO_PIN_PULLUP/GPIO_PIN_PULLDOWN return EINVAL.
Then better to set it as supported by driver, and ignore them in driver. Otherwise other controllers who support pullup/pulldown will have unpredictable results on that lines, because nobody said to pull it.
I seem GPIO_PIN_PULLUP/GPIO_PIN_PULLDOWN not set in any sys/mips/ gpio code. And gpioiic.c not use GPIO_PIN_PULLUP/GPIO_PIN_PULLDOWN that is same bitbang code . I think better not use in gpiospi.c rather than low driver ignore.
If ignore GPIO_PIN_PULLUP/GPIO_PIN_PULLDOWN in low driver then GPIO_PIN_PULLUP/GPIO_PIN_PULLDOWN flag have no meaning in a system.
Thanks for your contribution!
Generally speaking, it looks fine. 
To satisfy both cases (with and wo pulling) it may be worth to make pulling configurable (and make default is off).
@yamori813_yahoo.co.jp with i2c the bus hardware must have pullups (required by standard). This is why I haven't added it to gpioiic (but maybe I should...).
It is safe to ignore pullup/pulldown in gpio driver, they will have no meaning for that specific gpio controller, if you have a different controller they can still be used.
The check in gpio_check_flags() is wrong, I going to fix it. Thanks!
| sys/dev/gpio/gpiospi.c | ||
|---|---|---|
| 316 | The delays still seem wrong to me, see: https://en.wikipedia.org/wiki/Serial_Peripheral_Interface_Bus We have to take the phase into account. | |
| sys/dev/spibus/spibus.c | ||
| 120–122 | Correct. | |
| sys/mips/atheros/ar531x/ar5315_spi.c | ||
| 125 | Correct, please commit. | |
I check this code on my develop SPI module code that is ksz8995ma ether switch chip and FON2100. This case delay is fixed problem and work. I check signal enclose picture. If no delay clock is not to zero.
This is my setting hints.
hint.gpiospi.0.at="gpiobus0"
hint.gpiospi.0.pins=0x9a
hint.gpiospi.0.cs0=0
hint.gpiospi.0.sclk=3
hint.gpiospi.0.mosi=1
hint.gpiospi.0.miso=2
hint.gpiospi.0.freq=100000000
yeah, this delay() fixes the clock output, but what I am saying is that data and clock should come out with a 90o phase difference. your patch doesn't not fix this but it is surely an improvement (you can commit this change too).
gpio_check_flags() should be fixed after r310000: https://svnweb.freebsd.org/changeset/base/310000
thanks!
Why delete my added gpio_delay() in gpiospi.c ? My KSZ8995MA code don't work no gpio_delay() on my target. I think current code clock is wrong.
Hi Hiroki-san,
gpio_delay has been committed by next commit in sequence: https://github.com/freebsd/freebsd/commit/1ea50c0b5014d04d2b8586d6efd258abe411d87f
I suppose Phabricator doesn't track commits for already closed reviews (smells like possible improvement ;).

