Merge tag 'rpi-next-2020.07' of https://gitlab.denx.de/u-boot/custodians/u-boot-raspb...
[oweals/u-boot.git] / test / dm / dma.c
1 // SPDX-License-Identifier: GPL-2.0+
2 /*
3  * Direct Memory Access U-Class tests
4  *
5  * Copyright (C) 2018 Texas Instruments Incorporated <www.ti.com>
6  * Grygorii Strashko <grygorii.strashko@ti.com>
7  */
8
9 #include <common.h>
10 #include <dm.h>
11 #include <malloc.h>
12 #include <dm/test.h>
13 #include <dma.h>
14 #include <test/ut.h>
15
16 static int dm_test_dma_m2m(struct unit_test_state *uts)
17 {
18         struct udevice *dev;
19         struct dma dma_m2m;
20         u8 src_buf[512];
21         u8 dst_buf[512];
22         size_t len = 512;
23         int i;
24
25         ut_assertok(uclass_get_device_by_name(UCLASS_DMA, "dma", &dev));
26         ut_assertok(dma_get_by_name(dev, "m2m", &dma_m2m));
27
28         memset(dst_buf, 0, len);
29         for (i = 0; i < len; i++)
30                 src_buf[i] = i;
31
32         ut_assertok(dma_memcpy(dst_buf, src_buf, len));
33
34         ut_assertok(memcmp(src_buf, dst_buf, len));
35         return 0;
36 }
37 DM_TEST(dm_test_dma_m2m, DM_TESTF_SCAN_FDT);
38
39 static int dm_test_dma(struct unit_test_state *uts)
40 {
41         struct udevice *dev;
42         struct dma dma_tx, dma_rx;
43         u8 src_buf[512];
44         u8 dst_buf[512];
45         void *dst_ptr;
46         size_t len = 512;
47         u32 meta1, meta2;
48         int i;
49
50         ut_assertok(uclass_get_device_by_name(UCLASS_DMA, "dma", &dev));
51
52         ut_assertok(dma_get_by_name(dev, "tx0", &dma_tx));
53         ut_assertok(dma_get_by_name(dev, "rx0", &dma_rx));
54
55         ut_assertok(dma_enable(&dma_tx));
56         ut_assertok(dma_enable(&dma_rx));
57
58         memset(dst_buf, 0, len);
59         for (i = 0; i < len; i++)
60                 src_buf[i] = i;
61         meta1 = 0xADADDEAD;
62         meta2 = 0;
63         dst_ptr = &dst_buf;
64
65         ut_assertok(dma_send(&dma_tx, src_buf, len, &meta1));
66
67         ut_asserteq(len, dma_receive(&dma_rx, &dst_ptr, &meta2));
68         ut_asserteq(0xADADDEAD, meta2);
69
70         ut_assertok(dma_disable(&dma_tx));
71         ut_assertok(dma_disable(&dma_rx));
72
73         ut_assertok(dma_free(&dma_tx));
74         ut_assertok(dma_free(&dma_rx));
75         ut_assertok(memcmp(src_buf, dst_buf, len));
76
77         return 0;
78 }
79 DM_TEST(dm_test_dma, DM_TESTF_SCAN_FDT);
80
81 static int dm_test_dma_rx(struct unit_test_state *uts)
82 {
83         struct udevice *dev;
84         struct dma dma_tx, dma_rx;
85         u8 src_buf[512];
86         u8 dst_buf[512];
87         void *dst_ptr;
88         size_t len = 512;
89         u32 meta1, meta2;
90         int i;
91
92         ut_assertok(uclass_get_device_by_name(UCLASS_DMA, "dma", &dev));
93
94         ut_assertok(dma_get_by_name(dev, "tx0", &dma_tx));
95         ut_assertok(dma_get_by_name(dev, "rx0", &dma_rx));
96
97         ut_assertok(dma_enable(&dma_tx));
98         ut_assertok(dma_enable(&dma_rx));
99
100         memset(dst_buf, 0, len);
101         for (i = 0; i < len; i++)
102                 src_buf[i] = i;
103         meta1 = 0xADADDEAD;
104         meta2 = 0;
105         dst_ptr = NULL;
106
107         ut_assertok(dma_prepare_rcv_buf(&dma_tx, dst_buf, len));
108
109         ut_assertok(dma_send(&dma_tx, src_buf, len, &meta1));
110
111         ut_asserteq(len, dma_receive(&dma_rx, &dst_ptr, &meta2));
112         ut_asserteq(0xADADDEAD, meta2);
113         ut_asserteq_ptr(dst_buf, dst_ptr);
114
115         ut_assertok(dma_disable(&dma_tx));
116         ut_assertok(dma_disable(&dma_rx));
117
118         ut_assertok(dma_free(&dma_tx));
119         ut_assertok(dma_free(&dma_rx));
120         ut_assertok(memcmp(src_buf, dst_buf, len));
121
122         return 0;
123 }
124 DM_TEST(dm_test_dma_rx, DM_TESTF_SCAN_FDT);