From: caternuson Date: Fri, 21 May 2021 20:59:34 +0000 (-0700) Subject: more u2if updates X-Git-Tag: 6.10.0~1^2~3 X-Git-Url: https://git.ayoreis.com/Adafruit_Blinka-hackapet.git/commitdiff_plain/4a1e028d30c9453d78483f8d71dc847fc2bfa2a9?ds=inline;hp=-c more u2if updates --- 4a1e028d30c9453d78483f8d71dc847fc2bfa2a9 diff --git a/src/adafruit_blinka/board/feather_u2if.py b/src/adafruit_blinka/board/feather_u2if.py index caf2a19..d8dd84a 100644 --- a/src/adafruit_blinka/board/feather_u2if.py +++ b/src/adafruit_blinka/board/feather_u2if.py @@ -41,4 +41,4 @@ MOSI = pin.GP19 MISO = pin.GP20 # access u2if via pin instance to open for specifc VID/PID -pin.GP0._u2if_open_hid(0x239A, 0x80F2) +pin.GP0._u2if_open_hid(0x239A, 0x00F1) diff --git a/src/adafruit_blinka/board/itsybitsy_u2if.py b/src/adafruit_blinka/board/itsybitsy_u2if.py new file mode 100644 index 0000000..f67c72a --- /dev/null +++ b/src/adafruit_blinka/board/itsybitsy_u2if.py @@ -0,0 +1,53 @@ +"""Pin definitions for the ItsyBitsy RP2040 with u2if firmware.""" + +""" +Adafruit CircuitPython 6.2.0 on 2021-04-05; Adafruit ItsyBitsy RP2040 with rp2040 +>>> import board +>>> board. +A0 A1 A2 A3 +BUTTON D0 D1 D10 +D11 D12 D13 D2 +D24 D25 D3 D4 +D5 D7 D9 I2C +LED MISO MOSI NEOPIXEL +NEOPIXEL_POWER RX SCK SCL +SDA SPI TX UART +""" + + +from adafruit_blinka.microcontroller.rp2040_u2if import pin + +D0 = pin.GP1 +D1 = pin.GP0 +D2 = pin.GP12 +D3 = pin.GP5 +D4 = pin.GP4 +D5 = pin.GP14 +D7 = pin.GP6 +D9 = pin.GP7 +D10 = pin.GP8 +D11 = pin.GP9 +D12 = pin.GP10 +D13 = pin.GP11 +D24 = pin.GP24 +D25 = pin.GP25 + +A0 = pin.GP26 +A1 = pin.GP27 +A2 = pin.GP28 +#A3 = pin.GP29 # not currently supported in firmware + +SCL = pin.GP3 +SDA = pin.GP2 + +SCLK = SCK = pin.GP18 +MOSI = pin.GP19 +MISO = pin.GP20 + +NEOPIXEL = pin.GP17 +NEOPIXEL_POWER = pin.GP16 + +BUTTON = pin.GP13 + +# access u2if via pin instance to open for specifc VID/PID +pin.GP0._u2if_open_hid(0x239A, 0x00FD) diff --git a/src/adafruit_blinka/board/qt2040_trinkey_u2if.py b/src/adafruit_blinka/board/qt2040_trinkey_u2if.py index 287a662..d48b71b 100644 --- a/src/adafruit_blinka/board/qt2040_trinkey_u2if.py +++ b/src/adafruit_blinka/board/qt2040_trinkey_u2if.py @@ -10,4 +10,4 @@ SDA = pin.GP16 NEOPIXEL = pin.GP27 # access u2if via pin instance to open for specifc VID/PID -pin.GP0._u2if_open_hid(0x239A, 0x13C0) +pin.GP0._u2if_open_hid(0x239A, 0x0109) diff --git a/src/adafruit_blinka/board/qtpy_u2if.py b/src/adafruit_blinka/board/qtpy_u2if.py index 0f52ff4..4a31d2c 100644 --- a/src/adafruit_blinka/board/qtpy_u2if.py +++ b/src/adafruit_blinka/board/qtpy_u2if.py @@ -50,4 +50,4 @@ NEOPIXEL_POWER = pin.GP11 BUTTON = pin.GP21 # access u2if via pin instance to open for specifc VID/PID -pin.GP0._u2if_open_hid(0x239A, 0x80F8) +pin.GP0._u2if_open_hid(0x239A, 0x00F7) diff --git a/src/adafruit_blinka/microcontroller/rp2040_u2if/analogio.py b/src/adafruit_blinka/microcontroller/rp2040_u2if/analogio.py index 51b365b..847a3c9 100644 --- a/src/adafruit_blinka/microcontroller/rp2040_u2if/analogio.py +++ b/src/adafruit_blinka/microcontroller/rp2040_u2if/analogio.py @@ -55,3 +55,11 @@ class AnalogIn_QTPY(AnalogIn): if pin.id not in (26, 27, 28): raise ValueError("Pin does not support ADC.") super().__init__(pin) + +class AnalogIn_ItsyBitsy(AnalogIn): + """AnalogIn Base Class for ItsyBitsy 2040 u2if""" + + def __init__(self, pin): + if pin.id not in (26, 27, 28): + raise ValueError("Pin does not support ADC.") + super().__init__(pin) \ No newline at end of file diff --git a/src/adafruit_blinka/microcontroller/rp2040_u2if/i2c.py b/src/adafruit_blinka/microcontroller/rp2040_u2if/i2c.py index ec836ce..551274b 100644 --- a/src/adafruit_blinka/microcontroller/rp2040_u2if/i2c.py +++ b/src/adafruit_blinka/microcontroller/rp2040_u2if/i2c.py @@ -83,7 +83,7 @@ class I2C_Feather(I2C): super().__init__(index, frequency=frequency) class I2C_QTPY(I2C): - """I2C Class for QT2040 Trinkey u2if""" + """I2C Class for QT Py 2if""" def __init__(self, scl, sda, *, frequency=100000): index = None @@ -97,6 +97,19 @@ class I2C_QTPY(I2C): super().__init__(index, frequency=frequency) +class I2C_ItsyBitsy(I2C): + """I2C Class for ItsyBitsy u2if""" + + def __init__(self, scl, sda, *, frequency=100000): + index = None + if scl.id == 3 and sda.id == 2: + index = 1 + if index is None: + raise ValueError("I2C not found on specified pins.") + self._index = index + + super().__init__(index, frequency=frequency) + class I2C_QT2040_Trinkey(I2C): """I2C Class for QT2040 Trinkey u2if""" diff --git a/src/adafruit_blinka/microcontroller/rp2040_u2if/spi.py b/src/adafruit_blinka/microcontroller/rp2040_u2if/spi.py index ef1161d..ea46c83 100644 --- a/src/adafruit_blinka/microcontroller/rp2040_u2if/spi.py +++ b/src/adafruit_blinka/microcontroller/rp2040_u2if/spi.py @@ -64,6 +64,7 @@ class SPI: # pylint: enable=too-many-arguments class SPI_Pico(SPI): + """SPI Class for Pico u2if""" def __init__(self, clock, *, baudrate=100000): index = None @@ -76,6 +77,7 @@ class SPI_Pico(SPI): super().__init__(index, baudrate=baudrate) class SPI_Feather(SPI): + """SPI Class for Feather u2if""" def __init__(self, clock, *, baudrate=100000): index = None @@ -86,6 +88,7 @@ class SPI_Feather(SPI): super().__init__(index, baudrate=baudrate) class SPI_QTPY(SPI): + """SPI Class for QT Py u2if""" def __init__(self, clock, *, baudrate=100000): index = None @@ -93,4 +96,15 @@ class SPI_QTPY(SPI): index = 0 if index is None: raise ValueError("No SPI port on specified pin.") + super().__init__(index, baudrate=baudrate) + +class SPI_ItsyBitsy(SPI): + """SPI Class for ItsyBitsy u2if""" + + def __init__(self, clock, *, baudrate=100000): + index = None + if clock.id == 18: + index = 0 + if index is None: + raise ValueError("No SPI port on specified pin.") super().__init__(index, baudrate=baudrate) \ No newline at end of file diff --git a/src/analogio.py b/src/analogio.py index e6837b3..3cff6b4 100644 --- a/src/analogio.py +++ b/src/analogio.py @@ -35,5 +35,7 @@ elif detector.board.feather_u2if: from adafruit_blinka.microcontroller.rp2040_u2if.analogio import AnalogIn_Feather as AnalogIn elif detector.board.qtpy_u2if: from adafruit_blinka.microcontroller.rp2040_u2if.analogio import AnalogIn_QTPY as AnalogIn +elif detector.board.itsybitsy_u2if: + from adafruit_blinka.microcontroller.rp2040_u2if.analogio import AnalogIn_ItsyBitsy as AnalogIn else: raise NotImplementedError("analogio not supported for this board.") diff --git a/src/board.py b/src/board.py index 9bcc022..eb5e7d9 100755 --- a/src/board.py +++ b/src/board.py @@ -233,6 +233,9 @@ elif board_id == ap_board.FEATHER_U2IF: elif board_id == ap_board.QTPY_U2IF: from adafruit_blinka.board.qtpy_u2if import * +elif board_id == ap_board.ITSYBITSY_U2IF: + from adafruit_blinka.board.itsybitsy_u2if import * + elif board_id == ap_board.QT2040_TRINKEY_U2IF: from adafruit_blinka.board.qt2040_trinkey_u2if import * diff --git a/src/busio.py b/src/busio.py index 8dcf6ab..f8598a5 100755 --- a/src/busio.py +++ b/src/busio.py @@ -66,6 +66,11 @@ class I2C(Lockable): if detector.board.qtpy_u2if: from adafruit_blinka.microcontroller.rp2040_u2if.i2c import I2C_QTPY as _I2C + self._i2c = _I2C(scl, sda, frequency=frequency) + return + if detector.board.itsybitsy_u2if: + from adafruit_blinka.microcontroller.rp2040_u2if.i2c import I2C_ItsyBitsy as _I2C + self._i2c = _I2C(scl, sda, frequency=frequency) return if detector.board.qt2040_trinkey_u2if: @@ -215,6 +220,12 @@ class SPI(Lockable): if detector.board.feather_u2if: from adafruit_blinka.microcontroller.rp2040_u2if.spi import SPI_Feather 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.itsybitsy_u2if: + from adafruit_blinka.microcontroller.rp2040_u2if.spi import SPI_ItsyBitsy 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 @@ -331,6 +342,10 @@ class SPI(Lockable): from adafruit_blinka.microcontroller.rp2040_u2if.spi import SPI_Pico as _SPI elif detector.board.feather_u2if: from adafruit_blinka.microcontroller.rp2040_u2if.spi import SPI_Feather as _SPI + elif detector.board.itsybitsy_u2if: + from adafruit_blinka.microcontroller.rp2040_u2if.spi import SPI_ItsyBitsy as _SPI + elif detector.board.qtpy_u2if: + from adafruit_blinka.microcontroller.rp2040_u2if.spi import SPI_QTPY as _SPI elif detector.chip.id == ap_chip.RP2040: from adafruit_blinka.microcontroller.rp2040.spi import SPI as _SPI else: diff --git a/src/digitalio.py b/src/digitalio.py index d67e6f6..c1aa7c3 100755 --- a/src/digitalio.py +++ b/src/digitalio.py @@ -83,11 +83,8 @@ elif detector.chip.H616: from adafruit_blinka.microcontroller.allwinner.h616.pin import Pin elif detector.board.pico_u2if: from adafruit_blinka.microcontroller.rp2040_u2if.pin import Pin -elif detector.board.feather_u2if: - from adafruit_blinka.microcontroller.rp2040_u2if.pin import Pin -elif detector.board.qtpy_u2if: - from adafruit_blinka.microcontroller.rp2040_u2if.pin import Pin -elif detector.board.qt2040_trinkey_u2if: +elif detector.board.feather_u2if or detector.board.qtpy_u2if or \ + detector.board.itsybitsy_u2if or detector.board.qt2040_trinkey_u2if: from adafruit_blinka.microcontroller.rp2040_u2if.pin import Pin from adafruit_blinka import Enum, ContextManaged diff --git a/src/neopixel_write.py b/src/neopixel_write.py index d024bec..8ab506b 100644 --- a/src/neopixel_write.py +++ b/src/neopixel_write.py @@ -14,8 +14,10 @@ from adafruit_blinka.agnostic import detector if detector.board.any_raspberry_pi: from adafruit_blinka.microcontroller.bcm283x import neopixel as _neopixel -elif detector.board.pico_u2if or detector.board.feather_u2if or \ - detector.board.qtpy_u2if or detector.board.qt2040_trinkey_u2if: +elif detector.board.pico_u2if: + from adafruit_blinka.microcontroller.rp2040_u2if import neopixel as _neopixel +elif detector.board.feather_u2if or detector.board.qtpy_u2if or \ + detector.board.itsybitsy_u2if or detector.board.qt2040_trinkey_u2if: from adafruit_blinka.microcontroller.rp2040_u2if import neopixel as _neopixel elif "sphinx" in sys.modules: pass diff --git a/src/pwmio.py b/src/pwmio.py index 5b5fb39..f9c2394 100644 --- a/src/pwmio.py +++ b/src/pwmio.py @@ -31,7 +31,8 @@ elif detector.board.any_lubancat: from adafruit_blinka.microcontroller.generic_linux.sysfs_pwmout import PWMOut elif detector.board.pico_u2if: from adafruit_blinka.microcontroller.rp2040_u2if.pwmio import PWMOut -elif detector.board.feather_u2if: +elif detector.board.feather_u2if or detector.board.qtpy_u2if or \ + detector.board.itsybitsy_u2if or detector.board.qt2040_trinkey_u2if: from adafruit_blinka.microcontroller.rp2040_u2if.pwmio import PWMOut elif "sphinx" in sys.modules: pass