X-Git-Url: https://git.ayoreis.com/Adafruit_Blinka-hackapet.git/blobdiff_plain/6892349c68d92b78bd1d20c7c936f8df9478c114..a79e37b2729f77faf00545062fc4a8ded1a6eb97:/src/adafruit_blinka/microcontroller/generic_linux/i2c.py?ds=sidebyside diff --git a/src/adafruit_blinka/microcontroller/generic_linux/i2c.py b/src/adafruit_blinka/microcontroller/generic_linux/i2c.py index e309e9e..b151798 100644 --- a/src/adafruit_blinka/microcontroller/generic_linux/i2c.py +++ b/src/adafruit_blinka/microcontroller/generic_linux/i2c.py @@ -1,7 +1,10 @@ +"""Generic Linux I2C class using PureIO's smbus class""" import Adafruit_PureIO.smbus as smbus -import time + class I2C: + """I2C class""" + MASTER = 0 SLAVE = 1 _baudrate = None @@ -13,18 +16,21 @@ class I2C: raise NotImplementedError("Only I2C Master supported!") _mode = self.MASTER - #if baudrate != None: + # if baudrate != None: # print("I2C frequency is not settable in python, ignoring!") - + try: self._i2c_bus = smbus.SMBus(bus_num) except FileNotFoundError: - raise RuntimeError("I2C Bus #%d not found, check if enabled in config!" % bus_num) + raise RuntimeError( + "I2C Bus #%d not found, check if enabled in config!" % bus_num + ) def scan(self): - """Try to read a byte from each address, if you get an OSError it means the device isnt there""" + """Try to read a byte from each address, if you get an OSError + it means the device isnt there""" found = [] - for addr in range(0,0x80): + for addr in range(0, 0x80): try: self._i2c_bus.read_byte(addr) except OSError: @@ -32,24 +38,41 @@ class I2C: found.append(addr) return found + # pylint: disable=unused-argument def writeto(self, address, buffer, *, start=0, end=None, stop=True): + """Write data from the buffer to an address""" 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): + """Read data from an address and into the buffer""" 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): + readin = self._i2c_bus.read_bytes(address, end - start) + for i in range(end - start): + buffer[i + start] = readin[i] + + # pylint: enable=unused-argument + + def writeto_then_readfrom( + self, + address, + buffer_out, + buffer_in, + *, + out_start=0, + out_end=None, + in_start=0, + in_end=None, + stop=False + ): + """Write data from buffer_out to an address and then + read data from an address and into buffer_in + """ if out_end is None: - out_end = len(buffer_out) + out_end = len(buffer_out) if in_end is None: in_end = len(buffer_in) if stop: @@ -58,9 +81,8 @@ class I2C: 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] - + readin = self._i2c_bus.read_i2c_block_data( + address, buffer_out[out_start:out_end], in_end - in_start + ) + for i in range(in_end - in_start): + buffer_in[i + in_start] = readin[i]