]> Repositories - hackapet/Adafruit_Blinka.git/blobdiff - src/digitalio.py
jetson integration
[hackapet/Adafruit_Blinka.git] / src / digitalio.py
index 40f42ad24964da35b465de0a2bb28463d4896468..a64a750ef90bc8b72a047fcba6a0013942295b6f 100755 (executable)
@@ -7,14 +7,21 @@ See `CircuitPython:digitalio` in CircuitPython for more details.
 * Author(s): cefn
 """
 
-from adafruit_blinka.agnostic import board_id
-if board_id == "raspi_3" or board_id == "raspi_2":
-    from adafruit_blinka.microcontroller.raspi_23.pin import Pin
-elif board_id == "beaglebone_black":
-    from adafruit_blinka.microcontroller.beaglebone_black.pin import Pin
-elif board_id == "orangepipc":
+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 board_id == "pyboard":
+elif detector.chip.SAMA5:
+    from adafruit_blinka.microcontroller.sama5.pin import Pin
+elif detector.chip.TEGRAXXX:
+    from adafruit_blinka.microcontroller.tegra.pin import Pin
+elif detector.chip.STM32:
     from machine import Pin
 from adafruit_blinka import Enum, ContextManaged
 
@@ -47,7 +54,6 @@ Pull.DOWN = Pull()
 
 #Pull.NONE = Pull()
 
-
 class DigitalInOut(ContextManaged):
     _pin = None
 
@@ -67,6 +73,9 @@ class DigitalInOut(ContextManaged):
     def deinit(self):
         del self._pin
 
+    def cleanup(self, channel=None):
+        Pin.cleanup(self, channel)
+
     @property
     def direction(self):
         return self.__direction
@@ -113,7 +122,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: