parent
cf5f80f3f3
commit
f57ca82ee1
|
@ -267,7 +267,7 @@ class I2CDriver:
|
||||||
|
|
||||||
:param dev: 7-bit I2C device address
|
:param dev: 7-bit I2C device address
|
||||||
:param reg: register address 0-255
|
:param reg: register address 0-255
|
||||||
:param fmt: :py:func:`struct.unpack` format string for the register contents
|
:param fmt: :py:func:`struct.unpack` format string for the register contents, or an integer byte count
|
||||||
|
|
||||||
If device 0x75 has a 16-bit register 102, it can be read with:
|
If device 0x75 has a 16-bit register 102, it can be read with:
|
||||||
|
|
||||||
|
@ -276,17 +276,23 @@ class I2CDriver:
|
||||||
"""
|
"""
|
||||||
|
|
||||||
if isinstance(fmt, str):
|
if isinstance(fmt, str):
|
||||||
n = struct.calcsize(fmt)
|
r = struct.unpack(fmt, self.regrd(dev, reg, struct.calcsize(fmt)))
|
||||||
self.__ser_w(b'r' + struct.pack("BBB", dev, reg, n))
|
|
||||||
r = struct.unpack(fmt, self.ser.read(n))
|
|
||||||
if len(r) == 1:
|
if len(r) == 1:
|
||||||
return r[0]
|
return r[0]
|
||||||
else:
|
else:
|
||||||
return r
|
return r
|
||||||
else:
|
else:
|
||||||
n = fmt
|
n = fmt
|
||||||
self.__ser_w(b'r' + struct.pack("BBB", dev, reg, n))
|
if n <= 256:
|
||||||
return self.ser.read(n)
|
self.__ser_w(b'r' + struct.pack("BBB", dev, reg, n & 0xff))
|
||||||
|
return self.ser.read(n)
|
||||||
|
else:
|
||||||
|
self.start(dev, 0)
|
||||||
|
self.write([reg])
|
||||||
|
self.start(dev, 1)
|
||||||
|
r = self.read(n)
|
||||||
|
self.stop()
|
||||||
|
return r
|
||||||
|
|
||||||
def regwr(self, dev, reg, vv):
|
def regwr(self, dev, reg, vv):
|
||||||
"""Write a device's register.
|
"""Write a device's register.
|
||||||
|
|
|
@ -111,6 +111,13 @@ class TestDUT(unittest.TestCase):
|
||||||
self.assertEqual(self.lm75_read(i2, 3), 0x5000)
|
self.assertEqual(self.lm75_read(i2, 3), 0x5000)
|
||||||
self.stacksame()
|
self.stacksame()
|
||||||
|
|
||||||
|
def test_regrd256(self):
|
||||||
|
i2 = self.i2
|
||||||
|
reg = 3
|
||||||
|
self.lm75_write(i2, reg, 0x7480)
|
||||||
|
for n in (127, 128, 129):
|
||||||
|
self.assertEqual(i2.regrd(0x48, reg, ">" + str(n) + "h"), (0x7480,) * n)
|
||||||
|
|
||||||
def test_setspeed(self):
|
def test_setspeed(self):
|
||||||
i2 = self.init()
|
i2 = self.init()
|
||||||
self.stack0()
|
self.stack0()
|
||||||
|
|
Loading…
Reference in New Issue