diff options
Diffstat (limited to 'mpm/python')
-rw-r--r-- | mpm/python/usrp_mpm/sys_utils/sysfs_gpio.py | 36 |
1 files changed, 30 insertions, 6 deletions
diff --git a/mpm/python/usrp_mpm/sys_utils/sysfs_gpio.py b/mpm/python/usrp_mpm/sys_utils/sysfs_gpio.py index 668342592..b542123bc 100644 --- a/mpm/python/usrp_mpm/sys_utils/sysfs_gpio.py +++ b/mpm/python/usrp_mpm/sys_utils/sysfs_gpio.py @@ -229,12 +229,32 @@ class SysFSGPIO(object): self.log.trace("Reading value {} from `{}'...".format(read_value, value_path)) return read_value -class GPIOBank(object): +class GPIOBank: """ - Extension of a SysFSGPIO + Usability / convenience wrapper for GPIO banks accessed by SysFSGPIO + + This class is useful when: + - Accessing a GPIO bank that is hanging off of a SysFSGPIO node + - All pins in this bank are consecutive pins on the SysFSGPIO node + - The pins can be at an offset (i.e., do not have to start at pin 0 of the + SysFSGPIO node) + - The pins might have to be written/read as a whole + + For example, assume that a device has 8 GPIO pins, starting at pin 10. The + user wants to read all pins at once as a single byte: + + >>> gpio_bank = GPIOBank( + label_dict, # See SysFSGPIO for this parameter + 10, # Pin offset + 0xFF, # 8 pins. Must be consecutive ones! + 0x00) # All pins are readable + >>> if gpio_bank.get_all() == 3: + print("Pins 0 and 1 are high!") """ def __init__(self, uio_identifiers, offset, usemask, ddr): self._gpiosize = bin(usemask).count("1") + # Make sure the pins are all one: + assert (1 << self._gpiosize) == usemask+1 self._offset = offset self._ddr = ddr self._usemask = usemask @@ -256,29 +276,33 @@ class GPIOBank(object): Clear all pins """ for i in range(self._gpiosize): - self._gpios.reset(self._offset+i) + if self._ddr & i: + self._gpios.reset(self._offset+i) def reset(self, index): """ Clear a pin by index + + Read back a pin by index. See also SysFSGPIO.reset(). The DDR value for + this pin must be high. """ assert index in range(self._gpiosize) self._gpios.reset(self._offset + index) def get_all(self): """ - Read back all pins + Read back all pins. Pins with a DDR value of 1 ("output") are left zero. """ result = 0 for i in range(self._gpiosize): - if not (1<<i)&self._ddr: + if not (1<<i) & self._ddr: value = self._gpios.get(self._offset + i) result = (result << 1) | value return result def get(self, index): """ - Read back a pin by index + Read back a pin by index. See also SysFSGPIO.get() """ assert index in range(self._gpiosize) return self._gpios.get(self._offset + index) |