summaryrefslogtreecommitdiff
path: root/tests/ports/stm32_hardware/dma_alignment.py
blob: 1c271d48e725b00fddef251f81f3999feaf0a70c (plain)
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
51
52
53
54
55
56
57
58
59
# Regression test for DMA for DCache coherency bugs with cache line
# written originally for https://github.com/micropython/micropython/issues/13471

# IMPORTANT: This test requires SPI2 MISO (pin Y8 on Pyboard D) to be connected to GND

import unittest
from machine import SPI

SPI_NUM = 2
BAUDRATE = 5_000_000


class Test(unittest.TestCase):
    @classmethod
    def setUpClass(cls):
        cls.spi = SPI(SPI_NUM, baudrate=BAUDRATE)
        cls.skip_slow_test = False

    def test_variable_offset_fixed_length(self):
        buf = bytearray(1024)
        for offs in range(0, len(buf)):
            v = memoryview(buf)[offs : offs + 128]
            self.spi.readinto(v, 0xFF)
            ok = all(b == 0x00 for b in v)
            if not ok:
                print(offs, v.hex())
                self.skip_slow_test = True
            self.assertTrue(ok)

    def test_variable_offset_and_lengths(self):
        # this takes around 30s to run, so skipped if already failing
        if self.skip_slow_test:
            self.skipTest("already failing")

        buf = bytearray(1024)
        for op_len in range(1, 66):
            print(op_len)
            wr = b"\xff" * op_len
            for offs in range(1, len(buf) - op_len - 1):
                # Place some "sentinel" values before and after the DMA buffer
                before = offs & 0xFF
                after = (~offs) & 0xFF
                buf[offs - 1] = before
                buf[offs + op_len] = after
                v = memoryview(buf)[offs : offs + op_len]
                self.spi.write_readinto(wr, v)
                ok = (
                    all(b == 0x00 for b in v)
                    and buf[offs - 1] == before
                    and buf[offs + op_len] == after
                )
                if not ok:
                    print(v.hex())
                    print(hex(op_len), hex(offs), hex(buf[offs - 1]), hex(buf[offs + op_len]))
                self.assertTrue(ok)


if __name__ == "__main__":
    unittest.main()