]> Repositories - Adafruit_Blinka-hackapet.git/blob - src/adafruit_blinka/microcontroller/ft232h/pin.py
18c5e3164959611b9e23ca3be1d4c8edf207e792
[Adafruit_Blinka-hackapet.git] / src / adafruit_blinka / microcontroller / ft232h / pin.py
1 """FT232H pin names"""
2
3
4 class Pin:
5     """A basic Pin class for use with FT232H."""
6
7     IN = 0
8     OUT = 1
9     LOW = 0
10     HIGH = 1
11     PULL_NONE = 0
12     PULL_UP = 1
13     PULL_DOWN = 2
14
15     ft232h_gpio = None
16
17     def __init__(self, pin_id=None):
18         # setup GPIO controller if not done yet
19         # use one provided by I2C as default
20         if not Pin.ft232h_gpio:
21             # pylint: disable=import-outside-toplevel
22             from pyftdi.i2c import I2cController
23
24             # pylint: enable=import-outside-toplevel
25
26             i2c = I2cController()
27             i2c.configure("ftdi://ftdi:ft232h/1")
28             Pin.ft232h_gpio = i2c.get_gpio()
29         # check if pin is valid
30         if pin_id:
31             if Pin.ft232h_gpio.all_pins & 1 << pin_id == 0:
32                 raise ValueError("Can not use pin {} as GPIO.".format(pin_id))
33         # ID is just bit position
34         self.id = pin_id
35
36     def init(self, mode=IN, pull=None):
37         """Initialize the Pin"""
38         if not self.id:
39             raise RuntimeError("Can not init a None type pin.")
40         # FT232H does't have configurable internal pulls?
41         if pull:
42             raise NotImplementedError(
43                 "Internal pull up/down not currently supported.")
44         pin_mask = Pin.ft232h_gpio.pins | 1 << self.id
45         current = Pin.ft232h_gpio.direction
46         if mode == self.OUT:
47             current |= 1 << self.id
48         else:
49             current &= ~(1 << self.id)
50         Pin.ft232h_gpio.set_direction(pin_mask, current)
51
52     def value(self, val=None):
53         """Set or return the Pin Value"""
54         if not self.id:
55             raise RuntimeError("Can not access a None type pin.")
56         current = Pin.ft232h_gpio.read(with_output=True)
57         # read
58         if val is None:
59             return 1 if current & 1 << self.id != 0 else 0
60         # write
61         if val in (self.LOW, self.HIGH):
62             if val == self.HIGH:
63                 current |= 1 << self.id
64             else:
65                 current &= ~(1 << self.id)
66             # must mask out any input pins
67             Pin.ft232h_gpio.write(current & Pin.ft232h_gpio.direction)
68             return None
69         # release the kraken
70         raise RuntimeError("Invalid value for pin")
71
72
73 # create pin instances for each pin
74 # D0 to D3 are used by I2C/SPI
75 D4 = Pin(4)
76 D5 = Pin(5)
77 D6 = Pin(6)
78 D7 = Pin(7)
79 C0 = Pin(8)
80 C1 = Pin(9)
81 C2 = Pin(10)
82 C3 = Pin(11)
83 C4 = Pin(12)
84 C5 = Pin(13)
85 C6 = Pin(14)
86 C7 = Pin(15)
87 # C8 and C9 are not GPIO
88
89 # create None type pins for I2C and SPI since they are expected to be defined
90 SCL = Pin()
91 SDA = Pin()
92 SCK = SCLK = Pin()
93 MOSI = Pin()
94 MISO = Pin()