]> Repositories - Adafruit_Blinka-hackapet.git/commitdiff
Merge pull request #26 from ladyada/master
authorLimor "Ladyada" Fried <limor@ladyada.net>
Fri, 17 Aug 2018 18:34:39 +0000 (11:34 -0700)
committerGitHub <noreply@github.com>
Fri, 17 Aug 2018 18:34:39 +0000 (11:34 -0700)
add writeto_then_readfrom support for repeated-start i2c transactions

src/adafruit_blinka/microcontroller/raspi_23/i2c.py
src/busio.py

index edac8db010335712784ec92afdba8c7325c0b1e3..e309e9ef6ac0ae3e5db041b616ca5fb2ba463105 100644 (file)
@@ -32,10 +32,35 @@ class I2C:
             found.append(addr)
         return found
 
-    def writeto(self, address, buffer, stop=True):
-        self._i2c_bus.write_bytes(address, buffer)
+    def writeto(self, address, buffer, *, start=0, end=None, stop=True):
+        if end is None:
+            end = len(buffer)
+        self._i2c_bus.write_bytes(address, buffer[start:end])
+
+    def readfrom_into(self, address, buffer, *, start=0, end=None, stop=True):
+        if end is None:
+            end = len(buffer)
+        
+        readin = self._i2c_bus.read_bytes(address, end-start)
+        for i in range(end-start):
+            buffer[i+start] = readin[i]
+
+    def writeto_then_readfrom(self, address, buffer_out, buffer_in, *,
+                       out_start=0, out_end=None,
+                       in_start=0, in_end=None, stop=False):
+        if out_end is None:
+            out_end = len(buffer_out)        
+        if in_end is None:
+            in_end = len(buffer_in)
+        if stop:
+            # To generate a stop in linux, do in two transactions
+            self.writeto(address, buffer_out, start=out_start, end=out_end, stop=True)
+            self.readfrom_into(address, buffer_in, start=in_start, end=in_end)
+        else:
+            # To generate without a stop, do in one block transaction
+            if out_end-out_start != 1:
+                raise NotImplementedError("Currently can only write a single byte in writeto_then_readfrom")
+            readin = self._i2c_bus.read_i2c_block_data(address, buffer_out[out_start:out_end][0], in_end-in_start)
+            for i in range(in_end-in_start):
+                buffer_in[i+in_start] = readin[i]
 
-    def readfrom_into(self, address, buffer, stop=True):
-        readin = self._i2c_bus.read_bytes(address, len(buffer))
-        for i in range(len(buffer)):
-            buffer[i] = readin[i]
index 069e9bec91134024ba8347a9098bb6d2905b5962..72f3c7a66627e58f2c9eee4981112131fe4ddd73 100755 (executable)
@@ -44,7 +44,7 @@ class I2C(Lockable):
     def scan(self):
         return self._i2c.scan()
 
-    def readfrom_into(self, address, buffer, start=0, end=None):
+    def readfrom_into(self, address, buffer, *, start=0, end=None):
         if start is not 0 or end is not None:
             if end is None:
                 end = len(buffer)
@@ -52,7 +52,7 @@ class I2C(Lockable):
         stop = True  # remove for efficiency later
         return self._i2c.readfrom_into(address, buffer, stop)
 
-    def writeto(self, address, buffer, start=0, end=None, stop=True):
+    def writeto(self, address, buffer, *, start=0, end=None, stop=True):
         if isinstance(buffer, str):
             buffer = bytes([ord(x) for x in buffer])
         if start is not 0 or end is not None:
@@ -62,6 +62,8 @@ class I2C(Lockable):
                 return self._i2c.writeto(address, memoryview(buffer)[start:end], stop)
         return self._i2c.writeto(address, buffer, stop)
 
+    def writeto_then_readfrom(self, address, buffer_out, buffer_in, *, out_start=0, out_end=None, in_start=0, in_end=None, stop=False):
+        return self._i2c.writeto_then_readfrom(address, buffer_out, buffer_in, out_start, out_end, in_start, in_end, stop)
 
 class SPI(Lockable):
     def __init__(self, clock, MOSI=None, MISO=None):