]> Repositories - Adafruit_Blinka-hackapet.git/commitdiff
add SPI frequency property
authorcaternuson <caternuson@gmail.com>
Fri, 11 Oct 2019 00:43:13 +0000 (17:43 -0700)
committercaternuson <caternuson@gmail.com>
Fri, 11 Oct 2019 00:43:13 +0000 (17:43 -0700)
src/adafruit_blinka/microcontroller/ft232h/spi.py
src/adafruit_blinka/microcontroller/generic_linux/spi.py
src/busio.py

index 9ae57512233c1f6dce07f512e6194a7e753dc8c1..2d42ae0da8d546c9c4132d3e2730c3917e2f546e 100644 (file)
@@ -3,55 +3,47 @@ from adafruit_blinka.microcontroller.ft232h.pin import Pin
 class SPI:
     MSB = 0
 
-    baudrate = 100000
-    mode = 0
-    bits = 8
-
     def __init__(self):
-        # change GPIO controller to SPI
         from pyftdi.spi import SpiController
         self._spi = SpiController(cs_count=1)
         self._spi.configure('ftdi:///1')
+        self._port = self._spi.get_port(0)
+        self._port.set_frequency(100000)
+        self._port._cpol = 0
+        self._port._cpha = 0
+        # Change GPIO controller to SPI
         Pin.ft232h_gpio = self._spi.get_gpio()
 
     def init(self, baudrate=100000, polarity=0, phase=0, bits=8,
                   firstbit=MSB, sck=None, mosi=None, miso=None):
-        self.cs = 0
-        self.freq = baudrate
-        if polarity == 0 and phase == 0:
-            self.mode = 0
-        elif polarity == 0 and phase == 1:
-            self.mode = 1
-        elif polarity == 1 and phase == 0:
-            raise ValueError("SPI mode 2 is not supported.")
-        elif polarity == 1 and phase == 1:
-            self.mode = 3
-        else:
-            raise ValueError("Unknown SPI mode.")
+        self._port.set_frequency(baudrate)
+        self._port._cpol = polarity
+        self._port._cpha = phase
+
+    @property
+    def frequency(self):
+        return self._port.frequency
 
     def write(self, buf, start=0, end=None):
         end = end if end else len(buf)
-        port = self._spi.get_port(self.cs, self.freq, self.mode)
         chunks, rest = divmod(end - start, self._spi.PAYLOAD_MAX_LENGTH)
         for i in range(chunks):
             chunk_start = start + i * self._spi.PAYLOAD_MAX_LENGTH
             chunk_end = chunk_start + self._spi.PAYLOAD_MAX_LENGTH
-            port.write(buf[chunk_start:chunk_end])
+            self._port.write(buf[chunk_start:chunk_end])
         if rest:
-            port.write(buf[-1*rest:])
+            self._port.write(buf[-1*rest:])
 
     def readinto(self, buf, start=0, end=None, write_value=0):
         end = end if end else len(buf)
-        port = self._spi.get_port(self.cs, self.freq, self.mode)
-        result = port.read(end-start)
+        result = self._port.read(end-start)
         for i, b in enumerate(result):
             buf[start+i] = b
 
     def write_readinto(self, buffer_out, buffer_in,  out_start=0, out_end=None, in_start=0, in_end=None):
         out_end = out_end if out_end else len(buffer_out)
         in_end = in_end if in_end else len(buffer_in)
-        port = self._spi.get_port(self.cs, self.freq, self.mode)
-        result = port.exchange(buffer_out[out_start:out_end],
-                               in_end-in_start, duplex=True)
+        result = self._port.exchange(buffer_out[out_start:out_end],
+                                     in_end-in_start, duplex=True)
         for i, b in enumerate(result):
             buffer_in[in_start+i] = b
index cf4a06c6cd259ea5ce20f286d8db22c22970ad98..a93c46b0183779d5808cd8eee22bd869eb9f0553 100755 (executable)
@@ -43,6 +43,10 @@ class SPI:
             except AttributeError:
                 pass
 
+    @property
+    def frequency(self):
+        return self.baudrate
+
     def write(self, buf, start=0, end=None):
         if not buf:
             return
index 94f8f674a96660d0bb5ce68dca2bec211e100a09..9702848a841246889af28d575e41db6baa51861a 100755 (executable)
@@ -159,6 +159,13 @@ class SPI(Lockable):
         self._spi = None
         self._pinIds = None
 
+    @property
+    def frequency(self):
+        try:
+            return self._spi.frequency
+        except AttributeError:
+            raise NotImplementedError("Frequency attribute not implemented for this platform")
+
     def write(self, buf, start=0, end=None):
         return self._spi.write(buf, start, end)