X-Git-Url: https://git.ayoreis.com/Adafruit_Blinka-hackapet.git/blobdiff_plain/681eb0a6e5da381b7035bb7a104e78e7bca9716b..c3bfd01efa31a426ec6eb258598b1871bb04a178:/src/microcontroller/__init__.py?ds=inline diff --git a/src/microcontroller/__init__.py b/src/microcontroller/__init__.py old mode 100755 new mode 100644 index da71099..8e7efe8 --- a/src/microcontroller/__init__.py +++ b/src/microcontroller/__init__.py @@ -1,3 +1,6 @@ +# SPDX-FileCopyrightText: 2021 Melissa LeBlanc-Williams for Adafruit Industries +# +# SPDX-License-Identifier: MIT """ `microcontroller` - Pin references and cpu functionality ======================================================== @@ -9,9 +12,9 @@ import sys import time from adafruit_platformdetect.constants import chips as ap_chip -from adafruit_blinka import Enum from adafruit_blinka.agnostic import board_id, chip_id -import microcontroller.pin +from microcontroller import pin # pylint: disable=unused-import +from microcontroller.pin import Pin # pylint: disable=unused-import def delay_us(delay): @@ -19,33 +22,6 @@ def delay_us(delay): time.sleep(delay / 1e6) -class Pin(Enum): - """ - Identifies an IO pin on the microcontroller. - - They are fixed by the hardware so they cannot be constructed on demand. Instead, use board or - microcontroller.pin to reference the desired pin. - """ - - def __init__(self, pin_id): - """Identifier for pin, referencing platform-specific pin id""" - self.id = pin_id - - def __repr__(self): - # pylint: disable=import-outside-toplevel, cyclic-import - import board - - for key in dir(board): - if getattr(board, key) is self: - return "board.{}".format(key) - # pylint: enable=import-outside-toplevel, cyclic-import - - for key in dir(microcontroller.pin): - if getattr(microcontroller.pin, key) is self: - return "microcontroller.pin.{}".format(key) - return repr(self) - - # We intentionally are patching into this namespace so skip the wildcard check. # pylint: disable=unused-wildcard-import,wildcard-import,ungrouped-imports @@ -68,8 +44,14 @@ elif chip_id == ap_chip.DRA74X: from adafruit_blinka.microcontroller.dra74x import * elif chip_id == ap_chip.AM33XX: from adafruit_blinka.microcontroller.am335x import * +elif chip_id == ap_chip.AM65XX: + from adafruit_blinka.microcontroller.am65xx import * elif chip_id == ap_chip.JH71x0: from adafruit_blinka.microcontroller.starfive.JH71x0 import * +elif chip_id == ap_chip.SUN4I: + from adafruit_blinka.microcontroller.allwinner.a10 import * +elif chip_id == ap_chip.SUN7I: + from adafruit_blinka.microcontroller.allwinner.a10 import * elif chip_id == ap_chip.SUN8I: from adafruit_blinka.microcontroller.allwinner.h3 import * elif chip_id == ap_chip.H5: @@ -86,16 +68,28 @@ elif chip_id == ap_chip.T186: from adafruit_blinka.microcontroller.tegra.t186 import * elif chip_id == ap_chip.T194: from adafruit_blinka.microcontroller.tegra.t194 import * +elif chip_id == ap_chip.T234: + from adafruit_blinka.microcontroller.tegra.t234 import * elif chip_id == ap_chip.S905: from adafruit_blinka.microcontroller.amlogic.s905 import * +elif chip_id == ap_chip.S905X: + from adafruit_blinka.microcontroller.amlogic.s905x import * elif chip_id == ap_chip.S905X3: from adafruit_blinka.microcontroller.amlogic.s905x3 import * +elif chip_id == ap_chip.S905Y2: + from adafruit_blinka.microcontroller.amlogic.s905y2 import * elif chip_id == ap_chip.S922X: from adafruit_blinka.microcontroller.amlogic.s922x import * +elif chip_id == ap_chip.A311D: + from adafruit_blinka.microcontroller.amlogic.a311d import * elif chip_id == ap_chip.EXYNOS5422: from adafruit_blinka.microcontroller.samsung.exynos5422 import * elif chip_id == ap_chip.APQ8016: from adafruit_blinka.microcontroller.snapdragon.apq8016 import * +elif chip_id == ap_chip.A10: + from adafruit_blinka.microcontroller.allwinner.a10 import * +elif chip_id == ap_chip.A20: + from adafruit_blinka.microcontroller.allwinner.a10 import * elif chip_id == ap_chip.A64: from adafruit_blinka.microcontroller.allwinner.a64 import * elif chip_id == ap_chip.A33: @@ -104,8 +98,12 @@ elif chip_id == ap_chip.RK3308: from adafruit_blinka.microcontroller.rockchip.rk3308 import * elif chip_id == ap_chip.RK3399: from adafruit_blinka.microcontroller.rockchip.rk3399 import * +elif chip_id == ap_chip.RK3588: + from adafruit_blinka.microcontroller.rockchip.rk3588 import * elif chip_id == ap_chip.RK3328: from adafruit_blinka.microcontroller.rockchip.rk3328 import * +elif chip_id == ap_chip.RK3566: + from adafruit_blinka.microcontroller.rockchip.rk3566 import * elif chip_id == ap_chip.H3: from adafruit_blinka.microcontroller.allwinner.h3 import * elif chip_id == ap_chip.H5: @@ -132,14 +130,22 @@ elif chip_id == ap_chip.FT2232H: from adafruit_blinka.microcontroller.ftdi_mpsse.ft2232h import * elif chip_id == ap_chip.PENTIUM_N3710: from adafruit_blinka.microcontroller.pentium.n3710 import * +elif chip_id == ap_chip.ATOM_J4105: + from adafruit_blinka.microcontroller.pentium.j4105 import * elif chip_id == ap_chip.STM32MP157: from adafruit_blinka.microcontroller.stm32.stm32mp157 import * elif chip_id == ap_chip.MT8167: from adafruit_blinka.microcontroller.mt8167 import * elif chip_id == ap_chip.RP2040_U2IF: from adafruit_blinka.microcontroller.rp2040_u2if import * +elif chip_id == ap_chip.D1_RISCV: + from adafruit_blinka.microcontroller.allwinner.D1 import * elif chip_id == ap_chip.GENERIC_X86: print("WARNING: GENERIC_X86 is not fully supported. Some features may not work.") +elif chip_id is None: + print( + "WARNING: chip_id == None is not fully supported. Some features may not work." + ) elif "sphinx" in sys.modules: pass else: