1*cd60bc56SAndroid Build Coastguard Worker // SPDX-License-Identifier: LGPL-2.1-or-later
2*cd60bc56SAndroid Build Coastguard Worker /*
3*cd60bc56SAndroid Build Coastguard Worker * Testcase for dtc expression support
4*cd60bc56SAndroid Build Coastguard Worker *
5*cd60bc56SAndroid Build Coastguard Worker * Copyright (C) 2008 David Gibson, IBM Corporation.
6*cd60bc56SAndroid Build Coastguard Worker */
7*cd60bc56SAndroid Build Coastguard Worker
8*cd60bc56SAndroid Build Coastguard Worker #include <stdlib.h>
9*cd60bc56SAndroid Build Coastguard Worker #include <stdio.h>
10*cd60bc56SAndroid Build Coastguard Worker #include <string.h>
11*cd60bc56SAndroid Build Coastguard Worker #include <stdint.h>
12*cd60bc56SAndroid Build Coastguard Worker #include <errno.h>
13*cd60bc56SAndroid Build Coastguard Worker
14*cd60bc56SAndroid Build Coastguard Worker
15*cd60bc56SAndroid Build Coastguard Worker #include <libfdt.h>
16*cd60bc56SAndroid Build Coastguard Worker
17*cd60bc56SAndroid Build Coastguard Worker #include "tests.h"
18*cd60bc56SAndroid Build Coastguard Worker #include "testdata.h"
19*cd60bc56SAndroid Build Coastguard Worker
20*cd60bc56SAndroid Build Coastguard Worker static struct test_expr {
21*cd60bc56SAndroid Build Coastguard Worker const char *expr;
22*cd60bc56SAndroid Build Coastguard Worker uint32_t result;
23*cd60bc56SAndroid Build Coastguard Worker } expr_table[] = {
24*cd60bc56SAndroid Build Coastguard Worker #define TE(expr) { #expr, (expr) }
25*cd60bc56SAndroid Build Coastguard Worker TE(0xdeadbeef),
26*cd60bc56SAndroid Build Coastguard Worker TE(-0x21524111),
27*cd60bc56SAndroid Build Coastguard Worker TE(1+1),
28*cd60bc56SAndroid Build Coastguard Worker TE(2*3),
29*cd60bc56SAndroid Build Coastguard Worker TE(4/2),
30*cd60bc56SAndroid Build Coastguard Worker TE(10/3),
31*cd60bc56SAndroid Build Coastguard Worker TE(19%4),
32*cd60bc56SAndroid Build Coastguard Worker TE(1 << 13),
33*cd60bc56SAndroid Build Coastguard Worker TE(0x1000 >> 4),
34*cd60bc56SAndroid Build Coastguard Worker TE(3*2+1), TE(3*(2+1)),
35*cd60bc56SAndroid Build Coastguard Worker TE(1+2*3), TE((1+2)*3),
36*cd60bc56SAndroid Build Coastguard Worker TE(1 < 2), TE(2 < 1), TE(1 < 1),
37*cd60bc56SAndroid Build Coastguard Worker TE(1 <= 2), TE(2 <= 1), TE(1 <= 1),
38*cd60bc56SAndroid Build Coastguard Worker TE(1 > 2), TE(2 > 1), TE(1 > 1),
39*cd60bc56SAndroid Build Coastguard Worker TE(1 >= 2), TE(2 >= 1), TE(1 >= 1),
40*cd60bc56SAndroid Build Coastguard Worker TE(1 == 1), TE(1 == 2),
41*cd60bc56SAndroid Build Coastguard Worker TE(1 != 1), TE(1 != 2),
42*cd60bc56SAndroid Build Coastguard Worker TE(0xabcdabcd & 0xffff0000),
43*cd60bc56SAndroid Build Coastguard Worker TE(0xdead4110 ^ 0xf0f0f0f0),
44*cd60bc56SAndroid Build Coastguard Worker TE(0xabcd0000 | 0x0000abcd),
45*cd60bc56SAndroid Build Coastguard Worker TE(~0x21524110),
46*cd60bc56SAndroid Build Coastguard Worker TE(~~0xdeadbeef),
47*cd60bc56SAndroid Build Coastguard Worker TE(0 && 0), TE(17 && 0), TE(0 && 17), TE(17 && 17),
48*cd60bc56SAndroid Build Coastguard Worker TE(0 || 0), TE(17 || 0), TE(0 || 17), TE(17 || 17),
49*cd60bc56SAndroid Build Coastguard Worker TE(!0), TE(!1), TE(!17), TE(!!0), TE(!!17),
50*cd60bc56SAndroid Build Coastguard Worker TE(0 ? 17 : 39), TE(1 ? 17 : 39), TE(17 ? 0xdeadbeef : 0xabcd1234),
51*cd60bc56SAndroid Build Coastguard Worker TE(11 * 257 * 1321517ULL),
52*cd60bc56SAndroid Build Coastguard Worker TE(123456790 - 4/2 + 17%4),
53*cd60bc56SAndroid Build Coastguard Worker };
54*cd60bc56SAndroid Build Coastguard Worker
55*cd60bc56SAndroid Build Coastguard Worker #define ARRAY_SIZE(x) (sizeof(x) / sizeof((x)[0]))
56*cd60bc56SAndroid Build Coastguard Worker
main(int argc,char * argv[])57*cd60bc56SAndroid Build Coastguard Worker int main(int argc, char *argv[])
58*cd60bc56SAndroid Build Coastguard Worker {
59*cd60bc56SAndroid Build Coastguard Worker void *fdt;
60*cd60bc56SAndroid Build Coastguard Worker const fdt32_t *res;
61*cd60bc56SAndroid Build Coastguard Worker int reslen;
62*cd60bc56SAndroid Build Coastguard Worker unsigned int i;
63*cd60bc56SAndroid Build Coastguard Worker
64*cd60bc56SAndroid Build Coastguard Worker test_init(argc, argv);
65*cd60bc56SAndroid Build Coastguard Worker
66*cd60bc56SAndroid Build Coastguard Worker if ((argc == 3) && (strcmp(argv[1], "-g") == 0)) {
67*cd60bc56SAndroid Build Coastguard Worker FILE *f = fopen(argv[2], "w");
68*cd60bc56SAndroid Build Coastguard Worker
69*cd60bc56SAndroid Build Coastguard Worker if (!f)
70*cd60bc56SAndroid Build Coastguard Worker FAIL("Couldn't open \"%s\" for output: %s\n",
71*cd60bc56SAndroid Build Coastguard Worker argv[2], strerror(errno));
72*cd60bc56SAndroid Build Coastguard Worker
73*cd60bc56SAndroid Build Coastguard Worker fprintf(f, "/dts-v1/;\n");
74*cd60bc56SAndroid Build Coastguard Worker fprintf(f, "/ {\n");
75*cd60bc56SAndroid Build Coastguard Worker fprintf(f, "\texpressions = <\n");
76*cd60bc56SAndroid Build Coastguard Worker for (i = 0; i < ARRAY_SIZE(expr_table); i++)
77*cd60bc56SAndroid Build Coastguard Worker fprintf(f, "\t\t(%s)\n", expr_table[i].expr);
78*cd60bc56SAndroid Build Coastguard Worker fprintf(f, "\t>;\n");
79*cd60bc56SAndroid Build Coastguard Worker fprintf(f, "};\n");
80*cd60bc56SAndroid Build Coastguard Worker fclose(f);
81*cd60bc56SAndroid Build Coastguard Worker } else {
82*cd60bc56SAndroid Build Coastguard Worker fdt = load_blob_arg(argc, argv);
83*cd60bc56SAndroid Build Coastguard Worker
84*cd60bc56SAndroid Build Coastguard Worker res = fdt_getprop(fdt, 0, "expressions", &reslen);
85*cd60bc56SAndroid Build Coastguard Worker
86*cd60bc56SAndroid Build Coastguard Worker if (!res)
87*cd60bc56SAndroid Build Coastguard Worker FAIL("Error retrieving expression results: %s\n",
88*cd60bc56SAndroid Build Coastguard Worker fdt_strerror(reslen));
89*cd60bc56SAndroid Build Coastguard Worker
90*cd60bc56SAndroid Build Coastguard Worker if (reslen != (ARRAY_SIZE(expr_table) * sizeof(uint32_t)))
91*cd60bc56SAndroid Build Coastguard Worker FAIL("Unexpected length of results %d instead of %zd\n",
92*cd60bc56SAndroid Build Coastguard Worker reslen, ARRAY_SIZE(expr_table) * sizeof(uint32_t));
93*cd60bc56SAndroid Build Coastguard Worker
94*cd60bc56SAndroid Build Coastguard Worker for (i = 0; i < ARRAY_SIZE(expr_table); i++)
95*cd60bc56SAndroid Build Coastguard Worker if (fdt32_to_cpu(res[i]) != expr_table[i].result)
96*cd60bc56SAndroid Build Coastguard Worker FAIL("Incorrect result for expression \"%s\","
97*cd60bc56SAndroid Build Coastguard Worker " 0x%x instead of 0x%x\n",
98*cd60bc56SAndroid Build Coastguard Worker expr_table[i].expr, fdt32_to_cpu(res[i]),
99*cd60bc56SAndroid Build Coastguard Worker expr_table[i].result);
100*cd60bc56SAndroid Build Coastguard Worker }
101*cd60bc56SAndroid Build Coastguard Worker
102*cd60bc56SAndroid Build Coastguard Worker PASS();
103*cd60bc56SAndroid Build Coastguard Worker }
104