From mboxrd@z Thu Jan 1 00:00:00 1970 From: linux@arm.linux.org.uk (Russell King - ARM Linux) Date: Sat, 15 Dec 2012 10:51:57 +0000 Subject: [PATCH RESEND 0/6 v10] gpio: Add block GPIO In-Reply-To: <50CBBB25.20002@antcom.de> References: <1355495185-24220-1-git-send-email-stigge@antcom.de> <50CB68AB.5070806@grandegger.com> <50CBBB25.20002@antcom.de> Message-ID: <20121215105157.GN14363@n2100.arm.linux.org.uk> To: linux-arm-kernel@lists.infradead.org List-Id: linux-arm-kernel.lists.infradead.org On Sat, Dec 15, 2012 at 12:49:57AM +0100, Roland Stigge wrote: > Without having an AT91 available right now, I guess the hardware > interface of this GPIO chip is different from the GPIO block API. While > the hardware has clear and set registers, the val parameter of > at91_gpiolib_set_block() should be interpreted as the actual output > values. See lpc32xx_gpo_set_block() for an example for handling set and > clear registers like this: First, set_bits and clear_bits words are > calculated from mask and val parameters, and finally written to the > respective hardware registers. > > Note that one .set_block() can result in writing both the set and clear > registers of the hardware when val contains both 0s and 1s in > respectively masked positions. Note also that if this is the same IP as found in SAM3N devices, that it's possible to write the bit values directly through the OWER/OWDR (output write enable register/disable register) plus the ODSR (output data status register) which will synchronously change the state of all the write-enabled output pins. That may be important for some applications.