]> Repositories - hackapet/Adafruit_Blinka.git/blobdiff - src/digitalio.py
Merge pull request #183 from theacodes/master
[hackapet/Adafruit_Blinka.git] / src / digitalio.py
index 8fb53854a81e7d27637b3ea137606e3759dd0294..c02c4d51d8de45a5761f85418a17a63dd8d0a018 100755 (executable)
@@ -7,8 +7,36 @@ See `CircuitPython:digitalio` in CircuitPython for more details.
 * Author(s): cefn
 """
 
-from machine import Pin
-from adafruit_blinka.agnostic import board as boardId
+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.T210:
+    from adafruit_blinka.microcontroller.tegra.t210.pin import Pin
+elif detector.chip.T186:
+    from adafruit_blinka.microcontroller.tegra.t186.pin import Pin
+elif detector.chip.T194:
+    from adafruit_blinka.microcontroller.tegra.t194.pin import Pin
+elif detector.chip.S905:
+    from adafruit_blinka.microcontroller.amlogic.s905.pin import Pin
+elif detector.chip.S922X:
+    from adafruit_blinka.microcontroller.amlogic.s922x.pin import Pin
+elif detector.chip.APQ8016:
+    from adafruit_blinka.microcontroller.snapdragon.apq8016.pin import Pin
+elif detector.chip.IMX8MX:
+    from adafruit_blinka.microcontroller.nxp_imx8m.pin import Pin
+elif detector.board.ftdi_ft232h:
+    from adafruit_blinka.microcontroller.ft232h.pin import Pin
+elif detector.chip.STM32:
+    from machine import Pin
 from adafruit_blinka import Enum, ContextManaged
 
 class DriveMode(Enum):
@@ -106,7 +134,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: