]> Repositories - hackapet/Adafruit_Blinka.git/blobdiff - src/digitalio.py
Added individual jetson board and tegra chip integration
[hackapet/Adafruit_Blinka.git] / src / digitalio.py
old mode 100644 (file)
new mode 100755 (executable)
index 5598d58..0d9bc5b
@@ -1,8 +1,36 @@
-from machine import Pin
-from adafruit_blinka.agnostic import board as boardId
+"""
+`digitalio` - Digital input and output control
+=================================================
+
+See `CircuitPython:digitalio` in CircuitPython for more details.
+
+* Author(s): cefn
+"""
+
+from adafruit_blinka.agnostic import board_id, detector
+
+# pylint: disable=ungrouped-imports,wrong-import-position
+
+if detector.chip.BCM2XXX:
+    from adafruit_blinka.microcontroller.bcm283x.pin import Pin
+elif detector.chip.AM33XX:
+    from adafruit_blinka.microcontroller.am335x.pin import Pin
+elif detector.chip.SUN8I:
+    from adafruit_blinka.microcontroller.allwinner_h3.pin import Pin
+elif detector.chip.SAMA5:
+    from adafruit_blinka.microcontroller.sama5.pin import Pin
+elif detector.chip.TEGRA_TX1:
+    from adafruit_blinka.microcontroller.tegra.tx1.pin import Pin
+elif detector.chip.TEGRA_TX2:
+    from adafruit_blinka.microcontroller.tegra.tx2.pin import Pin
+elif detector.chip.TEGRA_XAVIER:
+    from adafruit_blinka.microcontroller.tegra.xavier.pin import Pin
+elif detector.chip.TEGRA_TXX:
+    from adafruit_blinka.microcontroller.tegra.txx.pin import Pin
+elif detector.chip.STM32:
+    from machine import Pin
 from adafruit_blinka import Enum, ContextManaged
 
-
 class DriveMode(Enum):
     PUSH_PULL = None
     OPEN_DRAIN = None
@@ -98,7 +126,7 @@ class DigitalInOut(ContextManaged):
                     self._pin.init(mode=Pin.IN, pull=Pin.PULL_DOWN)
                 else:
                     raise NotImplementedError("{} unsupported on {}".format(
-                        Pull.DOWN, boardId))
+                        Pull.DOWN, board_id))
             elif pul is None:
                 self._pin.init(mode=Pin.IN, pull=None)
             else:
@@ -120,6 +148,3 @@ class DigitalInOut(ContextManaged):
             self._pin.init(mode=Pin.OPEN_DRAIN)
         elif mod is DriveMode.PUSH_PULL:
             self._pin.init(mode=Pin.OUT)
-
-
-# __all__ = ['DigitalInOut', 'DriveMode', 'Direction','Pull']