1 // SPDX-License-Identifier: GPL-2.0+
13 #define BIT(x) (1UL << (x))
15 #define NI_ROUTE_VALUE_EXTERNAL_CONVERSION 1
17 #include "../ni_route_values.c"
18 #include "../ni_device_routes.c"
19 #include "all_cfiles.c"
23 #define RVij(rv, src, dest) ((rv)->register_values[(dest)][(src)])
28 * "family" : "<family-name>",
29 * "register_values": {
30 * <destination0>:[src0, src1, ...],
31 * <destination0>:[src0, src1, ...],
36 void family_write(const struct family_route_values *rv, FILE *fp)
40 " # dest -> {src0:val0, src1:val1, ...}\n"
42 for (unsigned int dest = NI_NAMES_BASE;
43 dest < (NI_NAMES_BASE + NI_NUM_NAMES);
45 unsigned int src = NI_NAMES_BASE;
47 for (; src < (NI_NAMES_BASE + NI_NUM_NAMES) &&
48 RVij(rv, B(src), B(dest)) == 0; ++src)
51 if (src >= (NI_NAMES_BASE + NI_NUM_NAMES))
52 continue; /* no data here */
54 fprintf(fp, " %u : {\n", dest);
55 for (src = NI_NAMES_BASE; src < (NI_NAMES_BASE + NI_NUM_NAMES);
57 register_type r = RVij(rv, B(src), B(dest));
62 } else if (MARKED_V(r)) {
64 } else if (MARKED_I(r)) {
66 } else if (MARKED_U(r)) {
70 "Invalid register marking %s[%u][%u] = %u\n",
71 rv->family, dest, src, r);
75 fprintf(fp, " %u : \"%s(%u)\",\n",
80 fprintf(fp, " },\n\n");
83 bool is_valid_ni_sig(unsigned int sig)
85 return (sig >= NI_NAMES_BASE) && (sig < (NI_NAMES_BASE + NI_NUM_NAMES));
91 * "family" : "<family-name>",
92 * "register_values": {
93 * <destination0>:[src0, src1, ...],
94 * <destination0>:[src0, src1, ...],
99 void device_write(const struct ni_device_routes *dR, FILE *fp)
103 " # dest -> [src0, src1, ...]\n"
108 while (dR->routes[i].dest != 0) {
109 if (!is_valid_ni_sig(dR->routes[i].dest)) {
111 "Invalid NI signal value [%u] for destination %s.[%u]\n",
112 dR->routes[i].dest, dR->device, i);
116 fprintf(fp, " %u : [", dR->routes[i].dest);
120 while (dR->routes[i].src[j] != 0) {
121 if (!is_valid_ni_sig(dR->routes[i].src[j])) {
123 "Invalid NI signal value [%u] for source %s.[%u].[%u]\n",
124 dR->routes[i].src[j], dR->device, i, j);
128 fprintf(fp, "%u,", dR->routes[i].src[j]);
136 fprintf(fp, " },\n\n");
141 FILE *fp = fopen("ni_values.py", "w");
143 /* write route register values */
144 fprintf(fp, "ni_route_values = {\n");
145 for (int i = 0; ni_all_route_values[i]; ++i)
146 family_write(ni_all_route_values[i], fp);
147 fprintf(fp, "}\n\n");
149 /* write valid device routes */
150 fprintf(fp, "ni_device_routes = {\n");
151 for (int i = 0; ni_device_routes_list[i]; ++i)
152 device_write(ni_device_routes_list[i], fp);
155 /* finish; close file */