X-Git-Url: https://git.ayoreis.com/Adafruit_Blinka-hackapet.git/blobdiff_plain/a6f8d38f78f2a34a092fddf12fb0a6211fff1b41..80dcbdfbfdfaf398c75faad746e36584d5879968:/src/busio.py diff --git a/src/busio.py b/src/busio.py index 2ebc23d..1dd9338 100644 --- a/src/busio.py +++ b/src/busio.py @@ -9,8 +9,6 @@ See `CircuitPython:busio` in CircuitPython for more details. * Author(s): cefn """ -import os - try: import threading except ImportError: @@ -56,10 +54,7 @@ class I2C(Lockable): self._i2c = _I2C(frequency=frequency) return - if ( - "BLINKA_FORCECHIP" in os.environ - and os.environ["BLINKA_FORCEBOARD"] == "GENERIC_AGNOSTIC_BOARD" - ): + if detector.board.OS_AGNOSTIC_BOARD: from adafruit_blinka.microcontroller.generic_agnostic_board.i2c import ( I2C as _I2C, ) @@ -136,6 +131,13 @@ class I2C(Lockable): I2C_KB2040 as _I2C, ) + self._i2c = _I2C(scl, sda, frequency=frequency) + return + if detector.board.radxa_x4_u2if: + from adafruit_blinka.microcontroller.rp2040_u2if.i2c import ( + I2C_Radxa_X4 as _I2C, + ) + self._i2c = _I2C(scl, sda, frequency=frequency) return if detector.chip.id == ap_chip.RP2040: @@ -156,6 +158,8 @@ class I2C(Lockable): frequency = None # Set to None if default to avoid triggering warning elif detector.board.ftdi_ft2232h: from adafruit_blinka.microcontroller.ftdi_mpsse.mpsse.i2c import I2C as _I2C + elif detector.board.ftdi_ft4232h: + from adafruit_blinka.microcontroller.ftdi_mpsse.mpsse.i2c import I2C as _I2C else: from adafruit_blinka.microcontroller.generic_micropython.i2c import ( I2C as _I2C, @@ -173,9 +177,8 @@ class I2C(Lockable): pass else: raise ValueError( - "No Hardware I2C on (scl,sda)={}\nValid I2C ports: {}".format( - (scl, sda), i2cPorts - ) + f"No Hardware I2C on (scl,sda)={(scl, sda)}\n" + f"Valid I2C ports: {i2cPorts}.\nMake sure I2C is enabled." ) if threading is not None: self._lock = threading.RLock() @@ -344,6 +347,14 @@ class SPI(Lockable): SPI_KB2040 as _SPI, ) + self._spi = _SPI(clock) # this is really all that's needed + self._pins = (clock, clock, clock) # will determine MOSI/MISO from clock + return + if detector.board.radxa_x4_u2if: + from adafruit_blinka.microcontroller.rp2040_u2if.spi import ( + SPI_Radxa_X4 as _SPI, + ) + self._spi = _SPI(clock) # this is really all that's needed self._pins = (clock, clock, clock) # will determine MOSI/MISO from clock return @@ -363,10 +374,9 @@ class SPI(Lockable): from adafruit_blinka.microcontroller.generic_linux.spi import SPI as _SPI elif detector.board.ftdi_ft2232h: from adafruit_blinka.microcontroller.ftdi_mpsse.mpsse.spi import SPI as _SPI - elif ( - "BLINKA_FORCECHIP" in os.environ - and os.environ["BLINKA_FORCEBOARD"] == "GENERIC_AGNOSTIC_BOARD" - ): + elif detector.board.ftdi_ft4232h: + from adafruit_blinka.microcontroller.ftdi_mpsse.mpsse.spi import SPI as _SPI + elif detector.board.OS_AGNOSTIC_BOARD: from adafruit_blinka.microcontroller.generic_agnostic_board.spi import ( SPI as _SPI, ) @@ -387,9 +397,8 @@ class SPI(Lockable): break else: raise ValueError( - "No Hardware SPI on (SCLK, MOSI, MISO)={}\nValid SPI ports:{}".format( - (clock, MOSI, MISO), spiPorts - ) + f"No Hardware SPI on (SCLK, MOSI, MISO)={(clock, MOSI, MISO)}\n" + f"Valid SPI ports: {spiPorts}.\nMake sure SPI is enabled." ) def configure(self, baudrate=100000, polarity=0, phase=0, bits=8): @@ -404,6 +413,10 @@ class SPI(Lockable): from adafruit_blinka.microcontroller.ftdi_mpsse.mpsse.spi import ( SPI as _SPI, ) + elif detector.board.ftdi_ft4232h: + from adafruit_blinka.microcontroller.ftdi_mpsse.mpsse.spi import ( + SPI as _SPI, + ) elif detector.board.binho_nova: from adafruit_blinka.microcontroller.nova.spi import SPI as _SPI elif detector.board.greatfet_one: @@ -442,6 +455,10 @@ class SPI(Lockable): ) elif detector.board.qtpy_u2if: from adafruit_blinka.microcontroller.rp2040_u2if.spi import SPI_QTPY as _SPI + elif detector.board.radxa_x4_u2if: + from adafruit_blinka.microcontroller.rp2040_u2if.spi import ( + SPI_Radxa_X4 as _SPI, + ) elif detector.chip.id == ap_chip.RP2040: from adafruit_blinka.microcontroller.rp2040.spi import SPI as _SPI elif detector.board.any_siemens_iot2000: @@ -449,6 +466,10 @@ class SPI(Lockable): from adafruit_blinka.microcontroller.am65xx.pin import Pin elif detector.board.any_embedded_linux: from adafruit_blinka.microcontroller.generic_linux.spi import SPI as _SPI + elif detector.board.OS_AGNOSTIC_BOARD: + from adafruit_blinka.microcontroller.generic_agnostic_board.spi import ( + SPI as _SPI, + ) else: from adafruit_blinka.microcontroller.generic_micropython.spi import ( SPI as _SPI,