From: Francis Guevarra Date: Tue, 19 Nov 2019 07:29:59 +0000 (-0800) Subject: Comment out pin import for i2c for now to get it working, implement the rest of spi... X-Git-Tag: 3.1.0^2^2~1^2~8 X-Git-Url: https://git.ayoreis.com/Adafruit_Blinka-hackapet.git/commitdiff_plain/1b1794b4881a2f390bc795cedbfe13bb5f1848c5?ds=inline Comment out pin import for i2c for now to get it working, implement the rest of spi interfaces --- diff --git a/src/adafruit_blinka/microcontroller/nova/i2c.py b/src/adafruit_blinka/microcontroller/nova/i2c.py index 3e8f2ab..d6de705 100644 --- a/src/adafruit_blinka/microcontroller/nova/i2c.py +++ b/src/adafruit_blinka/microcontroller/nova/i2c.py @@ -1,4 +1,4 @@ -from adafruit_blinka.microcontroller.nova.pin import Pin +#from adafruit_blinka.microcontroller.nova.pin import Pin class I2C: diff --git a/src/adafruit_blinka/microcontroller/nova/spi.py b/src/adafruit_blinka/microcontroller/nova/spi.py index 82e75b0..d92d2d7 100644 --- a/src/adafruit_blinka/microcontroller/nova/spi.py +++ b/src/adafruit_blinka/microcontroller/nova/spi.py @@ -1,7 +1,7 @@ #from adafruit_blinka.microcontroller.nova.pin import Pin class SPI: - MSB = 0 + PAYLOAD_MAX_LENGTH = 64 def __init__(self, clock): from binhoHostAdapter import binhoHostAdapter @@ -41,17 +41,26 @@ class SPI: @property def frequency(self): - return self._nova.getClockSPI(0) + return self._nova.getClockSPI(0).split('CLK ')[1] def write(self, buf, start=0, end=None): end = end if end else len(buf) - #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 - # self._port.write(buf[chunk_start:chunk_end]) - #if rest: - # self._port.write(buf[-1*rest:]) + chunks, rest = divmod(end - start, self.PAYLOAD_MAX_LENGTH) + self._nova.setIOpinValue(0, 'LOW') + for i in range(chunks): + chunk_start = start + i * self.PAYLOAD_MAX_LENGTH + chunk_end = chunk_start + self.PAYLOAD_MAX_LENGTH + buffer_data = buf[chunk_start:chunk_end] + self._nova.clearBuffer(0) + self._nova.writeToBuffer(0, 0, buffer_data) + self._nova.transferBufferSPI(0, chunk_end - chunk_start + 1) + if rest: + buffer_data = buf[-1*rest:] + self._nova.clearBuffer(0) + self._nova.writeToBuffer(0, 0, buffer_data) + self._nova.transferBufferSPI(0, rest) + self._nova.setIOpinValue(0, 'HIGH') + print(self._nova.readBuffer(0, 4)) def readinto(self, buf, start=0, end=None, write_value=0): end = end if end else len(buf) @@ -59,12 +68,22 @@ class SPI: for i in range(start, end): buf[start+i] = int(self.getSpiReceivedData(self._nova.transferSPI(0, write_value)), 16) self._nova.setIOpinValue(0, 'HIGH') -""" + 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) - 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 -""" \ No newline at end of file + readlen = in_end-in_start + writelen = out_end-out_start + if readlen > writelen: + # resize out and pad with 0's + tmp = bytearray(buffer_out) + tmp.extend([0] * (readlen - len(buffer_out))) + buffer_out = tmp + i = 0 + self._nova.setIOpinValue(0, 'LOW') + for data_out in buffer_out: + data_in = int(self.getSpiReceivedData(self._nova.transferSPI(0, data_out)), 16) + if i < readlen: + buffer_in[in_start+i] = data_in + i += 1 + self._nova.setIOpinValue(0, 'HIGH')