X-Git-Url: https://git.ayoreis.com/hackapet/Adafruit_Blinka.git/blobdiff_plain/240cf176db41d86036b6dc1a70b45c1bd9a0eae7..53235694da3c8c72ce90a80e5d88bb098045bff5:/src/busio.py diff --git a/src/busio.py b/src/busio.py index ede1e6c..d4571c4 100755 --- a/src/busio.py +++ b/src/busio.py @@ -11,7 +11,8 @@ import threading from adafruit_blinka import Enum, Lockable, agnostic from adafruit_blinka.agnostic import board_id, detector -import adafruit_platformdetect.board as ap_board +import adafruit_platformdetect.constants.boards as ap_board +import adafruit_platformdetect.constants.chips as ap_chip class I2C(Lockable): def __init__(self, scl, sda, frequency=400000): @@ -21,7 +22,15 @@ class I2C(Lockable): self.deinit() if detector.board.ftdi_ft232h: from adafruit_blinka.microcontroller.ft232h.i2c import I2C - self._i2c = I2C() + self._i2c = I2C(frequency=frequency) + return + elif detector.board.binho_nova: + from adafruit_blinka.microcontroller.nova.i2c import I2C + self._i2c = I2C(frequency=frequency) + return + elif detector.board.microchip_mcp2221: + from adafruit_blinka.microcontroller.mcp2221.i2c import I2C + self._i2c = I2C(frequency=frequency) return elif detector.board.any_embedded_linux: from adafruit_blinka.microcontroller.generic_linux.i2c import I2C as _I2C @@ -91,6 +100,12 @@ class SPI(Lockable): self._spi = _SPI() self._pins = (SCK, MOSI, MISO) return + elif detector.board.binho_nova: + from adafruit_blinka.microcontroller.nova.spi import SPI as _SPI + from adafruit_blinka.microcontroller.nova.pin import SCK, MOSI, MISO + self._spi = _SPI(clock) + self._pins = (SCK, MOSI, MISO) + return elif detector.board.any_embedded_linux: from adafruit_blinka.microcontroller.generic_linux.spi import SPI as _SPI else: @@ -115,8 +130,8 @@ class SPI(Lockable): elif detector.board.any_beaglebone: from adafruit_blinka.microcontroller.am335x.pin import Pin from adafruit_blinka.microcontroller.generic_linux.spi import SPI as _SPI - elif board_id == ap_board.ORANGE_PI_PC or board_id == ap_board.ORANGE_PI_R1 or board_id == ap_board.ORANGE_PI_ZERO: - from adafruit_blinka.microcontroller.allwinner_h3.pin import Pin + elif detector.board.any_orange_pi and detector.chip.id == ap_chip.SUN8I: + from adafruit_blinka.microcontroller.allwinner.h3.pin import Pin from adafruit_blinka.microcontroller.generic_linux.spi import SPI as _SPI elif board_id == ap_board.GIANT_BOARD: from adafruit_blinka.microcontroller.sama5.pin import Pin @@ -142,9 +157,19 @@ class SPI(Lockable): elif board_id == ap_board.JETSON_XAVIER: from adafruit_blinka.microcontroller.generic_linux.spi import SPI as _SPI from adafruit_blinka.microcontroller.tegra.t194.pin import Pin + elif detector.board.SIFIVE_UNLEASHED: + from adafruit_blinka.microcontroller.generic_linux.spi import SPI as _SPI + from adafruit_blinka.microcontroller.hfu540.pin import Pin elif detector.board.ftdi_ft232h: from adafruit_blinka.microcontroller.ft232h.spi import SPI as _SPI from adafruit_blinka.microcontroller.ft232h.pin import Pin + elif detector.board.binho_nova: + from adafruit_blinka.microcontroller.nova.spi import SPI as _SPI + from adafruit_blinka.microcontroller.nova.pin import Pin + elif board_id == ap_board.PINE64 or board_id == ap_board.PINEBOOK or board_id == ap_board.PINEPHONE: + from adafruit_blinka.microcontroller.allwinner.a64.pin import Pin + from adafruit_blinka.microcontroller.generic_linux.spi import SPI as _SPI + else: from machine import SPI as _SPI from machine import Pin @@ -204,9 +229,15 @@ class UART(Lockable): flow=None): if detector.board.any_embedded_linux: raise RuntimeError('busio.UART not supported on this platform. Please use pyserial instead.') + elif detector.board.binho_nova: + from adafruit_blinka.microcontroller.nova.uart import UART as _UART else: from machine import UART as _UART - from microcontroller.pin import uartPorts + + if detector.board.binho_nova: + from adafruit_blinka.microcontroller.nova.pin import uartPorts + else: + from microcontroller.pin import uartPorts self.baudrate = baudrate @@ -244,6 +275,8 @@ class UART(Lockable): ) def deinit(self): + if detector.board.binho_nova: + self._uart.deinit() self._uart = None def read(self, nbytes=None):