On Tuesday 25 November 2008, Eric Miao wrote: > Using a bit mask will be more generic if the GPIOs are not contiguous. > Yet I still doubt this will be generic enough to be added to gpiolib. My expectation for this kind of mechanism was that systems who need to craft another parallel bus out of GPIO pins would be doing this with some system-specific utility functions. So my "is it generic enough" question is more at the level of "Are there enough Linux systems that need this sort of thing to justify generic support?". I happen not to have come across the need for such ganged access from Linux (yet). Whereas I've yet to use non-x86 Linux systems that don't need to manipulate individual GPIO pins... > The user of this gpio_set_value_bus() may assume too much about > the internal, e.g. how many GPIOs on the chip and whether these GPIOs > are contiguous or not, and whether this GPIO chip support bitwise > operations. Actually I would expect that to be addressed by the hardware designer. As in, if you're bitbanging a 16-bit parallel bus (plus several control signals -- chip select lines, address latch, r/w, etc) the board would be designed for efficient bitbanging, by taking care that the software bus ops aren't stupidly complex. So I guess I'm agreeing with Eric there: wanting this kind of stuff at all seems to imply being fairly low-down'n'dirty. Example, assuming a 32 bit GPIO bank, the data lines would probably be all adjacent and politely ordered by the board designer so that /* write a 16 bit value on the specfied data lines, * assuming the intermediate state doesn't matter... */ writew(0xffff << N, &bank->clear_bits); writew(value << N, &bank->set_bits); instead of needing to compute some complex permutation of those bits ... and similarly /* read a 16 bit value from the specified data lines */ value = 0xffff & (readw(&bank->read_bits) >> N); possibly after handshaking with the device on the other side about changing signal direction, again without permutation. But heck, maybe there just aren't that many adjacent GPIOs free, because of alternate functions that are used... ugh. Note also that this proposal only includes > > + void (*set_bus)(struct gpio_chip *chip, > > + unsigned offset, int values, > > + int bitwidth); not its sibling read operation. > Let's have a concrete example: what if the user gives a bunch of GPIOs > that crosses the chip boundary, say, GPIO29 - GPIO35 (with each chip > covering 32 GPIOs). I'd care more about the upper level operation being performed ... like the control protocol for passing the address of a word being read or written and then switching the bus from address to data read (or write) mode to get the word, then yielding the bus access. - Dave -- To unsubscribe from this list: send the line "unsubscribe linux-embedded" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html