summaryrefslogtreecommitdiffstatshomepage
path: root/tests/pyb/i2c_error.py
blob: d6c0debe29e94cf8786a030987e79d6af6d89ea1 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
# test I2C errors, with polling (disabled irqs) and DMA

import pyb
from pyb import I2C

# init accelerometer
pyb.Accel()

# get I2C bus
i2c = I2C(1, I2C.MASTER) 

# test polling mem_read
pyb.disable_irq()
i2c.mem_read(1, 76, 0x0a) # should succeed
pyb.enable_irq()
try:
    pyb.disable_irq()
    i2c.mem_read(1, 77, 0x0a) # should fail
except OSError as e:
    pyb.enable_irq()
    print(repr(e))
i2c.mem_read(1, 76, 0x0a) # should succeed

# test polling mem_write
pyb.disable_irq()
i2c.mem_write(1, 76, 0x0a) # should succeed
pyb.enable_irq()
try:
    pyb.disable_irq()
    i2c.mem_write(1, 77, 0x0a) # should fail
except OSError as e:
    pyb.enable_irq()
    print(repr(e))
i2c.mem_write(1, 76, 0x0a) # should succeed

# test DMA mem_read
i2c.mem_read(1, 76, 0x0a) # should succeed
try:
    i2c.mem_read(1, 77, 0x0a) # should fail
except OSError as e:
    print(repr(e))
i2c.mem_read(1, 76, 0x0a) # should succeed

# test DMA mem_write
i2c.mem_write(1, 76, 0x0a) # should succeed
try:
    i2c.mem_write(1, 77, 0x0a) # should fail
except OSError as e:
    print(repr(e))
i2c.mem_write(1, 76, 0x0a) # should succeed