X-Git-Url: https://git.ayoreis.com/hackapet/Adafruit_Blinka.git/blobdiff_plain/e7fee263ecca5ed166b9d3cef21c366d7c665b9f..998befb5d068ea8dfadf17cd9196857dc36d9b0b:/src/busio.py?ds=sidebyside diff --git a/src/busio.py b/src/busio.py index 3d786ac..302eb88 100755 --- a/src/busio.py +++ b/src/busio.py @@ -8,7 +8,7 @@ See `CircuitPython:busio` in CircuitPython for more details. """ from adafruit_blinka import Enum, Lockable, agnostic -from adafruit_blinka.agnostic import board as boardId +from adafruit_blinka.agnostic import board_id class I2C(Lockable): def __init__(self, scl, sda, frequency=400000): @@ -16,7 +16,7 @@ class I2C(Lockable): def init(self, scl, sda, frequency): self.deinit() - if boardId == "raspi_3" or boardId == "raspi_2": + if board_id == "raspi_3" or board_id == "raspi_2": from adafruit_blinka.microcontroller.raspi_23.i2c import I2C as _I2C else: from machine import I2C as _I2C @@ -63,27 +63,38 @@ class I2C(Lockable): class SPI(Lockable): def __init__(self, clock, MOSI=None, MISO=None): + self.deinit() + if board_id == "raspi_3" or board_id == "raspi_2": + from adafruit_blinka.microcontroller.raspi_23.spi import SPI as _SPI + else: + from machine import SPI as _SPI from microcontroller.pin import spiPorts for portId, portSck, portMosi, portMiso in spiPorts: if clock == portSck and MOSI == portMosi and MISO == portMiso: - self._spi = SPI(portId) + self._spi = _SPI(portId) self._pins = (portSck, portMosi, portMiso) break else: raise NotImplementedError( - "No Hardware SPI on (clock, MOSI, MISO)={}\nValid SPI ports:{}". + "No Hardware SPI on (SCLK, MOSI, MISO)={}\nValid SPI ports:{}". format((clock, MOSI, MISO), spiPorts)) def configure(self, baudrate=100000, polarity=0, phase=0, bits=8): - if self._locked: + if board_id == "raspi_3" or board_id == "raspi_2": + from adafruit_blinka.microcontroller.raspi_23.spi import SPI as _SPI + from adafruit_blinka.microcontroller.raspi_23.pin import Pin + else: + from machine import SPI as _SPI from machine import Pin + + if self._locked: # TODO check if #init ignores MOSI=None rather than unsetting, to save _pinIds attribute self._spi.init( baudrate=baudrate, polarity=polarity, phase=phase, bits=bits, - firstbit=SPI.MSB, + firstbit=_SPI.MSB, sck=Pin(self._pins[0].id), mosi=Pin(self._pins[1].id), miso=Pin(self._pins[2].id) @@ -99,10 +110,10 @@ class SPI(Lockable): return self._spi.write(buf) def readinto(self, buf): - return self.readinto(buf) + return self._spi.readinto(buf) def write_readinto(self, buffer_out, buffer_in): - return self.write_readinto(buffer_out, buffer_in) + return self._spi.write_readinto(buffer_out, buffer_in) class UART(Lockable):