X-Git-Url: https://git.ayoreis.com/Adafruit_Blinka-hackapet.git/blobdiff_plain/8ab94af6ad8ad48831f85d4e25b6f34c1f904505..1e9d6aacedd0d0e541a3fbb71a403e0d17f4c2f9:/src/adafruit_blinka/microcontroller/nova/pin.py diff --git a/src/adafruit_blinka/microcontroller/nova/pin.py b/src/adafruit_blinka/microcontroller/nova/pin.py index 30dbc66..945de25 100644 --- a/src/adafruit_blinka/microcontroller/nova/pin.py +++ b/src/adafruit_blinka/microcontroller/nova/pin.py @@ -1,80 +1,55 @@ class Pin: - """A basic Pin class for use with FT232H.""" + """A basic Pin class for use with Binho Nova.""" - IN = 0 - OUT = 1 + IN = 'DIN' + OUT = 'DOUT' + AIN = 'AIN' + AOUT = 'AOUT' + PWM = 'PWM' LOW = 0 HIGH = 1 - ft232h_gpio = None + _nova = None def __init__(self, pin_id=None): - # setup GPIO controller if not done yet - # use one provided by I2C as default - if not Pin.ft232h_gpio: - from pyftdi.i2c import I2cController - i2c = I2cController() - i2c.configure("ftdi:///1") - Pin.ft232h_gpio = i2c.get_gpio() + if not Pin._nova: + from binhoHostAdapter import binhoHostAdapter + from binhoHostAdapter import binhoUtilities + + utilities = binhoUtilities.binhoUtilities() + devices = utilities.listAvailableDevices() + + if len(devices) > 0: + Pin._nova = binhoHostAdapter.binhoHostAdapter(devices[0]) # check if pin is valid - if pin_id: - if Pin.ft232h_gpio.all_pins & 1 << pin_id == 0: - raise ValueError("Can not use pin {} as GPIO.".format(pin_id)) - # ID is just bit position + if pin_id > 4: + raise ValueError("Invalid pin {}.".format(pin_id)) + self.id = pin_id def init(self, mode=IN, pull=None): - if not self.id: + if self.id is None: raise RuntimeError("Can not init a None type pin.") - # FT232H does't have configurable internal pulls? + # Nova does't have configurable internal pulls for if pull: raise ValueError("Internal pull up/down not currently supported.") - pin_mask = Pin.ft232h_gpio.pins | 1 << self.id - current = Pin.ft232h_gpio.direction - if mode == self.OUT: - current |= 1 << self.id - else: - current &= ~(1 << self.id) - Pin.ft232h_gpio.set_direction(pin_mask, current) + Pin._nova.setIOpinMode(self.id, mode) def value(self, val=None): - if not self.id: + if self.id is None: raise RuntimeError("Can not access a None type pin.") - current = Pin.ft232h_gpio.read(with_output=True) # read if val is None: - return 1 if current & 1 << self.id != 0 else 0 + return int(Pin._nova.getIOpinValue(self.id).split('VALUE ')[1]) # write elif val in (self.LOW, self.HIGH): - if val == self.HIGH: - current |= 1 << self.id - else: - current &= ~(1 << self.id) - # must mask out any input pins - Pin.ft232h_gpio.write(current & Pin.ft232h_gpio.direction) - # release the kraken + Pin._nova.setIOpinValue(self.id, val) else: raise RuntimeError("Invalid value for pin") # create pin instances for each pin -# D0 to D3 are used by I2C/SPI -D4 = Pin(4) -D5 = Pin(5) -D6 = Pin(6) -D7 = Pin(7) -C0 = Pin(8) -C1 = Pin(9) -C2 = Pin(10) -C3 = Pin(11) -C4 = Pin(12) -C5 = Pin(13) -C6 = Pin(14) -C7 = Pin(15) -# C8 and C9 are not GPIO - -# create None type pins for I2C and SPI since they are expected to be defined -SCL = Pin() -SDA = Pin() -SCK = SCLK = Pin() -MOSI = Pin() -MISO = Pin() +IO0 = Pin(0) +IO1 = Pin(1) +IO2 = Pin(2) +IO3 = Pin(3) +IO4 = Pin(4)