blob: 879ca2ab2bfc9b00780f2ee2069c45548d555b3a [file] [log] [blame]
Simon Glass3c19dc82019-10-31 07:42:55 -06001#!/usr/bin/env python3
Tom Rini83d290c2018-05-06 17:58:06 -04002# SPDX-License-Identifier: GPL-2.0+
Simon Glassc0791922017-06-18 22:09:06 -06003# Copyright (c) 2012 The Chromium OS Authors.
4#
Simon Glassc0791922017-06-18 22:09:06 -06005
6"""Tests for the dtb_platdata module
7
Simon Glass3def0cf2018-07-06 10:27:20 -06008This includes unit tests for some functions and functional tests for the dtoc
9tool.
Simon Glassc0791922017-06-18 22:09:06 -060010"""
11
12import collections
Simon Glassa32eb7d2021-02-03 06:00:51 -070013import copy
Simon Glass10cbd3b2020-12-28 20:34:52 -070014import glob
Simon Glassc0791922017-06-18 22:09:06 -060015import os
16import struct
17import unittest
18
Simon Glass67b5ec52020-12-28 20:34:47 -070019from dtoc import dtb_platdata
Simon Glassbf776672020-04-17 18:09:04 -060020from dtoc import fdt
21from dtoc import fdt_util
Simon Glassa32eb7d2021-02-03 06:00:51 -070022from dtoc import src_scan
Simon Glass8a455fc2022-02-11 13:23:20 -070023from dtoc.dtb_platdata import Ftype
24from dtoc.dtb_platdata import get_value
25from dtoc.dtb_platdata import tab_to
Simon Glassa542a702020-12-28 20:35:06 -070026from dtoc.src_scan import conv_name_to_c
27from dtoc.src_scan import get_compat_name
Simon Glassbf776672020-04-17 18:09:04 -060028from patman import test_util
29from patman import tools
Simon Glassc0791922017-06-18 22:09:06 -060030
Simon Glass67b5ec52020-12-28 20:34:47 -070031OUR_PATH = os.path.dirname(os.path.realpath(__file__))
Simon Glassc0791922017-06-18 22:09:06 -060032
33
Simon Glassaab660f2017-11-12 21:52:17 -070034HEADER = '''/*
35 * DO NOT MODIFY
36 *
Simon Glassd1055d62020-12-28 20:35:00 -070037 * Defines the structs used to hold devicetree data.
38 * This was generated by dtoc from a .dtb (device tree binary) file.
Simon Glassaab660f2017-11-12 21:52:17 -070039 */
40
41#include <stdbool.h>
Masahiro Yamadab08c8c42018-03-05 01:20:11 +090042#include <linux/libfdt.h>'''
Simon Glassaab660f2017-11-12 21:52:17 -070043
Simon Glass426d12f2021-02-03 06:01:14 -070044DECL_HEADER = '''/*
45 * DO NOT MODIFY
46 *
47 * Declares externs for all device/uclass instances.
48 * This was generated by dtoc from a .dtb (device tree binary) file.
49 */
50'''
51
Simon Glass4b91be22021-02-03 06:01:15 -070052C_HEADER_PRE = '''/*
Simon Glassaab660f2017-11-12 21:52:17 -070053 * DO NOT MODIFY
54 *
Simon Glassd1055d62020-12-28 20:35:00 -070055 * Declares the U_BOOT_DRIVER() records and platform data.
56 * This was generated by dtoc from a .dtb (device tree binary) file.
Simon Glassaab660f2017-11-12 21:52:17 -070057 */
Simon Glass4b91be22021-02-03 06:01:15 -070058'''
Simon Glassaab660f2017-11-12 21:52:17 -070059
Simon Glass4b91be22021-02-03 06:01:15 -070060C_HEADER = C_HEADER_PRE + '''
Simon Glass20e442a2020-12-28 20:34:54 -070061/* Allow use of U_BOOT_DRVINFO() in this file */
Simon Glassf31fa992020-12-28 20:35:01 -070062#define DT_PLAT_C
Simon Glasscb43ac12020-10-03 11:31:41 -060063
Simon Glassaab660f2017-11-12 21:52:17 -070064#include <common.h>
65#include <dm.h>
66#include <dt-structs.h>
67'''
68
Simon Glassea74c952021-02-03 06:01:20 -070069UCLASS_HEADER_COMMON = '''/*
70 * DO NOT MODIFY
71 *
72 * Declares the uclass instances (struct uclass).
73 * This was generated by dtoc from a .dtb (device tree binary) file.
74 */
75'''
76
Simon Glassa32eb7d2021-02-03 06:00:51 -070077# Scanner saved from a previous run of the tests (to speed things up)
78saved_scan = None
79
Simon Glass67b5ec52020-12-28 20:34:47 -070080# This is a test so is allowed to access private things in the module it is
81# testing
82# pylint: disable=W0212
Simon Glassfe57c782018-07-06 10:27:37 -060083
84def get_dtb_file(dts_fname, capture_stderr=False):
Simon Glassc0791922017-06-18 22:09:06 -060085 """Compile a .dts file to a .dtb
86
87 Args:
Simon Glass67b5ec52020-12-28 20:34:47 -070088 dts_fname (str): Filename of .dts file in the current directory
89 capture_stderr (bool): True to capture and discard stderr output
Simon Glassc0791922017-06-18 22:09:06 -060090
91 Returns:
Simon Glass67b5ec52020-12-28 20:34:47 -070092 str: Filename of compiled file in output directory
Simon Glassc0791922017-06-18 22:09:06 -060093 """
Simon Glassdff51a52021-02-03 06:00:56 -070094 return fdt_util.EnsureCompiled(os.path.join(OUR_PATH, 'test', dts_fname),
Simon Glassfe57c782018-07-06 10:27:37 -060095 capture_stderr=capture_stderr)
Simon Glassc0791922017-06-18 22:09:06 -060096
97
Simon Glassa32eb7d2021-02-03 06:00:51 -070098def setup():
99 global saved_scan
100
101 # Disable warnings so that calls to get_normalized_compat_name() will not
102 # output things.
Simon Glass0c59ace2021-03-26 16:17:25 +1300103 saved_scan = src_scan.Scanner(None, False)
Simon Glassa32eb7d2021-02-03 06:00:51 -0700104 saved_scan.scan_drivers()
105
106def copy_scan():
107 """Get a copy of saved_scan so that each test can start clean"""
108 return copy.deepcopy(saved_scan)
109
110
Simon Glassc0791922017-06-18 22:09:06 -0600111class TestDtoc(unittest.TestCase):
112 """Tests for dtoc"""
113 @classmethod
114 def setUpClass(cls):
Simon Glassc1aa66e2022-01-29 14:14:04 -0700115 tools.prepare_output_dir(None)
Simon Glassf02d0eb2020-07-07 21:32:06 -0600116 cls.maxDiff = None
Simon Glassc0791922017-06-18 22:09:06 -0600117
118 @classmethod
119 def tearDownClass(cls):
Simon Glassc1aa66e2022-01-29 14:14:04 -0700120 tools.finalise_output_dir()
Simon Glassc0791922017-06-18 22:09:06 -0600121
Simon Glass67b5ec52020-12-28 20:34:47 -0700122 @staticmethod
123 def _write_python_string(fname, data):
Simon Glass57f0bc42018-07-06 10:27:25 -0600124 """Write a string with tabs expanded as done in this Python file
125
126 Args:
Simon Glass67b5ec52020-12-28 20:34:47 -0700127 fname (str): Filename to write to
128 data (str): Raw string to convert
Simon Glass57f0bc42018-07-06 10:27:25 -0600129 """
130 data = data.replace('\t', '\\t')
Simon Glass67b5ec52020-12-28 20:34:47 -0700131 with open(fname, 'w') as fout:
132 fout.write(data)
Simon Glass57f0bc42018-07-06 10:27:25 -0600133
Simon Glass67b5ec52020-12-28 20:34:47 -0700134 def _check_strings(self, expected, actual):
Simon Glass57f0bc42018-07-06 10:27:25 -0600135 """Check that a string matches its expected value
136
137 If the strings do not match, they are written to the /tmp directory in
138 the same Python format as is used here in the test. This allows for
139 easy comparison and update of the tests.
140
141 Args:
Simon Glass67b5ec52020-12-28 20:34:47 -0700142 expected (str): Expected string
143 actual (str): Actual string
Simon Glass57f0bc42018-07-06 10:27:25 -0600144 """
145 if expected != actual:
Simon Glass67b5ec52020-12-28 20:34:47 -0700146 self._write_python_string('/tmp/binman.expected', expected)
147 self._write_python_string('/tmp/binman.actual', actual)
Simon Glass90a81322019-05-17 22:00:31 -0600148 print('Failures written to /tmp/binman.{expected,actual}')
Simon Glass67b5ec52020-12-28 20:34:47 -0700149 self.assertEqual(expected, actual)
Simon Glass57f0bc42018-07-06 10:27:25 -0600150
Simon Glass67b5ec52020-12-28 20:34:47 -0700151 @staticmethod
Simon Glass4a092352021-02-03 06:01:12 -0700152 def run_test(args, dtb_file, output, instantiate=False):
Simon Glass67b5ec52020-12-28 20:34:47 -0700153 """Run a test using dtoc
Walter Lozano361e7332020-06-25 01:10:08 -0300154
Simon Glass67b5ec52020-12-28 20:34:47 -0700155 Args:
156 args (list of str): List of arguments for dtoc
157 dtb_file (str): Filename of .dtb file
158 output (str): Filename of output file
Simon Glass05953522021-02-03 06:01:07 -0700159
160 Returns:
161 DtbPlatdata object
Simon Glass67b5ec52020-12-28 20:34:47 -0700162 """
Simon Glass337d6972021-02-03 06:01:10 -0700163 # Make a copy of the 'scan' object, since it includes uclasses and
164 # drivers, which get updated during execution.
Simon Glass4a092352021-02-03 06:01:12 -0700165 return dtb_platdata.run_steps(
166 args, dtb_file, False, output, [], None, instantiate,
167 warning_disabled=True, scan=copy_scan())
Walter Lozano361e7332020-06-25 01:10:08 -0300168
Simon Glassc0791922017-06-18 22:09:06 -0600169 def test_name(self):
170 """Test conversion of device tree names to C identifiers"""
171 self.assertEqual('serial_at_0x12', conv_name_to_c('serial@0x12'))
172 self.assertEqual('vendor_clock_frequency',
173 conv_name_to_c('vendor,clock-frequency'))
174 self.assertEqual('rockchip_rk3399_sdhci_5_1',
175 conv_name_to_c('rockchip,rk3399-sdhci-5.1'))
176
177 def test_tab_to(self):
178 """Test operation of tab_to() function"""
179 self.assertEqual('fred ', tab_to(0, 'fred'))
180 self.assertEqual('fred\t', tab_to(1, 'fred'))
181 self.assertEqual('fred was here ', tab_to(1, 'fred was here'))
182 self.assertEqual('fred was here\t\t', tab_to(3, 'fred was here'))
183 self.assertEqual('exactly8 ', tab_to(1, 'exactly8'))
184 self.assertEqual('exactly8\t', tab_to(2, 'exactly8'))
185
186 def test_get_value(self):
187 """Test operation of get_value() function"""
188 self.assertEqual('0x45',
Simon Glass5ea9dcc2020-11-08 20:36:17 -0700189 get_value(fdt.Type.INT, struct.pack('>I', 0x45)))
Simon Glassc0791922017-06-18 22:09:06 -0600190 self.assertEqual('0x45',
Simon Glass5ea9dcc2020-11-08 20:36:17 -0700191 get_value(fdt.Type.BYTE, struct.pack('<I', 0x45)))
Simon Glassc0791922017-06-18 22:09:06 -0600192 self.assertEqual('0x0',
Simon Glass5ea9dcc2020-11-08 20:36:17 -0700193 get_value(fdt.Type.BYTE, struct.pack('>I', 0x45)))
194 self.assertEqual('"test"', get_value(fdt.Type.STRING, 'test'))
195 self.assertEqual('true', get_value(fdt.Type.BOOL, None))
Simon Glassc0791922017-06-18 22:09:06 -0600196
197 def test_get_compat_name(self):
198 """Test operation of get_compat_name() function"""
199 Prop = collections.namedtuple('Prop', ['value'])
200 Node = collections.namedtuple('Node', ['props'])
201
202 prop = Prop(['rockchip,rk3399-sdhci-5.1', 'arasan,sdhci-5.1'])
203 node = Node({'compatible': prop})
Walter Lozanodcb3ed62020-07-23 00:22:03 -0300204 self.assertEqual((['rockchip_rk3399_sdhci_5_1', 'arasan_sdhci_5_1']),
Simon Glassc0791922017-06-18 22:09:06 -0600205 get_compat_name(node))
206
207 prop = Prop(['rockchip,rk3399-sdhci-5.1'])
208 node = Node({'compatible': prop})
Walter Lozanodcb3ed62020-07-23 00:22:03 -0300209 self.assertEqual((['rockchip_rk3399_sdhci_5_1']),
Simon Glassc0791922017-06-18 22:09:06 -0600210 get_compat_name(node))
211
212 prop = Prop(['rockchip,rk3399-sdhci-5.1', 'arasan,sdhci-5.1', 'third'])
213 node = Node({'compatible': prop})
Walter Lozanodcb3ed62020-07-23 00:22:03 -0300214 self.assertEqual((['rockchip_rk3399_sdhci_5_1',
Simon Glass67b5ec52020-12-28 20:34:47 -0700215 'arasan_sdhci_5_1', 'third']),
Simon Glassc0791922017-06-18 22:09:06 -0600216 get_compat_name(node))
217
218 def test_empty_file(self):
219 """Test output from a device tree file with no nodes"""
220 dtb_file = get_dtb_file('dtoc_test_empty.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -0700221 output = tools.get_output_filename('output')
Simon Glassa32eb7d2021-02-03 06:00:51 -0700222
223 # Run this one without saved_scan to complete test coverage
Simon Glass4a092352021-02-03 06:01:12 -0700224 dtb_platdata.run_steps(['struct'], dtb_file, False, output, [], None,
225 False)
Simon Glassc0791922017-06-18 22:09:06 -0600226 with open(output) as infile:
227 lines = infile.read().splitlines()
Simon Glassaab660f2017-11-12 21:52:17 -0700228 self.assertEqual(HEADER.splitlines(), lines)
Simon Glassc0791922017-06-18 22:09:06 -0600229
Walter Lozano361e7332020-06-25 01:10:08 -0300230 self.run_test(['platdata'], dtb_file, output)
Simon Glassc0791922017-06-18 22:09:06 -0600231 with open(output) as infile:
232 lines = infile.read().splitlines()
Simon Glassd960f0d2020-12-28 20:35:05 -0700233 self.assertEqual(C_HEADER.splitlines() + [''], lines)
Simon Glassc0791922017-06-18 22:09:06 -0600234
Simon Glass426d12f2021-02-03 06:01:14 -0700235 decl_text = DECL_HEADER + '''
236#include <dm/device-internal.h>
237#include <dm/uclass-internal.h>
238
239/* driver declarations - these allow DM_DRIVER_GET() to be used */
Simon Glasscff7dcf2021-03-15 17:25:11 +1300240extern U_BOOT_DRIVER(sandbox_i2c);
241extern U_BOOT_DRIVER(sandbox_pmic);
242extern U_BOOT_DRIVER(sandbox_spl_test);
243extern U_BOOT_DRIVER(sandbox_spl_test);
244extern U_BOOT_DRIVER(sandbox_spl_test);
Simon Glass426d12f2021-02-03 06:01:14 -0700245
246/* uclass driver declarations - needed for DM_UCLASS_DRIVER_REF() */
Simon Glasscff7dcf2021-03-15 17:25:11 +1300247extern UCLASS_DRIVER(i2c);
248extern UCLASS_DRIVER(misc);
249extern UCLASS_DRIVER(pmic);
Simon Glass426d12f2021-02-03 06:01:14 -0700250'''
251 decl_text_inst = DECL_HEADER + '''
252#include <dm/device-internal.h>
253#include <dm/uclass-internal.h>
254
255/* driver declarations - these allow DM_DRIVER_GET() to be used */
Simon Glasscff7dcf2021-03-15 17:25:11 +1300256extern U_BOOT_DRIVER(sandbox_i2c);
257extern U_BOOT_DRIVER(root_driver);
258extern U_BOOT_DRIVER(denx_u_boot_test_bus);
259extern U_BOOT_DRIVER(sandbox_spl_test);
260extern U_BOOT_DRIVER(sandbox_spl_test);
261extern U_BOOT_DRIVER(denx_u_boot_fdt_test);
262extern U_BOOT_DRIVER(denx_u_boot_fdt_test);
Simon Glass426d12f2021-02-03 06:01:14 -0700263
264/* device declarations - these allow DM_DEVICE_REF() to be used */
Simon Glasscff7dcf2021-03-15 17:25:11 +1300265extern DM_DEVICE_INST(i2c);
266extern DM_DEVICE_INST(root);
267extern DM_DEVICE_INST(some_bus);
268extern DM_DEVICE_INST(spl_test);
269extern DM_DEVICE_INST(spl_test3);
270extern DM_DEVICE_INST(test);
271extern DM_DEVICE_INST(test0);
Simon Glass426d12f2021-02-03 06:01:14 -0700272
273/* uclass driver declarations - needed for DM_UCLASS_DRIVER_REF() */
Simon Glasscff7dcf2021-03-15 17:25:11 +1300274extern UCLASS_DRIVER(i2c);
275extern UCLASS_DRIVER(misc);
276extern UCLASS_DRIVER(root);
277extern UCLASS_DRIVER(testbus);
278extern UCLASS_DRIVER(testfdt);
Simon Glass426d12f2021-02-03 06:01:14 -0700279
280/* uclass declarations - needed for DM_UCLASS_REF() */
Simon Glasscff7dcf2021-03-15 17:25:11 +1300281extern DM_UCLASS_INST(i2c);
282extern DM_UCLASS_INST(misc);
283extern DM_UCLASS_INST(root);
284extern DM_UCLASS_INST(testbus);
285extern DM_UCLASS_INST(testfdt);
Simon Glass426d12f2021-02-03 06:01:14 -0700286'''
Simon Glassde846cb2020-12-28 20:34:49 -0700287 struct_text = HEADER + '''
Simon Glassf38161c2021-02-03 06:00:57 -0700288struct dtd_sandbox_i2c {
Simon Glass5ec741f2017-08-29 14:15:51 -0600289};
Simon Glassf38161c2021-02-03 06:00:57 -0700290struct dtd_sandbox_pmic {
Simon Glass5ec741f2017-08-29 14:15:51 -0600291\tbool\t\tlow_power;
Simon Glass3e200ca2021-03-26 16:17:26 +1300292\tfdt32_t\t\treg[1];
Simon Glass5ec741f2017-08-29 14:15:51 -0600293};
Simon Glassc0791922017-06-18 22:09:06 -0600294struct dtd_sandbox_spl_test {
Simon Glassf02d0eb2020-07-07 21:32:06 -0600295\tconst char * acpi_name;
Simon Glassc0791922017-06-18 22:09:06 -0600296\tbool\t\tboolval;
297\tunsigned char\tbytearray[3];
298\tunsigned char\tbyteval;
Simon Glassd866e622021-11-23 11:03:39 -0700299\tfdt32_t\t\tint64val[2];
Simon Glassca044942021-07-28 19:23:10 -0600300\tfdt32_t\t\tintarray[3];
Simon Glassc0791922017-06-18 22:09:06 -0600301\tfdt32_t\t\tintval;
302\tunsigned char\tlongbytearray[9];
Simon Glasseec44c72021-07-28 19:23:11 -0600303\tfdt32_t\t\tmaybe_empty_int[1];
Simon Glass2a2d91d2018-07-06 10:27:28 -0600304\tunsigned char\tnotstring[5];
Simon Glassc0791922017-06-18 22:09:06 -0600305\tconst char *\tstringarray[3];
306\tconst char *\tstringval;
307};
Simon Glassde846cb2020-12-28 20:34:49 -0700308'''
Simon Glassde846cb2020-12-28 20:34:49 -0700309 platdata_text = C_HEADER + '''
Simon Glass4b91be22021-02-03 06:01:15 -0700310/*
Simon Glass9763e4e2021-02-03 06:01:19 -0700311 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
312 *
313 * idx driver_info driver
314 * --- -------------------- --------------------
315 * 0: i2c_at_0 sandbox_i2c
316 * 1: pmic_at_9 sandbox_pmic
317 * 2: spl_test sandbox_spl_test
318 * 3: spl_test2 sandbox_spl_test
319 * 4: spl_test3 sandbox_spl_test
320 * --- -------------------- --------------------
321 */
322
323/*
Simon Glass4b91be22021-02-03 06:01:15 -0700324 * Node /i2c@0 index 0
325 * driver sandbox_i2c parent None
326 */
Simon Glassf38161c2021-02-03 06:00:57 -0700327static struct dtd_sandbox_i2c dtv_i2c_at_0 = {
Simon Glass1b272732020-10-03 11:31:25 -0600328};
Simon Glass20e442a2020-12-28 20:34:54 -0700329U_BOOT_DRVINFO(i2c_at_0) = {
Simon Glassf38161c2021-02-03 06:00:57 -0700330\t.name\t\t= "sandbox_i2c",
Simon Glass9763e4e2021-02-03 06:01:19 -0700331\t.plat\t\t= &dtv_i2c_at_0,
Simon Glass4f500862020-12-03 16:55:19 -0700332\t.plat_size\t= sizeof(dtv_i2c_at_0),
Simon Glasse41651f2020-10-03 11:31:35 -0600333\t.parent_idx\t= -1,
Simon Glass1b272732020-10-03 11:31:25 -0600334};
335
Simon Glass4b91be22021-02-03 06:01:15 -0700336/*
337 * Node /i2c@0/pmic@9 index 1
338 * driver sandbox_pmic parent sandbox_i2c
339 */
Simon Glassf38161c2021-02-03 06:00:57 -0700340static struct dtd_sandbox_pmic dtv_pmic_at_9 = {
Simon Glass1b272732020-10-03 11:31:25 -0600341\t.low_power\t\t= true,
Simon Glass3e200ca2021-03-26 16:17:26 +1300342\t.reg\t\t\t= {0x9},
Simon Glass1b272732020-10-03 11:31:25 -0600343};
Simon Glass20e442a2020-12-28 20:34:54 -0700344U_BOOT_DRVINFO(pmic_at_9) = {
Simon Glassf38161c2021-02-03 06:00:57 -0700345\t.name\t\t= "sandbox_pmic",
Simon Glass9763e4e2021-02-03 06:01:19 -0700346\t.plat\t\t= &dtv_pmic_at_9,
Simon Glass4f500862020-12-03 16:55:19 -0700347\t.plat_size\t= sizeof(dtv_pmic_at_9),
Simon Glasse41651f2020-10-03 11:31:35 -0600348\t.parent_idx\t= 0,
Simon Glass1b272732020-10-03 11:31:25 -0600349};
350
Simon Glass4b91be22021-02-03 06:01:15 -0700351/*
352 * Node /spl-test index 2
353 * driver sandbox_spl_test parent None
354 */
Walter Lozano51f12632020-06-25 01:10:13 -0300355static struct dtd_sandbox_spl_test dtv_spl_test = {
Simon Glass1953ce72019-05-17 22:00:32 -0600356\t.boolval\t\t= true,
Simon Glassc0791922017-06-18 22:09:06 -0600357\t.bytearray\t\t= {0x6, 0x0, 0x0},
358\t.byteval\t\t= 0x5,
Simon Glassd866e622021-11-23 11:03:39 -0700359\t.int64val\t\t= {0x12345678, 0x9abcdef0},
Simon Glassca044942021-07-28 19:23:10 -0600360\t.intarray\t\t= {0x2, 0x3, 0x4},
Simon Glassc0791922017-06-18 22:09:06 -0600361\t.intval\t\t\t= 0x1,
Simon Glass21d54ac2017-08-29 14:15:49 -0600362\t.longbytearray\t\t= {0x9, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf, 0x10,
363\t\t0x11},
Simon Glasseec44c72021-07-28 19:23:11 -0600364\t.maybe_empty_int\t= {0x0},
Simon Glass1953ce72019-05-17 22:00:32 -0600365\t.notstring\t\t= {0x20, 0x21, 0x22, 0x10, 0x0},
Simon Glassc0791922017-06-18 22:09:06 -0600366\t.stringarray\t\t= {"multi-word", "message", ""},
Simon Glass1953ce72019-05-17 22:00:32 -0600367\t.stringval\t\t= "message",
Simon Glassc0791922017-06-18 22:09:06 -0600368};
Simon Glass20e442a2020-12-28 20:34:54 -0700369U_BOOT_DRVINFO(spl_test) = {
Simon Glassc0791922017-06-18 22:09:06 -0600370\t.name\t\t= "sandbox_spl_test",
Simon Glass9763e4e2021-02-03 06:01:19 -0700371\t.plat\t\t= &dtv_spl_test,
Simon Glass4f500862020-12-03 16:55:19 -0700372\t.plat_size\t= sizeof(dtv_spl_test),
Simon Glasse41651f2020-10-03 11:31:35 -0600373\t.parent_idx\t= -1,
Simon Glassc0791922017-06-18 22:09:06 -0600374};
375
Simon Glass4b91be22021-02-03 06:01:15 -0700376/*
377 * Node /spl-test2 index 3
378 * driver sandbox_spl_test parent None
379 */
Walter Lozano51f12632020-06-25 01:10:13 -0300380static struct dtd_sandbox_spl_test dtv_spl_test2 = {
Simon Glassf02d0eb2020-07-07 21:32:06 -0600381\t.acpi_name\t\t= "\\\\_SB.GPO0",
Simon Glassc0791922017-06-18 22:09:06 -0600382\t.bytearray\t\t= {0x1, 0x23, 0x34},
383\t.byteval\t\t= 0x8,
Simon Glassca044942021-07-28 19:23:10 -0600384\t.intarray\t\t= {0x5, 0x0, 0x0},
Simon Glassc0791922017-06-18 22:09:06 -0600385\t.intval\t\t\t= 0x3,
Simon Glasse144caf2020-10-03 11:31:27 -0600386\t.longbytearray\t\t= {0x9, 0xa, 0xb, 0xc, 0x0, 0x0, 0x0, 0x0,
Simon Glass21d54ac2017-08-29 14:15:49 -0600387\t\t0x0},
Simon Glassc0791922017-06-18 22:09:06 -0600388\t.stringarray\t\t= {"another", "multi-word", "message"},
Simon Glass1953ce72019-05-17 22:00:32 -0600389\t.stringval\t\t= "message2",
Simon Glassc0791922017-06-18 22:09:06 -0600390};
Simon Glass20e442a2020-12-28 20:34:54 -0700391U_BOOT_DRVINFO(spl_test2) = {
Simon Glassc0791922017-06-18 22:09:06 -0600392\t.name\t\t= "sandbox_spl_test",
Simon Glass9763e4e2021-02-03 06:01:19 -0700393\t.plat\t\t= &dtv_spl_test2,
Simon Glass4f500862020-12-03 16:55:19 -0700394\t.plat_size\t= sizeof(dtv_spl_test2),
Simon Glasse41651f2020-10-03 11:31:35 -0600395\t.parent_idx\t= -1,
Simon Glassc0791922017-06-18 22:09:06 -0600396};
397
Simon Glass4b91be22021-02-03 06:01:15 -0700398/*
399 * Node /spl-test3 index 4
400 * driver sandbox_spl_test parent None
401 */
Walter Lozano51f12632020-06-25 01:10:13 -0300402static struct dtd_sandbox_spl_test dtv_spl_test3 = {
Simon Glasse144caf2020-10-03 11:31:27 -0600403\t.longbytearray\t\t= {0x9, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf, 0x10,
404\t\t0x0},
Simon Glasseec44c72021-07-28 19:23:11 -0600405\t.maybe_empty_int\t= {0x1},
Simon Glassc0791922017-06-18 22:09:06 -0600406\t.stringarray\t\t= {"one", "", ""},
407};
Simon Glass20e442a2020-12-28 20:34:54 -0700408U_BOOT_DRVINFO(spl_test3) = {
Simon Glassc0791922017-06-18 22:09:06 -0600409\t.name\t\t= "sandbox_spl_test",
Simon Glass9763e4e2021-02-03 06:01:19 -0700410\t.plat\t\t= &dtv_spl_test3,
Simon Glass4f500862020-12-03 16:55:19 -0700411\t.plat_size\t= sizeof(dtv_spl_test3),
Simon Glasse41651f2020-10-03 11:31:35 -0600412\t.parent_idx\t= -1,
Simon Glassc0791922017-06-18 22:09:06 -0600413};
414
Simon Glassd960f0d2020-12-28 20:35:05 -0700415'''
Simon Glassea74c952021-02-03 06:01:20 -0700416 uclass_text_inst = '''
417
418#include <common.h>
419#include <dm.h>
420#include <dt-structs.h>
421
422/*
Simon Glassd392d322021-02-03 06:01:21 -0700423 * uclass declarations, ordered by 'struct uclass' linker_list idx:
424 * 0: i2c
425 * 1: misc
426 * 2: root
427 * 3: testbus
428 * 4: testfdt
Simon Glassea74c952021-02-03 06:01:20 -0700429 *
Simon Glassd392d322021-02-03 06:01:21 -0700430 * Sequence numbers allocated in each uclass:
Simon Glassea74c952021-02-03 06:01:20 -0700431 * i2c: UCLASS_I2C
432 * 4: /i2c
433 * misc: UCLASS_MISC
434 * 0: /spl-test
435 * 1: /spl-test3
436 * root: UCLASS_ROOT
437 * 0: /
438 * testbus: UCLASS_TEST_BUS
439 * 2: /some-bus
440 * testfdt: UCLASS_TEST_FDT
441 * 1: /some-bus/test
442 * 2: /some-bus/test0
443 */
444
445struct list_head uclass_head = {
446 .prev = &DM_UCLASS_REF(testfdt)->sibling_node,
447 .next = &DM_UCLASS_REF(i2c)->sibling_node,
448};
449
450DM_UCLASS_INST(i2c) = {
451 .uc_drv = DM_UCLASS_DRIVER_REF(i2c),
452 .sibling_node = {
453 .prev = &uclass_head,
454 .next = &DM_UCLASS_REF(misc)->sibling_node,
455 },
456 .dev_head = {
457 .prev = &DM_DEVICE_REF(i2c)->uclass_node,
458 .next = &DM_DEVICE_REF(i2c)->uclass_node,
459 },
460};
461
462DM_UCLASS_INST(misc) = {
463 .uc_drv = DM_UCLASS_DRIVER_REF(misc),
464 .sibling_node = {
465 .prev = &DM_UCLASS_REF(i2c)->sibling_node,
466 .next = &DM_UCLASS_REF(root)->sibling_node,
467 },
468 .dev_head = {
469 .prev = &DM_DEVICE_REF(spl_test3)->uclass_node,
470 .next = &DM_DEVICE_REF(spl_test)->uclass_node,
471 },
472};
473
474DM_UCLASS_INST(root) = {
475 .uc_drv = DM_UCLASS_DRIVER_REF(root),
476 .sibling_node = {
477 .prev = &DM_UCLASS_REF(misc)->sibling_node,
478 .next = &DM_UCLASS_REF(testbus)->sibling_node,
479 },
480 .dev_head = {
481 .prev = &DM_DEVICE_REF(root)->uclass_node,
482 .next = &DM_DEVICE_REF(root)->uclass_node,
483 },
484};
485
486DM_UCLASS_INST(testbus) = {
487 .uc_drv = DM_UCLASS_DRIVER_REF(testbus),
488 .sibling_node = {
489 .prev = &DM_UCLASS_REF(root)->sibling_node,
490 .next = &DM_UCLASS_REF(testfdt)->sibling_node,
491 },
492 .dev_head = {
493 .prev = &DM_DEVICE_REF(some_bus)->uclass_node,
494 .next = &DM_DEVICE_REF(some_bus)->uclass_node,
495 },
496};
497
498#include <dm/test.h>
499u8 _testfdt_priv_[sizeof(struct dm_test_uc_priv)]
500 __attribute__ ((section (".priv_data")));
501DM_UCLASS_INST(testfdt) = {
502 .priv_ = _testfdt_priv_,
503 .uc_drv = DM_UCLASS_DRIVER_REF(testfdt),
504 .sibling_node = {
505 .prev = &DM_UCLASS_REF(testbus)->sibling_node,
506 .next = &uclass_head,
507 },
508 .dev_head = {
509 .prev = &DM_DEVICE_REF(test0)->uclass_node,
510 .next = &DM_DEVICE_REF(test)->uclass_node,
511 },
512};
513
514'''
Simon Glassd392d322021-02-03 06:01:21 -0700515 device_text_inst = '''/*
516 * DO NOT MODIFY
517 *
518 * Declares the DM_DEVICE_INST() records.
519 * This was generated by dtoc from a .dtb (device tree binary) file.
520 */
521
522#include <common.h>
523#include <dm.h>
524#include <dt-structs.h>
525
526/*
527 * udevice declarations, ordered by 'struct udevice' linker_list position:
528 *
529 * idx udevice driver
530 * --- -------------------- --------------------
531 * 0: i2c sandbox_i2c
532 * 1: root root_driver
533 * 2: some_bus denx_u_boot_test_bus
534 * 3: spl_test sandbox_spl_test
535 * 4: spl_test3 sandbox_spl_test
536 * 5: test denx_u_boot_fdt_test
537 * 6: test0 denx_u_boot_fdt_test
538 * --- -------------------- --------------------
539 */
540
541/*
542 * Node /i2c index 0
543 * driver sandbox_i2c parent root_driver
544*/
545static struct dtd_sandbox_i2c dtv_i2c = {
546\t.intval\t\t\t= 0x3,
547};
548
549#include <asm/i2c.h>
550u8 _sandbox_i2c_priv_i2c[sizeof(struct sandbox_i2c_priv)]
551\t__attribute__ ((section (".priv_data")));
552#include <i2c.h>
553u8 _sandbox_i2c_uc_priv_i2c[sizeof(struct dm_i2c_bus)]
554\t__attribute__ ((section (".priv_data")));
555
556DM_DEVICE_INST(i2c) = {
557\t.driver\t\t= DM_DRIVER_REF(sandbox_i2c),
558\t.name\t\t= "sandbox_i2c",
559\t.plat_\t\t= &dtv_i2c,
560\t.priv_\t\t= _sandbox_i2c_priv_i2c,
561\t.uclass\t\t= DM_UCLASS_REF(i2c),
562\t.uclass_priv_ = _sandbox_i2c_uc_priv_i2c,
563\t.uclass_node\t= {
564\t\t.prev = &DM_UCLASS_REF(i2c)->dev_head,
565\t\t.next = &DM_UCLASS_REF(i2c)->dev_head,
566\t},
567\t.child_head\t= {
568\t\t.prev = &DM_DEVICE_REF(i2c)->child_head,
569\t\t.next = &DM_DEVICE_REF(i2c)->child_head,
570\t},
571\t.sibling_node\t= {
572\t\t.prev = &DM_DEVICE_REF(root)->child_head,
573\t\t.next = &DM_DEVICE_REF(some_bus)->sibling_node,
574\t},
575\t.seq_ = 4,
576};
577
578/*
579 * Node / index 1
580 * driver root_driver parent None
581*/
582static struct dtd_root_driver dtv_root = {
583};
584
585DM_DEVICE_INST(root) = {
586\t.driver\t\t= DM_DRIVER_REF(root_driver),
587\t.name\t\t= "root_driver",
588\t.plat_\t\t= &dtv_root,
589\t.uclass\t\t= DM_UCLASS_REF(root),
590\t.uclass_node\t= {
591\t\t.prev = &DM_UCLASS_REF(root)->dev_head,
592\t\t.next = &DM_UCLASS_REF(root)->dev_head,
593\t},
594\t.child_head\t= {
595\t\t.prev = &DM_DEVICE_REF(spl_test3)->sibling_node,
596\t\t.next = &DM_DEVICE_REF(i2c)->sibling_node,
597\t},
598\t.seq_ = 0,
599};
600
601/*
602 * Node /some-bus index 2
603 * driver denx_u_boot_test_bus parent root_driver
604*/
605
606#include <dm/test.h>
607struct dm_test_pdata __attribute__ ((section (".priv_data")))
608\t_denx_u_boot_test_bus_plat_some_bus = {
609\t.dtplat = {
610\t\t.ping_add\t\t= 0x4,
611\t\t.ping_expect\t\t= 0x4,
612\t\t.reg\t\t\t= {0x3, 0x1},
613\t},
614};
615#include <dm/test.h>
616u8 _denx_u_boot_test_bus_priv_some_bus[sizeof(struct dm_test_priv)]
617\t__attribute__ ((section (".priv_data")));
618#include <dm/test.h>
Simon Glass53c20be2022-05-08 04:39:23 -0600619u8 _denx_u_boot_test_bus_ucplat_some_bus[sizeof(struct dm_test_uclass_plat)]
Simon Glassd392d322021-02-03 06:01:21 -0700620\t__attribute__ ((section (".priv_data")));
Simon Glass930a3dd2022-05-08 04:39:24 -0600621#include <dm/test.h>
622u8 _denx_u_boot_test_bus_uc_priv_some_bus[sizeof(struct dm_test_uclass_priv)]
623 __attribute__ ((section (".priv_data")));
Simon Glassd392d322021-02-03 06:01:21 -0700624#include <test.h>
625
626DM_DEVICE_INST(some_bus) = {
627\t.driver\t\t= DM_DRIVER_REF(denx_u_boot_test_bus),
628\t.name\t\t= "denx_u_boot_test_bus",
629\t.plat_\t\t= &_denx_u_boot_test_bus_plat_some_bus,
630\t.uclass_plat_\t= _denx_u_boot_test_bus_ucplat_some_bus,
631\t.driver_data\t= DM_TEST_TYPE_FIRST,
632\t.priv_\t\t= _denx_u_boot_test_bus_priv_some_bus,
633\t.uclass\t\t= DM_UCLASS_REF(testbus),
Simon Glass930a3dd2022-05-08 04:39:24 -0600634\t.uclass_priv_ = _denx_u_boot_test_bus_uc_priv_some_bus,
Simon Glassd392d322021-02-03 06:01:21 -0700635\t.uclass_node\t= {
636\t\t.prev = &DM_UCLASS_REF(testbus)->dev_head,
637\t\t.next = &DM_UCLASS_REF(testbus)->dev_head,
638\t},
639\t.child_head\t= {
640\t\t.prev = &DM_DEVICE_REF(test0)->sibling_node,
641\t\t.next = &DM_DEVICE_REF(test)->sibling_node,
642\t},
643\t.sibling_node\t= {
644\t\t.prev = &DM_DEVICE_REF(i2c)->sibling_node,
645\t\t.next = &DM_DEVICE_REF(spl_test)->sibling_node,
646\t},
647\t.seq_ = 2,
648};
649
650/*
651 * Node /spl-test index 3
652 * driver sandbox_spl_test parent root_driver
653*/
654static struct dtd_sandbox_spl_test dtv_spl_test = {
655\t.boolval\t\t= true,
656\t.intval\t\t\t= 0x1,
657};
658
659DM_DEVICE_INST(spl_test) = {
660\t.driver\t\t= DM_DRIVER_REF(sandbox_spl_test),
661\t.name\t\t= "sandbox_spl_test",
662\t.plat_\t\t= &dtv_spl_test,
663\t.uclass\t\t= DM_UCLASS_REF(misc),
664\t.uclass_node\t= {
665\t\t.prev = &DM_UCLASS_REF(misc)->dev_head,
666\t\t.next = &DM_DEVICE_REF(spl_test3)->uclass_node,
667\t},
668\t.child_head\t= {
669\t\t.prev = &DM_DEVICE_REF(spl_test)->child_head,
670\t\t.next = &DM_DEVICE_REF(spl_test)->child_head,
671\t},
672\t.sibling_node\t= {
673\t\t.prev = &DM_DEVICE_REF(some_bus)->sibling_node,
674\t\t.next = &DM_DEVICE_REF(spl_test3)->sibling_node,
675\t},
676\t.seq_ = 0,
677};
678
679/*
680 * Node /spl-test3 index 4
681 * driver sandbox_spl_test parent root_driver
682*/
683static struct dtd_sandbox_spl_test dtv_spl_test3 = {
684\t.longbytearray\t\t= {0x90a0b0c, 0xd0e0f10},
685\t.stringarray\t\t= "one",
686};
687
688DM_DEVICE_INST(spl_test3) = {
689\t.driver\t\t= DM_DRIVER_REF(sandbox_spl_test),
690\t.name\t\t= "sandbox_spl_test",
691\t.plat_\t\t= &dtv_spl_test3,
692\t.uclass\t\t= DM_UCLASS_REF(misc),
693\t.uclass_node\t= {
694\t\t.prev = &DM_DEVICE_REF(spl_test)->uclass_node,
695\t\t.next = &DM_UCLASS_REF(misc)->dev_head,
696\t},
697\t.child_head\t= {
698\t\t.prev = &DM_DEVICE_REF(spl_test3)->child_head,
699\t\t.next = &DM_DEVICE_REF(spl_test3)->child_head,
700\t},
701\t.sibling_node\t= {
702\t\t.prev = &DM_DEVICE_REF(spl_test)->sibling_node,
703\t\t.next = &DM_DEVICE_REF(root)->child_head,
704\t},
705\t.seq_ = 1,
706};
707
708/*
709 * Node /some-bus/test index 5
710 * driver denx_u_boot_fdt_test parent denx_u_boot_test_bus
711*/
712
713#include <dm/test.h>
714struct dm_test_pdata __attribute__ ((section (".priv_data")))
715\t_denx_u_boot_fdt_test_plat_test = {
716\t.dtplat = {
717\t\t.ping_add\t\t= 0x5,
718\t\t.ping_expect\t\t= 0x5,
Simon Glass3e200ca2021-03-26 16:17:26 +1300719\t\t.reg\t\t\t= {0x5},
Simon Glassd392d322021-02-03 06:01:21 -0700720\t},
721};
722#include <dm/test.h>
723u8 _denx_u_boot_fdt_test_priv_test[sizeof(struct dm_test_priv)]
724\t__attribute__ ((section (".priv_data")));
725#include <dm/test.h>
726u8 _denx_u_boot_fdt_test_parent_plat_test[sizeof(struct dm_test_parent_plat)]
727\t__attribute__ ((section (".priv_data")));
728#include <dm/test.h>
729u8 _denx_u_boot_fdt_test_parent_priv_test[sizeof(struct dm_test_parent_data)]
730\t__attribute__ ((section (".priv_data")));
731
732DM_DEVICE_INST(test) = {
733\t.driver\t\t= DM_DRIVER_REF(denx_u_boot_fdt_test),
734\t.name\t\t= "denx_u_boot_fdt_test",
735\t.plat_\t\t= &_denx_u_boot_fdt_test_plat_test,
736\t.parent_plat_\t= _denx_u_boot_fdt_test_parent_plat_test,
737\t.driver_data\t= DM_TEST_TYPE_FIRST,
738\t.parent\t\t= DM_DEVICE_REF(some_bus),
739\t.priv_\t\t= _denx_u_boot_fdt_test_priv_test,
740\t.uclass\t\t= DM_UCLASS_REF(testfdt),
741\t.parent_priv_\t= _denx_u_boot_fdt_test_parent_priv_test,
742\t.uclass_node\t= {
743\t\t.prev = &DM_UCLASS_REF(testfdt)->dev_head,
744\t\t.next = &DM_DEVICE_REF(test0)->uclass_node,
745\t},
746\t.child_head\t= {
747\t\t.prev = &DM_DEVICE_REF(test)->child_head,
748\t\t.next = &DM_DEVICE_REF(test)->child_head,
749\t},
750\t.sibling_node\t= {
751\t\t.prev = &DM_DEVICE_REF(some_bus)->child_head,
752\t\t.next = &DM_DEVICE_REF(test0)->sibling_node,
753\t},
754\t.seq_ = 1,
755};
756
757/*
758 * Node /some-bus/test0 index 6
759 * driver denx_u_boot_fdt_test parent denx_u_boot_test_bus
760*/
761
762#include <dm/test.h>
763struct dm_test_pdata __attribute__ ((section (".priv_data")))
764\t_denx_u_boot_fdt_test_plat_test0 = {
765\t.dtplat = {
766\t},
767};
768#include <dm/test.h>
769u8 _denx_u_boot_fdt_test_priv_test0[sizeof(struct dm_test_priv)]
770\t__attribute__ ((section (".priv_data")));
771#include <dm/test.h>
772u8 _denx_u_boot_fdt_test_parent_plat_test0[sizeof(struct dm_test_parent_plat)]
773\t__attribute__ ((section (".priv_data")));
774#include <dm/test.h>
775u8 _denx_u_boot_fdt_test_parent_priv_test0[sizeof(struct dm_test_parent_data)]
776\t__attribute__ ((section (".priv_data")));
777
778DM_DEVICE_INST(test0) = {
779\t.driver\t\t= DM_DRIVER_REF(denx_u_boot_fdt_test),
780\t.name\t\t= "denx_u_boot_fdt_test",
781\t.plat_\t\t= &_denx_u_boot_fdt_test_plat_test0,
782\t.parent_plat_\t= _denx_u_boot_fdt_test_parent_plat_test0,
783\t.driver_data\t= DM_TEST_TYPE_SECOND,
784\t.parent\t\t= DM_DEVICE_REF(some_bus),
785\t.priv_\t\t= _denx_u_boot_fdt_test_priv_test0,
786\t.uclass\t\t= DM_UCLASS_REF(testfdt),
787\t.parent_priv_\t= _denx_u_boot_fdt_test_parent_priv_test0,
788\t.uclass_node\t= {
789\t\t.prev = &DM_DEVICE_REF(test)->uclass_node,
790\t\t.next = &DM_UCLASS_REF(testfdt)->dev_head,
791\t},
792\t.child_head\t= {
793\t\t.prev = &DM_DEVICE_REF(test0)->child_head,
794\t\t.next = &DM_DEVICE_REF(test0)->child_head,
795\t},
796\t.sibling_node\t= {
797\t\t.prev = &DM_DEVICE_REF(test)->sibling_node,
798\t\t.next = &DM_DEVICE_REF(some_bus)->child_head,
799\t},
800\t.seq_ = 2,
801};
802
803'''
Simon Glassde846cb2020-12-28 20:34:49 -0700804
805 def test_simple(self):
806 """Test output from some simple nodes with various types of data"""
807 dtb_file = get_dtb_file('dtoc_test_simple.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -0700808 output = tools.get_output_filename('output')
Simon Glassde846cb2020-12-28 20:34:49 -0700809 self.run_test(['struct'], dtb_file, output)
810 with open(output) as infile:
811 data = infile.read()
812
813 self._check_strings(self.struct_text, data)
814
815 self.run_test(['platdata'], dtb_file, output)
816 with open(output) as infile:
817 data = infile.read()
818
819 self._check_strings(self.platdata_text, data)
Simon Glassc0791922017-06-18 22:09:06 -0600820
Simon Glass426d12f2021-02-03 06:01:14 -0700821 self.run_test(['decl'], dtb_file, output)
822 with open(output) as infile:
823 data = infile.read()
824
825 self._check_strings(self.decl_text, data)
826
Simon Glass10cbd3b2020-12-28 20:34:52 -0700827 # Try the 'all' command
828 self.run_test(['all'], dtb_file, output)
Simon Glassc1aa66e2022-01-29 14:14:04 -0700829 data = tools.read_file(output, binary=False)
Simon Glassd392d322021-02-03 06:01:21 -0700830 self._check_strings(
Simon Glass17073252021-04-27 08:19:48 +1200831 self.decl_text + self.platdata_text + self.struct_text, data)
Simon Glass10cbd3b2020-12-28 20:34:52 -0700832
Walter Lozanodac82282020-07-03 08:07:17 -0300833 def test_driver_alias(self):
834 """Test output from a device tree file with a driver alias"""
835 dtb_file = get_dtb_file('dtoc_test_driver_alias.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -0700836 output = tools.get_output_filename('output')
Walter Lozano361e7332020-06-25 01:10:08 -0300837 self.run_test(['struct'], dtb_file, output)
Walter Lozanodac82282020-07-03 08:07:17 -0300838 with open(output) as infile:
839 data = infile.read()
Simon Glass67b5ec52020-12-28 20:34:47 -0700840 self._check_strings(HEADER + '''
Walter Lozanodac82282020-07-03 08:07:17 -0300841struct dtd_sandbox_gpio {
842\tconst char *\tgpio_bank_name;
843\tbool\t\tgpio_controller;
844\tfdt32_t\t\tsandbox_gpio_count;
845};
Walter Lozanodac82282020-07-03 08:07:17 -0300846''', data)
847
Walter Lozano361e7332020-06-25 01:10:08 -0300848 self.run_test(['platdata'], dtb_file, output)
Walter Lozanodac82282020-07-03 08:07:17 -0300849 with open(output) as infile:
850 data = infile.read()
Simon Glass67b5ec52020-12-28 20:34:47 -0700851 self._check_strings(C_HEADER + '''
Simon Glass4b91be22021-02-03 06:01:15 -0700852/*
Simon Glass9763e4e2021-02-03 06:01:19 -0700853 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
854 *
855 * idx driver_info driver
856 * --- -------------------- --------------------
857 * 0: gpios_at_0 sandbox_gpio
858 * --- -------------------- --------------------
859 */
860
861/*
Simon Glass4b91be22021-02-03 06:01:15 -0700862 * Node /gpios@0 index 0
863 * driver sandbox_gpio parent None
864 */
Walter Lozano51f12632020-06-25 01:10:13 -0300865static struct dtd_sandbox_gpio dtv_gpios_at_0 = {
Walter Lozanodac82282020-07-03 08:07:17 -0300866\t.gpio_bank_name\t\t= "a",
867\t.gpio_controller\t= true,
868\t.sandbox_gpio_count\t= 0x14,
869};
Simon Glass20e442a2020-12-28 20:34:54 -0700870U_BOOT_DRVINFO(gpios_at_0) = {
Walter Lozanodac82282020-07-03 08:07:17 -0300871\t.name\t\t= "sandbox_gpio",
Simon Glass9763e4e2021-02-03 06:01:19 -0700872\t.plat\t\t= &dtv_gpios_at_0,
Simon Glass4f500862020-12-03 16:55:19 -0700873\t.plat_size\t= sizeof(dtv_gpios_at_0),
Simon Glasse41651f2020-10-03 11:31:35 -0600874\t.parent_idx\t= -1,
Walter Lozanodac82282020-07-03 08:07:17 -0300875};
876
877''', data)
878
Walter Lozano361e7332020-06-25 01:10:08 -0300879 def test_invalid_driver(self):
880 """Test output from a device tree file with an invalid driver"""
881 dtb_file = get_dtb_file('dtoc_test_invalid_driver.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -0700882 output = tools.get_output_filename('output')
Simon Glass67b5ec52020-12-28 20:34:47 -0700883 with test_util.capture_sys_output() as _:
Simon Glass4a092352021-02-03 06:01:12 -0700884 dtb_platdata.run_steps(
885 ['struct'], dtb_file, False, output, [], None, False,
886 scan=copy_scan())
Walter Lozano361e7332020-06-25 01:10:08 -0300887 with open(output) as infile:
888 data = infile.read()
Simon Glass67b5ec52020-12-28 20:34:47 -0700889 self._check_strings(HEADER + '''
Walter Lozano361e7332020-06-25 01:10:08 -0300890struct dtd_invalid {
891};
892''', data)
893
Simon Glass67b5ec52020-12-28 20:34:47 -0700894 with test_util.capture_sys_output() as _:
Simon Glass4a092352021-02-03 06:01:12 -0700895 dtb_platdata.run_steps(
896 ['platdata'], dtb_file, False, output, [], None, False,
897 scan=copy_scan())
Walter Lozano361e7332020-06-25 01:10:08 -0300898 with open(output) as infile:
899 data = infile.read()
Simon Glass67b5ec52020-12-28 20:34:47 -0700900 self._check_strings(C_HEADER + '''
Simon Glass9763e4e2021-02-03 06:01:19 -0700901/*
902 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
903 *
904 * idx driver_info driver
905 * --- -------------------- --------------------
906 * 0: spl_test invalid
907 * --- -------------------- --------------------
908 */
909
Simon Glass1b272732020-10-03 11:31:25 -0600910/* Node /spl-test index 0 */
Walter Lozano51f12632020-06-25 01:10:13 -0300911static struct dtd_invalid dtv_spl_test = {
Walter Lozano361e7332020-06-25 01:10:08 -0300912};
Simon Glass20e442a2020-12-28 20:34:54 -0700913U_BOOT_DRVINFO(spl_test) = {
Walter Lozano361e7332020-06-25 01:10:08 -0300914\t.name\t\t= "invalid",
Simon Glass9763e4e2021-02-03 06:01:19 -0700915\t.plat\t\t= &dtv_spl_test,
Simon Glass4f500862020-12-03 16:55:19 -0700916\t.plat_size\t= sizeof(dtv_spl_test),
Simon Glasse41651f2020-10-03 11:31:35 -0600917\t.parent_idx\t= -1,
Walter Lozano361e7332020-06-25 01:10:08 -0300918};
919
920''', data)
921
Simon Glassc0791922017-06-18 22:09:06 -0600922 def test_phandle(self):
923 """Test output from a node containing a phandle reference"""
924 dtb_file = get_dtb_file('dtoc_test_phandle.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -0700925 output = tools.get_output_filename('output')
Walter Lozano361e7332020-06-25 01:10:08 -0300926 self.run_test(['struct'], dtb_file, output)
Simon Glassc0791922017-06-18 22:09:06 -0600927 with open(output) as infile:
928 data = infile.read()
Simon Glass67b5ec52020-12-28 20:34:47 -0700929 self._check_strings(HEADER + '''
Simon Glassc0791922017-06-18 22:09:06 -0600930struct dtd_source {
Simon Glass634eba42017-08-29 14:15:59 -0600931\tstruct phandle_2_arg clocks[4];
Simon Glassc0791922017-06-18 22:09:06 -0600932};
933struct dtd_target {
934\tfdt32_t\t\tintval;
935};
936''', data)
937
Walter Lozano361e7332020-06-25 01:10:08 -0300938 self.run_test(['platdata'], dtb_file, output)
Simon Glassc0791922017-06-18 22:09:06 -0600939 with open(output) as infile:
940 data = infile.read()
Simon Glass67b5ec52020-12-28 20:34:47 -0700941 self._check_strings(C_HEADER + '''
Simon Glass9763e4e2021-02-03 06:01:19 -0700942/*
943 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
944 *
945 * idx driver_info driver
946 * --- -------------------- --------------------
947 * 0: phandle2_target target
948 * 1: phandle3_target target
949 * 2: phandle_source source
950 * 3: phandle_source2 source
951 * 4: phandle_target target
952 * --- -------------------- --------------------
953 */
954
Simon Glass1b272732020-10-03 11:31:25 -0600955/* Node /phandle2-target index 0 */
Walter Lozano51f12632020-06-25 01:10:13 -0300956static struct dtd_target dtv_phandle2_target = {
Simon Glass634eba42017-08-29 14:15:59 -0600957\t.intval\t\t\t= 0x1,
958};
Simon Glass20e442a2020-12-28 20:34:54 -0700959U_BOOT_DRVINFO(phandle2_target) = {
Simon Glass634eba42017-08-29 14:15:59 -0600960\t.name\t\t= "target",
Simon Glass9763e4e2021-02-03 06:01:19 -0700961\t.plat\t\t= &dtv_phandle2_target,
Simon Glass4f500862020-12-03 16:55:19 -0700962\t.plat_size\t= sizeof(dtv_phandle2_target),
Simon Glasse41651f2020-10-03 11:31:35 -0600963\t.parent_idx\t= -1,
Simon Glass634eba42017-08-29 14:15:59 -0600964};
965
Simon Glass1b272732020-10-03 11:31:25 -0600966/* Node /phandle3-target index 1 */
Walter Lozano51f12632020-06-25 01:10:13 -0300967static struct dtd_target dtv_phandle3_target = {
Simon Glass634eba42017-08-29 14:15:59 -0600968\t.intval\t\t\t= 0x2,
969};
Simon Glass20e442a2020-12-28 20:34:54 -0700970U_BOOT_DRVINFO(phandle3_target) = {
Simon Glass634eba42017-08-29 14:15:59 -0600971\t.name\t\t= "target",
Simon Glass9763e4e2021-02-03 06:01:19 -0700972\t.plat\t\t= &dtv_phandle3_target,
Simon Glass4f500862020-12-03 16:55:19 -0700973\t.plat_size\t= sizeof(dtv_phandle3_target),
Simon Glasse41651f2020-10-03 11:31:35 -0600974\t.parent_idx\t= -1,
Simon Glass634eba42017-08-29 14:15:59 -0600975};
976
Simon Glass1b272732020-10-03 11:31:25 -0600977/* Node /phandle-source index 2 */
Walter Lozano51f12632020-06-25 01:10:13 -0300978static struct dtd_source dtv_phandle_source = {
Simon Glass35d50372017-08-29 14:15:57 -0600979\t.clocks\t\t\t= {
Simon Glass8a38abf2020-10-03 11:31:40 -0600980\t\t\t{4, {}},
981\t\t\t{0, {11}},
982\t\t\t{1, {12, 13}},
983\t\t\t{4, {}},},
Simon Glassc0791922017-06-18 22:09:06 -0600984};
Simon Glass20e442a2020-12-28 20:34:54 -0700985U_BOOT_DRVINFO(phandle_source) = {
Simon Glassc0791922017-06-18 22:09:06 -0600986\t.name\t\t= "source",
Simon Glass9763e4e2021-02-03 06:01:19 -0700987\t.plat\t\t= &dtv_phandle_source,
Simon Glass4f500862020-12-03 16:55:19 -0700988\t.plat_size\t= sizeof(dtv_phandle_source),
Simon Glasse41651f2020-10-03 11:31:35 -0600989\t.parent_idx\t= -1,
Simon Glassc0791922017-06-18 22:09:06 -0600990};
991
Simon Glass1b272732020-10-03 11:31:25 -0600992/* Node /phandle-source2 index 3 */
Walter Lozano51f12632020-06-25 01:10:13 -0300993static struct dtd_source dtv_phandle_source2 = {
Simon Glass760b7172018-07-06 10:27:31 -0600994\t.clocks\t\t\t= {
Simon Glass8a38abf2020-10-03 11:31:40 -0600995\t\t\t{4, {}},},
Simon Glass760b7172018-07-06 10:27:31 -0600996};
Simon Glass20e442a2020-12-28 20:34:54 -0700997U_BOOT_DRVINFO(phandle_source2) = {
Simon Glass760b7172018-07-06 10:27:31 -0600998\t.name\t\t= "source",
Simon Glass9763e4e2021-02-03 06:01:19 -0700999\t.plat\t\t= &dtv_phandle_source2,
Simon Glass4f500862020-12-03 16:55:19 -07001000\t.plat_size\t= sizeof(dtv_phandle_source2),
Simon Glasse41651f2020-10-03 11:31:35 -06001001\t.parent_idx\t= -1,
Simon Glass760b7172018-07-06 10:27:31 -06001002};
1003
Simon Glass9eca08d2020-12-28 20:35:04 -07001004/* Node /phandle-target index 4 */
1005static struct dtd_target dtv_phandle_target = {
1006\t.intval\t\t\t= 0x0,
1007};
1008U_BOOT_DRVINFO(phandle_target) = {
1009\t.name\t\t= "target",
Simon Glass9763e4e2021-02-03 06:01:19 -07001010\t.plat\t\t= &dtv_phandle_target,
Simon Glass9eca08d2020-12-28 20:35:04 -07001011\t.plat_size\t= sizeof(dtv_phandle_target),
1012\t.parent_idx\t= -1,
1013};
1014
Simon Glassc0791922017-06-18 22:09:06 -06001015''', data)
1016
Simon Glass8512ea22018-07-06 10:27:35 -06001017 def test_phandle_single(self):
1018 """Test output from a node containing a phandle reference"""
1019 dtb_file = get_dtb_file('dtoc_test_phandle_single.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -07001020 output = tools.get_output_filename('output')
Walter Lozano361e7332020-06-25 01:10:08 -03001021 self.run_test(['struct'], dtb_file, output)
Simon Glass8512ea22018-07-06 10:27:35 -06001022 with open(output) as infile:
1023 data = infile.read()
Simon Glass67b5ec52020-12-28 20:34:47 -07001024 self._check_strings(HEADER + '''
Simon Glass8512ea22018-07-06 10:27:35 -06001025struct dtd_source {
1026\tstruct phandle_0_arg clocks[1];
1027};
1028struct dtd_target {
1029\tfdt32_t\t\tintval;
1030};
1031''', data)
1032
1033 def test_phandle_reorder(self):
1034 """Test that phandle targets are generated before their references"""
1035 dtb_file = get_dtb_file('dtoc_test_phandle_reorder.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -07001036 output = tools.get_output_filename('output')
Walter Lozano361e7332020-06-25 01:10:08 -03001037 self.run_test(['platdata'], dtb_file, output)
Simon Glass8512ea22018-07-06 10:27:35 -06001038 with open(output) as infile:
1039 data = infile.read()
Simon Glass67b5ec52020-12-28 20:34:47 -07001040 self._check_strings(C_HEADER + '''
Simon Glass9763e4e2021-02-03 06:01:19 -07001041/*
1042 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
1043 *
1044 * idx driver_info driver
1045 * --- -------------------- --------------------
1046 * 0: phandle_source2 source
1047 * 1: phandle_target target
1048 * --- -------------------- --------------------
1049 */
1050
Simon Glass1b272732020-10-03 11:31:25 -06001051/* Node /phandle-source2 index 0 */
Walter Lozano51f12632020-06-25 01:10:13 -03001052static struct dtd_source dtv_phandle_source2 = {
Simon Glass8512ea22018-07-06 10:27:35 -06001053\t.clocks\t\t\t= {
Simon Glass8a38abf2020-10-03 11:31:40 -06001054\t\t\t{1, {}},},
Simon Glass8512ea22018-07-06 10:27:35 -06001055};
Simon Glass20e442a2020-12-28 20:34:54 -07001056U_BOOT_DRVINFO(phandle_source2) = {
Simon Glass8512ea22018-07-06 10:27:35 -06001057\t.name\t\t= "source",
Simon Glass9763e4e2021-02-03 06:01:19 -07001058\t.plat\t\t= &dtv_phandle_source2,
Simon Glass4f500862020-12-03 16:55:19 -07001059\t.plat_size\t= sizeof(dtv_phandle_source2),
Simon Glasse41651f2020-10-03 11:31:35 -06001060\t.parent_idx\t= -1,
Simon Glass8512ea22018-07-06 10:27:35 -06001061};
1062
Simon Glass9eca08d2020-12-28 20:35:04 -07001063/* Node /phandle-target index 1 */
1064static struct dtd_target dtv_phandle_target = {
1065};
1066U_BOOT_DRVINFO(phandle_target) = {
1067\t.name\t\t= "target",
Simon Glass9763e4e2021-02-03 06:01:19 -07001068\t.plat\t\t= &dtv_phandle_target,
Simon Glass9eca08d2020-12-28 20:35:04 -07001069\t.plat_size\t= sizeof(dtv_phandle_target),
1070\t.parent_idx\t= -1,
1071};
1072
Simon Glass8512ea22018-07-06 10:27:35 -06001073''', data)
1074
Walter Lozano6c3fc502020-06-25 01:10:17 -03001075 def test_phandle_cd_gpio(self):
1076 """Test that phandle targets are generated when unsing cd-gpios"""
1077 dtb_file = get_dtb_file('dtoc_test_phandle_cd_gpios.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -07001078 output = tools.get_output_filename('output')
Simon Glass4a092352021-02-03 06:01:12 -07001079 dtb_platdata.run_steps(
1080 ['platdata'], dtb_file, False, output, [], None, False,
1081 warning_disabled=True, scan=copy_scan())
Walter Lozano6c3fc502020-06-25 01:10:17 -03001082 with open(output) as infile:
1083 data = infile.read()
Simon Glass67b5ec52020-12-28 20:34:47 -07001084 self._check_strings(C_HEADER + '''
Simon Glass9763e4e2021-02-03 06:01:19 -07001085/*
1086 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
1087 *
1088 * idx driver_info driver
1089 * --- -------------------- --------------------
1090 * 0: phandle2_target target
1091 * 1: phandle3_target target
1092 * 2: phandle_source source
1093 * 3: phandle_source2 source
1094 * 4: phandle_target target
1095 * --- -------------------- --------------------
1096 */
1097
Simon Glass1b272732020-10-03 11:31:25 -06001098/* Node /phandle2-target index 0 */
Walter Lozano6c3fc502020-06-25 01:10:17 -03001099static struct dtd_target dtv_phandle2_target = {
1100\t.intval\t\t\t= 0x1,
1101};
Simon Glass20e442a2020-12-28 20:34:54 -07001102U_BOOT_DRVINFO(phandle2_target) = {
Walter Lozano6c3fc502020-06-25 01:10:17 -03001103\t.name\t\t= "target",
Simon Glass9763e4e2021-02-03 06:01:19 -07001104\t.plat\t\t= &dtv_phandle2_target,
Simon Glass4f500862020-12-03 16:55:19 -07001105\t.plat_size\t= sizeof(dtv_phandle2_target),
Simon Glasse41651f2020-10-03 11:31:35 -06001106\t.parent_idx\t= -1,
Walter Lozano6c3fc502020-06-25 01:10:17 -03001107};
1108
Simon Glass1b272732020-10-03 11:31:25 -06001109/* Node /phandle3-target index 1 */
Walter Lozano6c3fc502020-06-25 01:10:17 -03001110static struct dtd_target dtv_phandle3_target = {
1111\t.intval\t\t\t= 0x2,
1112};
Simon Glass20e442a2020-12-28 20:34:54 -07001113U_BOOT_DRVINFO(phandle3_target) = {
Walter Lozano6c3fc502020-06-25 01:10:17 -03001114\t.name\t\t= "target",
Simon Glass9763e4e2021-02-03 06:01:19 -07001115\t.plat\t\t= &dtv_phandle3_target,
Simon Glass4f500862020-12-03 16:55:19 -07001116\t.plat_size\t= sizeof(dtv_phandle3_target),
Simon Glasse41651f2020-10-03 11:31:35 -06001117\t.parent_idx\t= -1,
Walter Lozano6c3fc502020-06-25 01:10:17 -03001118};
1119
Simon Glass1b272732020-10-03 11:31:25 -06001120/* Node /phandle-source index 2 */
Walter Lozano6c3fc502020-06-25 01:10:17 -03001121static struct dtd_source dtv_phandle_source = {
1122\t.cd_gpios\t\t= {
Simon Glass8a38abf2020-10-03 11:31:40 -06001123\t\t\t{4, {}},
1124\t\t\t{0, {11}},
1125\t\t\t{1, {12, 13}},
1126\t\t\t{4, {}},},
Walter Lozano6c3fc502020-06-25 01:10:17 -03001127};
Simon Glass20e442a2020-12-28 20:34:54 -07001128U_BOOT_DRVINFO(phandle_source) = {
Walter Lozano6c3fc502020-06-25 01:10:17 -03001129\t.name\t\t= "source",
Simon Glass9763e4e2021-02-03 06:01:19 -07001130\t.plat\t\t= &dtv_phandle_source,
Simon Glass4f500862020-12-03 16:55:19 -07001131\t.plat_size\t= sizeof(dtv_phandle_source),
Simon Glasse41651f2020-10-03 11:31:35 -06001132\t.parent_idx\t= -1,
Walter Lozano6c3fc502020-06-25 01:10:17 -03001133};
1134
Simon Glass1b272732020-10-03 11:31:25 -06001135/* Node /phandle-source2 index 3 */
Walter Lozano6c3fc502020-06-25 01:10:17 -03001136static struct dtd_source dtv_phandle_source2 = {
1137\t.cd_gpios\t\t= {
Simon Glass8a38abf2020-10-03 11:31:40 -06001138\t\t\t{4, {}},},
Walter Lozano6c3fc502020-06-25 01:10:17 -03001139};
Simon Glass20e442a2020-12-28 20:34:54 -07001140U_BOOT_DRVINFO(phandle_source2) = {
Walter Lozano6c3fc502020-06-25 01:10:17 -03001141\t.name\t\t= "source",
Simon Glass9763e4e2021-02-03 06:01:19 -07001142\t.plat\t\t= &dtv_phandle_source2,
Simon Glass4f500862020-12-03 16:55:19 -07001143\t.plat_size\t= sizeof(dtv_phandle_source2),
Simon Glasse41651f2020-10-03 11:31:35 -06001144\t.parent_idx\t= -1,
Walter Lozano6c3fc502020-06-25 01:10:17 -03001145};
1146
Simon Glass9eca08d2020-12-28 20:35:04 -07001147/* Node /phandle-target index 4 */
1148static struct dtd_target dtv_phandle_target = {
1149\t.intval\t\t\t= 0x0,
1150};
1151U_BOOT_DRVINFO(phandle_target) = {
1152\t.name\t\t= "target",
Simon Glass9763e4e2021-02-03 06:01:19 -07001153\t.plat\t\t= &dtv_phandle_target,
Simon Glass9eca08d2020-12-28 20:35:04 -07001154\t.plat_size\t= sizeof(dtv_phandle_target),
1155\t.parent_idx\t= -1,
1156};
1157
Walter Lozano6c3fc502020-06-25 01:10:17 -03001158''', data)
1159
Simon Glass8512ea22018-07-06 10:27:35 -06001160 def test_phandle_bad(self):
1161 """Test a node containing an invalid phandle fails"""
Simon Glass4b4bc062018-10-01 21:12:43 -06001162 dtb_file = get_dtb_file('dtoc_test_phandle_bad.dts',
1163 capture_stderr=True)
Simon Glassc1aa66e2022-01-29 14:14:04 -07001164 output = tools.get_output_filename('output')
Simon Glass67b5ec52020-12-28 20:34:47 -07001165 with self.assertRaises(ValueError) as exc:
Walter Lozano361e7332020-06-25 01:10:08 -03001166 self.run_test(['struct'], dtb_file, output)
Simon Glass8512ea22018-07-06 10:27:35 -06001167 self.assertIn("Cannot parse 'clocks' in node 'phandle-source'",
Simon Glass67b5ec52020-12-28 20:34:47 -07001168 str(exc.exception))
Simon Glass8512ea22018-07-06 10:27:35 -06001169
1170 def test_phandle_bad2(self):
1171 """Test a phandle target missing its #*-cells property"""
Simon Glass4b4bc062018-10-01 21:12:43 -06001172 dtb_file = get_dtb_file('dtoc_test_phandle_bad2.dts',
1173 capture_stderr=True)
Simon Glassc1aa66e2022-01-29 14:14:04 -07001174 output = tools.get_output_filename('output')
Simon Glass67b5ec52020-12-28 20:34:47 -07001175 with self.assertRaises(ValueError) as exc:
Walter Lozano361e7332020-06-25 01:10:08 -03001176 self.run_test(['struct'], dtb_file, output)
Walter Lozanoad340172020-06-25 01:10:16 -03001177 self.assertIn("Node 'phandle-target' has no cells property",
Simon Glass67b5ec52020-12-28 20:34:47 -07001178 str(exc.exception))
Simon Glass8512ea22018-07-06 10:27:35 -06001179
Simon Glassc20ee0e2017-08-29 14:15:50 -06001180 def test_addresses64(self):
1181 """Test output from a node with a 'reg' property with na=2, ns=2"""
1182 dtb_file = get_dtb_file('dtoc_test_addr64.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -07001183 output = tools.get_output_filename('output')
Walter Lozano361e7332020-06-25 01:10:08 -03001184 self.run_test(['struct'], dtb_file, output)
Simon Glassc20ee0e2017-08-29 14:15:50 -06001185 with open(output) as infile:
1186 data = infile.read()
Simon Glass67b5ec52020-12-28 20:34:47 -07001187 self._check_strings(HEADER + '''
Simon Glassc20ee0e2017-08-29 14:15:50 -06001188struct dtd_test1 {
1189\tfdt64_t\t\treg[2];
1190};
1191struct dtd_test2 {
1192\tfdt64_t\t\treg[2];
1193};
1194struct dtd_test3 {
1195\tfdt64_t\t\treg[4];
1196};
1197''', data)
1198
Walter Lozano361e7332020-06-25 01:10:08 -03001199 self.run_test(['platdata'], dtb_file, output)
Simon Glassc20ee0e2017-08-29 14:15:50 -06001200 with open(output) as infile:
1201 data = infile.read()
Simon Glass67b5ec52020-12-28 20:34:47 -07001202 self._check_strings(C_HEADER + '''
Simon Glass9763e4e2021-02-03 06:01:19 -07001203/*
1204 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
1205 *
1206 * idx driver_info driver
1207 * --- -------------------- --------------------
1208 * 0: test1 test1
1209 * 1: test2 test2
1210 * 2: test3 test3
1211 * --- -------------------- --------------------
1212 */
1213
Simon Glass1b272732020-10-03 11:31:25 -06001214/* Node /test1 index 0 */
Walter Lozano51f12632020-06-25 01:10:13 -03001215static struct dtd_test1 dtv_test1 = {
Simon Glassc20ee0e2017-08-29 14:15:50 -06001216\t.reg\t\t\t= {0x1234, 0x5678},
1217};
Simon Glass20e442a2020-12-28 20:34:54 -07001218U_BOOT_DRVINFO(test1) = {
Simon Glassc20ee0e2017-08-29 14:15:50 -06001219\t.name\t\t= "test1",
Simon Glass9763e4e2021-02-03 06:01:19 -07001220\t.plat\t\t= &dtv_test1,
Simon Glass4f500862020-12-03 16:55:19 -07001221\t.plat_size\t= sizeof(dtv_test1),
Simon Glasse41651f2020-10-03 11:31:35 -06001222\t.parent_idx\t= -1,
Simon Glassc20ee0e2017-08-29 14:15:50 -06001223};
1224
Simon Glass1b272732020-10-03 11:31:25 -06001225/* Node /test2 index 1 */
Walter Lozano51f12632020-06-25 01:10:13 -03001226static struct dtd_test2 dtv_test2 = {
Simon Glassc20ee0e2017-08-29 14:15:50 -06001227\t.reg\t\t\t= {0x1234567890123456, 0x9876543210987654},
1228};
Simon Glass20e442a2020-12-28 20:34:54 -07001229U_BOOT_DRVINFO(test2) = {
Simon Glassc20ee0e2017-08-29 14:15:50 -06001230\t.name\t\t= "test2",
Simon Glass9763e4e2021-02-03 06:01:19 -07001231\t.plat\t\t= &dtv_test2,
Simon Glass4f500862020-12-03 16:55:19 -07001232\t.plat_size\t= sizeof(dtv_test2),
Simon Glasse41651f2020-10-03 11:31:35 -06001233\t.parent_idx\t= -1,
Simon Glassc20ee0e2017-08-29 14:15:50 -06001234};
1235
Simon Glass1b272732020-10-03 11:31:25 -06001236/* Node /test3 index 2 */
Walter Lozano51f12632020-06-25 01:10:13 -03001237static struct dtd_test3 dtv_test3 = {
Simon Glassc20ee0e2017-08-29 14:15:50 -06001238\t.reg\t\t\t= {0x1234567890123456, 0x9876543210987654, 0x2, 0x3},
1239};
Simon Glass20e442a2020-12-28 20:34:54 -07001240U_BOOT_DRVINFO(test3) = {
Simon Glassc20ee0e2017-08-29 14:15:50 -06001241\t.name\t\t= "test3",
Simon Glass9763e4e2021-02-03 06:01:19 -07001242\t.plat\t\t= &dtv_test3,
Simon Glass4f500862020-12-03 16:55:19 -07001243\t.plat_size\t= sizeof(dtv_test3),
Simon Glasse41651f2020-10-03 11:31:35 -06001244\t.parent_idx\t= -1,
Simon Glassc20ee0e2017-08-29 14:15:50 -06001245};
1246
Simon Glassd960f0d2020-12-28 20:35:05 -07001247''', data)
Simon Glassc20ee0e2017-08-29 14:15:50 -06001248
1249 def test_addresses32(self):
1250 """Test output from a node with a 'reg' property with na=1, ns=1"""
1251 dtb_file = get_dtb_file('dtoc_test_addr32.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -07001252 output = tools.get_output_filename('output')
Walter Lozano361e7332020-06-25 01:10:08 -03001253 self.run_test(['struct'], dtb_file, output)
Simon Glassc20ee0e2017-08-29 14:15:50 -06001254 with open(output) as infile:
1255 data = infile.read()
Simon Glass67b5ec52020-12-28 20:34:47 -07001256 self._check_strings(HEADER + '''
Simon Glassc20ee0e2017-08-29 14:15:50 -06001257struct dtd_test1 {
1258\tfdt32_t\t\treg[2];
1259};
1260struct dtd_test2 {
1261\tfdt32_t\t\treg[4];
1262};
1263''', data)
1264
Walter Lozano361e7332020-06-25 01:10:08 -03001265 self.run_test(['platdata'], dtb_file, output)
Simon Glassc20ee0e2017-08-29 14:15:50 -06001266 with open(output) as infile:
1267 data = infile.read()
Simon Glass67b5ec52020-12-28 20:34:47 -07001268 self._check_strings(C_HEADER + '''
Simon Glass9763e4e2021-02-03 06:01:19 -07001269/*
1270 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
1271 *
1272 * idx driver_info driver
1273 * --- -------------------- --------------------
1274 * 0: test1 test1
1275 * 1: test2 test2
1276 * --- -------------------- --------------------
1277 */
1278
Simon Glass1b272732020-10-03 11:31:25 -06001279/* Node /test1 index 0 */
Walter Lozano51f12632020-06-25 01:10:13 -03001280static struct dtd_test1 dtv_test1 = {
Simon Glassc20ee0e2017-08-29 14:15:50 -06001281\t.reg\t\t\t= {0x1234, 0x5678},
1282};
Simon Glass20e442a2020-12-28 20:34:54 -07001283U_BOOT_DRVINFO(test1) = {
Simon Glassc20ee0e2017-08-29 14:15:50 -06001284\t.name\t\t= "test1",
Simon Glass9763e4e2021-02-03 06:01:19 -07001285\t.plat\t\t= &dtv_test1,
Simon Glass4f500862020-12-03 16:55:19 -07001286\t.plat_size\t= sizeof(dtv_test1),
Simon Glasse41651f2020-10-03 11:31:35 -06001287\t.parent_idx\t= -1,
Simon Glassc20ee0e2017-08-29 14:15:50 -06001288};
1289
Simon Glass1b272732020-10-03 11:31:25 -06001290/* Node /test2 index 1 */
Walter Lozano51f12632020-06-25 01:10:13 -03001291static struct dtd_test2 dtv_test2 = {
Simon Glassc20ee0e2017-08-29 14:15:50 -06001292\t.reg\t\t\t= {0x12345678, 0x98765432, 0x2, 0x3},
1293};
Simon Glass20e442a2020-12-28 20:34:54 -07001294U_BOOT_DRVINFO(test2) = {
Simon Glassc20ee0e2017-08-29 14:15:50 -06001295\t.name\t\t= "test2",
Simon Glass9763e4e2021-02-03 06:01:19 -07001296\t.plat\t\t= &dtv_test2,
Simon Glass4f500862020-12-03 16:55:19 -07001297\t.plat_size\t= sizeof(dtv_test2),
Simon Glasse41651f2020-10-03 11:31:35 -06001298\t.parent_idx\t= -1,
Simon Glassc20ee0e2017-08-29 14:15:50 -06001299};
1300
Simon Glassd960f0d2020-12-28 20:35:05 -07001301''', data)
Simon Glassc20ee0e2017-08-29 14:15:50 -06001302
1303 def test_addresses64_32(self):
1304 """Test output from a node with a 'reg' property with na=2, ns=1"""
1305 dtb_file = get_dtb_file('dtoc_test_addr64_32.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -07001306 output = tools.get_output_filename('output')
Walter Lozano361e7332020-06-25 01:10:08 -03001307 self.run_test(['struct'], dtb_file, output)
Simon Glassc20ee0e2017-08-29 14:15:50 -06001308 with open(output) as infile:
1309 data = infile.read()
Simon Glass67b5ec52020-12-28 20:34:47 -07001310 self._check_strings(HEADER + '''
Simon Glassc20ee0e2017-08-29 14:15:50 -06001311struct dtd_test1 {
1312\tfdt64_t\t\treg[2];
1313};
1314struct dtd_test2 {
1315\tfdt64_t\t\treg[2];
1316};
1317struct dtd_test3 {
1318\tfdt64_t\t\treg[4];
1319};
1320''', data)
1321
Walter Lozano361e7332020-06-25 01:10:08 -03001322 self.run_test(['platdata'], dtb_file, output)
Simon Glassc20ee0e2017-08-29 14:15:50 -06001323 with open(output) as infile:
1324 data = infile.read()
Simon Glass67b5ec52020-12-28 20:34:47 -07001325 self._check_strings(C_HEADER + '''
Simon Glass9763e4e2021-02-03 06:01:19 -07001326/*
1327 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
1328 *
1329 * idx driver_info driver
1330 * --- -------------------- --------------------
1331 * 0: test1 test1
1332 * 1: test2 test2
1333 * 2: test3 test3
1334 * --- -------------------- --------------------
1335 */
1336
Simon Glass1b272732020-10-03 11:31:25 -06001337/* Node /test1 index 0 */
Walter Lozano51f12632020-06-25 01:10:13 -03001338static struct dtd_test1 dtv_test1 = {
Simon Glassc20ee0e2017-08-29 14:15:50 -06001339\t.reg\t\t\t= {0x123400000000, 0x5678},
1340};
Simon Glass20e442a2020-12-28 20:34:54 -07001341U_BOOT_DRVINFO(test1) = {
Simon Glassc20ee0e2017-08-29 14:15:50 -06001342\t.name\t\t= "test1",
Simon Glass9763e4e2021-02-03 06:01:19 -07001343\t.plat\t\t= &dtv_test1,
Simon Glass4f500862020-12-03 16:55:19 -07001344\t.plat_size\t= sizeof(dtv_test1),
Simon Glasse41651f2020-10-03 11:31:35 -06001345\t.parent_idx\t= -1,
Simon Glassc20ee0e2017-08-29 14:15:50 -06001346};
1347
Simon Glass1b272732020-10-03 11:31:25 -06001348/* Node /test2 index 1 */
Walter Lozano51f12632020-06-25 01:10:13 -03001349static struct dtd_test2 dtv_test2 = {
Simon Glassc20ee0e2017-08-29 14:15:50 -06001350\t.reg\t\t\t= {0x1234567890123456, 0x98765432},
1351};
Simon Glass20e442a2020-12-28 20:34:54 -07001352U_BOOT_DRVINFO(test2) = {
Simon Glassc20ee0e2017-08-29 14:15:50 -06001353\t.name\t\t= "test2",
Simon Glass9763e4e2021-02-03 06:01:19 -07001354\t.plat\t\t= &dtv_test2,
Simon Glass4f500862020-12-03 16:55:19 -07001355\t.plat_size\t= sizeof(dtv_test2),
Simon Glasse41651f2020-10-03 11:31:35 -06001356\t.parent_idx\t= -1,
Simon Glassc20ee0e2017-08-29 14:15:50 -06001357};
1358
Simon Glass1b272732020-10-03 11:31:25 -06001359/* Node /test3 index 2 */
Walter Lozano51f12632020-06-25 01:10:13 -03001360static struct dtd_test3 dtv_test3 = {
Simon Glassc20ee0e2017-08-29 14:15:50 -06001361\t.reg\t\t\t= {0x1234567890123456, 0x98765432, 0x2, 0x3},
1362};
Simon Glass20e442a2020-12-28 20:34:54 -07001363U_BOOT_DRVINFO(test3) = {
Simon Glassc20ee0e2017-08-29 14:15:50 -06001364\t.name\t\t= "test3",
Simon Glass9763e4e2021-02-03 06:01:19 -07001365\t.plat\t\t= &dtv_test3,
Simon Glass4f500862020-12-03 16:55:19 -07001366\t.plat_size\t= sizeof(dtv_test3),
Simon Glasse41651f2020-10-03 11:31:35 -06001367\t.parent_idx\t= -1,
Simon Glassc20ee0e2017-08-29 14:15:50 -06001368};
1369
Simon Glassd960f0d2020-12-28 20:35:05 -07001370''', data)
Simon Glassc20ee0e2017-08-29 14:15:50 -06001371
1372 def test_addresses32_64(self):
1373 """Test output from a node with a 'reg' property with na=1, ns=2"""
1374 dtb_file = get_dtb_file('dtoc_test_addr32_64.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -07001375 output = tools.get_output_filename('output')
Walter Lozano361e7332020-06-25 01:10:08 -03001376 self.run_test(['struct'], dtb_file, output)
Simon Glassc20ee0e2017-08-29 14:15:50 -06001377 with open(output) as infile:
1378 data = infile.read()
Simon Glass67b5ec52020-12-28 20:34:47 -07001379 self._check_strings(HEADER + '''
Simon Glassc20ee0e2017-08-29 14:15:50 -06001380struct dtd_test1 {
1381\tfdt64_t\t\treg[2];
1382};
1383struct dtd_test2 {
1384\tfdt64_t\t\treg[2];
1385};
1386struct dtd_test3 {
1387\tfdt64_t\t\treg[4];
1388};
1389''', data)
1390
Walter Lozano361e7332020-06-25 01:10:08 -03001391 self.run_test(['platdata'], dtb_file, output)
Simon Glassc20ee0e2017-08-29 14:15:50 -06001392 with open(output) as infile:
1393 data = infile.read()
Simon Glass67b5ec52020-12-28 20:34:47 -07001394 self._check_strings(C_HEADER + '''
Simon Glass9763e4e2021-02-03 06:01:19 -07001395/*
1396 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
1397 *
1398 * idx driver_info driver
1399 * --- -------------------- --------------------
1400 * 0: test1 test1
1401 * 1: test2 test2
1402 * 2: test3 test3
1403 * --- -------------------- --------------------
1404 */
1405
Simon Glass1b272732020-10-03 11:31:25 -06001406/* Node /test1 index 0 */
Walter Lozano51f12632020-06-25 01:10:13 -03001407static struct dtd_test1 dtv_test1 = {
Simon Glassc20ee0e2017-08-29 14:15:50 -06001408\t.reg\t\t\t= {0x1234, 0x567800000000},
1409};
Simon Glass20e442a2020-12-28 20:34:54 -07001410U_BOOT_DRVINFO(test1) = {
Simon Glassc20ee0e2017-08-29 14:15:50 -06001411\t.name\t\t= "test1",
Simon Glass9763e4e2021-02-03 06:01:19 -07001412\t.plat\t\t= &dtv_test1,
Simon Glass4f500862020-12-03 16:55:19 -07001413\t.plat_size\t= sizeof(dtv_test1),
Simon Glasse41651f2020-10-03 11:31:35 -06001414\t.parent_idx\t= -1,
Simon Glassc20ee0e2017-08-29 14:15:50 -06001415};
1416
Simon Glass1b272732020-10-03 11:31:25 -06001417/* Node /test2 index 1 */
Walter Lozano51f12632020-06-25 01:10:13 -03001418static struct dtd_test2 dtv_test2 = {
Simon Glassc20ee0e2017-08-29 14:15:50 -06001419\t.reg\t\t\t= {0x12345678, 0x9876543210987654},
1420};
Simon Glass20e442a2020-12-28 20:34:54 -07001421U_BOOT_DRVINFO(test2) = {
Simon Glassc20ee0e2017-08-29 14:15:50 -06001422\t.name\t\t= "test2",
Simon Glass9763e4e2021-02-03 06:01:19 -07001423\t.plat\t\t= &dtv_test2,
Simon Glass4f500862020-12-03 16:55:19 -07001424\t.plat_size\t= sizeof(dtv_test2),
Simon Glasse41651f2020-10-03 11:31:35 -06001425\t.parent_idx\t= -1,
Simon Glassc20ee0e2017-08-29 14:15:50 -06001426};
1427
Simon Glass1b272732020-10-03 11:31:25 -06001428/* Node /test3 index 2 */
Walter Lozano51f12632020-06-25 01:10:13 -03001429static struct dtd_test3 dtv_test3 = {
Simon Glassc20ee0e2017-08-29 14:15:50 -06001430\t.reg\t\t\t= {0x12345678, 0x9876543210987654, 0x2, 0x3},
1431};
Simon Glass20e442a2020-12-28 20:34:54 -07001432U_BOOT_DRVINFO(test3) = {
Simon Glassc20ee0e2017-08-29 14:15:50 -06001433\t.name\t\t= "test3",
Simon Glass9763e4e2021-02-03 06:01:19 -07001434\t.plat\t\t= &dtv_test3,
Simon Glass4f500862020-12-03 16:55:19 -07001435\t.plat_size\t= sizeof(dtv_test3),
Simon Glasse41651f2020-10-03 11:31:35 -06001436\t.parent_idx\t= -1,
Simon Glassc20ee0e2017-08-29 14:15:50 -06001437};
1438
Simon Glassd960f0d2020-12-28 20:35:05 -07001439''', data)
Simon Glass8512ea22018-07-06 10:27:35 -06001440
1441 def test_bad_reg(self):
1442 """Test that a reg property with an invalid type generates an error"""
Simon Glassfe57c782018-07-06 10:27:37 -06001443 # Capture stderr since dtc will emit warnings for this file
1444 dtb_file = get_dtb_file('dtoc_test_bad_reg.dts', capture_stderr=True)
Simon Glassc1aa66e2022-01-29 14:14:04 -07001445 output = tools.get_output_filename('output')
Simon Glass67b5ec52020-12-28 20:34:47 -07001446 with self.assertRaises(ValueError) as exc:
Walter Lozano361e7332020-06-25 01:10:08 -03001447 self.run_test(['struct'], dtb_file, output)
Simon Glass8512ea22018-07-06 10:27:35 -06001448 self.assertIn("Node 'spl-test' reg property is not an int",
Simon Glass67b5ec52020-12-28 20:34:47 -07001449 str(exc.exception))
Simon Glass8512ea22018-07-06 10:27:35 -06001450
1451 def test_bad_reg2(self):
1452 """Test that a reg property with an invalid cell count is detected"""
Simon Glassfe57c782018-07-06 10:27:37 -06001453 # Capture stderr since dtc will emit warnings for this file
1454 dtb_file = get_dtb_file('dtoc_test_bad_reg2.dts', capture_stderr=True)
Simon Glassc1aa66e2022-01-29 14:14:04 -07001455 output = tools.get_output_filename('output')
Simon Glass67b5ec52020-12-28 20:34:47 -07001456 with self.assertRaises(ValueError) as exc:
Walter Lozano361e7332020-06-25 01:10:08 -03001457 self.run_test(['struct'], dtb_file, output)
Simon Glass67b5ec52020-12-28 20:34:47 -07001458 self.assertIn(
Simon Glassda393412021-03-26 16:17:27 +13001459 "Node 'spl-test' (parent '/') reg property has 3 cells which is not a multiple of na + ns = 1 + 1)",
Simon Glass67b5ec52020-12-28 20:34:47 -07001460 str(exc.exception))
Simon Glass8512ea22018-07-06 10:27:35 -06001461
1462 def test_add_prop(self):
1463 """Test that a subequent node can add a new property to a struct"""
1464 dtb_file = get_dtb_file('dtoc_test_add_prop.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -07001465 output = tools.get_output_filename('output')
Walter Lozano361e7332020-06-25 01:10:08 -03001466 self.run_test(['struct'], dtb_file, output)
Simon Glass8512ea22018-07-06 10:27:35 -06001467 with open(output) as infile:
1468 data = infile.read()
Simon Glass67b5ec52020-12-28 20:34:47 -07001469 self._check_strings(HEADER + '''
Simon Glass8512ea22018-07-06 10:27:35 -06001470struct dtd_sandbox_spl_test {
1471\tfdt32_t\t\tintarray;
1472\tfdt32_t\t\tintval;
1473};
1474''', data)
1475
Walter Lozano361e7332020-06-25 01:10:08 -03001476 self.run_test(['platdata'], dtb_file, output)
Simon Glass8512ea22018-07-06 10:27:35 -06001477 with open(output) as infile:
1478 data = infile.read()
Simon Glass67b5ec52020-12-28 20:34:47 -07001479 self._check_strings(C_HEADER + '''
Simon Glass4b91be22021-02-03 06:01:15 -07001480/*
Simon Glass9763e4e2021-02-03 06:01:19 -07001481 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
1482 *
1483 * idx driver_info driver
1484 * --- -------------------- --------------------
1485 * 0: spl_test sandbox_spl_test
1486 * 1: spl_test2 sandbox_spl_test
1487 * --- -------------------- --------------------
1488 */
1489
1490/*
Simon Glass4b91be22021-02-03 06:01:15 -07001491 * Node /spl-test index 0
1492 * driver sandbox_spl_test parent None
1493 */
Walter Lozano51f12632020-06-25 01:10:13 -03001494static struct dtd_sandbox_spl_test dtv_spl_test = {
Simon Glass8512ea22018-07-06 10:27:35 -06001495\t.intval\t\t\t= 0x1,
1496};
Simon Glass20e442a2020-12-28 20:34:54 -07001497U_BOOT_DRVINFO(spl_test) = {
Simon Glass8512ea22018-07-06 10:27:35 -06001498\t.name\t\t= "sandbox_spl_test",
Simon Glass9763e4e2021-02-03 06:01:19 -07001499\t.plat\t\t= &dtv_spl_test,
Simon Glass4f500862020-12-03 16:55:19 -07001500\t.plat_size\t= sizeof(dtv_spl_test),
Simon Glasse41651f2020-10-03 11:31:35 -06001501\t.parent_idx\t= -1,
Simon Glass8512ea22018-07-06 10:27:35 -06001502};
1503
Simon Glass4b91be22021-02-03 06:01:15 -07001504/*
1505 * Node /spl-test2 index 1
1506 * driver sandbox_spl_test parent None
1507 */
Walter Lozano51f12632020-06-25 01:10:13 -03001508static struct dtd_sandbox_spl_test dtv_spl_test2 = {
Simon Glass8512ea22018-07-06 10:27:35 -06001509\t.intarray\t\t= 0x5,
1510};
Simon Glass20e442a2020-12-28 20:34:54 -07001511U_BOOT_DRVINFO(spl_test2) = {
Simon Glass8512ea22018-07-06 10:27:35 -06001512\t.name\t\t= "sandbox_spl_test",
Simon Glass9763e4e2021-02-03 06:01:19 -07001513\t.plat\t\t= &dtv_spl_test2,
Simon Glass4f500862020-12-03 16:55:19 -07001514\t.plat_size\t= sizeof(dtv_spl_test2),
Simon Glasse41651f2020-10-03 11:31:35 -06001515\t.parent_idx\t= -1,
Simon Glass8512ea22018-07-06 10:27:35 -06001516};
1517
Simon Glassd960f0d2020-12-28 20:35:05 -07001518''', data)
Simon Glass8512ea22018-07-06 10:27:35 -06001519
Simon Glass67b5ec52020-12-28 20:34:47 -07001520 def test_stdout(self):
Simon Glass8512ea22018-07-06 10:27:35 -06001521 """Test output to stdout"""
1522 dtb_file = get_dtb_file('dtoc_test_simple.dts')
Simon Glassde846cb2020-12-28 20:34:49 -07001523 with test_util.capture_sys_output() as (stdout, _):
Simon Glassf62cea02020-12-28 20:34:48 -07001524 self.run_test(['struct'], dtb_file, None)
Simon Glassde846cb2020-12-28 20:34:49 -07001525 self._check_strings(self.struct_text, stdout.getvalue())
Simon Glass8512ea22018-07-06 10:27:35 -06001526
Simon Glassbe44f272020-12-28 20:34:51 -07001527 def test_multi_to_file(self):
1528 """Test output of multiple pieces to a single file"""
1529 dtb_file = get_dtb_file('dtoc_test_simple.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -07001530 output = tools.get_output_filename('output')
Simon Glass10cbd3b2020-12-28 20:34:52 -07001531 self.run_test(['all'], dtb_file, output)
Simon Glassc1aa66e2022-01-29 14:14:04 -07001532 data = tools.read_file(output, binary=False)
Simon Glassd392d322021-02-03 06:01:21 -07001533 self._check_strings(
Simon Glass17073252021-04-27 08:19:48 +12001534 self.decl_text + self.platdata_text + self.struct_text, data)
Simon Glassbe44f272020-12-28 20:34:51 -07001535
Simon Glass67b5ec52020-12-28 20:34:47 -07001536 def test_no_command(self):
Simon Glass8512ea22018-07-06 10:27:35 -06001537 """Test running dtoc without a command"""
Simon Glass67b5ec52020-12-28 20:34:47 -07001538 with self.assertRaises(ValueError) as exc:
Walter Lozano361e7332020-06-25 01:10:08 -03001539 self.run_test([], '', '')
Simon Glass8512ea22018-07-06 10:27:35 -06001540 self.assertIn("Please specify a command: struct, platdata",
Simon Glass67b5ec52020-12-28 20:34:47 -07001541 str(exc.exception))
Simon Glass8512ea22018-07-06 10:27:35 -06001542
Simon Glass67b5ec52020-12-28 20:34:47 -07001543 def test_bad_command(self):
Simon Glass8512ea22018-07-06 10:27:35 -06001544 """Test running dtoc with an invalid command"""
1545 dtb_file = get_dtb_file('dtoc_test_simple.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -07001546 output = tools.get_output_filename('output')
Simon Glass67b5ec52020-12-28 20:34:47 -07001547 with self.assertRaises(ValueError) as exc:
Simon Glass426d12f2021-02-03 06:01:14 -07001548 self.run_test(['invalid-cmd'], dtb_file, output)
1549 self.assertIn(
Simon Glass8490c572021-03-25 06:40:51 +13001550 "Unknown command 'invalid-cmd': (use: decl, platdata, struct)",
Simon Glass426d12f2021-02-03 06:01:14 -07001551 str(exc.exception))
Walter Lozano6c74d1b2020-07-28 19:06:23 -03001552
Simon Glass10cbd3b2020-12-28 20:34:52 -07001553 def test_output_conflict(self):
1554 """Test a conflict between and output dirs and output file"""
1555 with self.assertRaises(ValueError) as exc:
Simon Glass4a092352021-02-03 06:01:12 -07001556 dtb_platdata.run_steps(
1557 ['all'], None, False, 'out', ['cdir'], None, False,
1558 warning_disabled=True, scan=copy_scan())
Simon Glass10cbd3b2020-12-28 20:34:52 -07001559 self.assertIn("Must specify either output or output_dirs, not both",
1560 str(exc.exception))
1561
Simon Glass17073252021-04-27 08:19:48 +12001562 def check_output_dirs(self, instantiate):
Simon Glass10cbd3b2020-12-28 20:34:52 -07001563 # Remove the directory so that files from other tests are not there
Simon Glassc1aa66e2022-01-29 14:14:04 -07001564 tools._remove_output_dir()
1565 tools.prepare_output_dir(None)
Simon Glass10cbd3b2020-12-28 20:34:52 -07001566
1567 # This should create the .dts and .dtb in the output directory
1568 dtb_file = get_dtb_file('dtoc_test_simple.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -07001569 outdir = tools.get_output_dir()
Simon Glass10cbd3b2020-12-28 20:34:52 -07001570 fnames = glob.glob(outdir + '/*')
1571 self.assertEqual(2, len(fnames))
1572
Simon Glass4a092352021-02-03 06:01:12 -07001573 dtb_platdata.run_steps(
Simon Glass17073252021-04-27 08:19:48 +12001574 ['all'], dtb_file, False, None, [outdir], None, instantiate,
Simon Glass4a092352021-02-03 06:01:12 -07001575 warning_disabled=True, scan=copy_scan())
Simon Glass10cbd3b2020-12-28 20:34:52 -07001576 fnames = glob.glob(outdir + '/*')
Simon Glass17073252021-04-27 08:19:48 +12001577 return fnames
1578
1579 def test_output_dirs(self):
1580 """Test outputting files to a directory"""
1581 fnames = self.check_output_dirs(False)
1582 self.assertEqual(5, len(fnames))
Simon Glass10cbd3b2020-12-28 20:34:52 -07001583
1584 leafs = set(os.path.basename(fname) for fname in fnames)
1585 self.assertEqual(
Simon Glass426d12f2021-02-03 06:01:14 -07001586 {'dt-structs-gen.h', 'source.dts', 'dt-plat.c', 'source.dtb',
Simon Glass17073252021-04-27 08:19:48 +12001587 'dt-decl.h'},
1588 leafs)
1589
1590 def test_output_dirs_inst(self):
1591 """Test outputting files to a directory with instantiation"""
1592 fnames = self.check_output_dirs(True)
1593 self.assertEqual(6, len(fnames))
1594
1595 leafs = set(os.path.basename(fname) for fname in fnames)
1596 self.assertEqual(
1597 {'dt-structs-gen.h', 'source.dts', 'source.dtb',
Simon Glassd392d322021-02-03 06:01:21 -07001598 'dt-uclass.c', 'dt-decl.h', 'dt-device.c'},
Simon Glass10cbd3b2020-12-28 20:34:52 -07001599 leafs)
Simon Glassfd471e22021-02-03 06:01:00 -07001600
1601 def setup_process_test(self):
1602 """Set up a test of process_nodes()
1603
1604 This uses saved_scan but returns a deep copy of it, so it is safe to
1605 modify it in these tests
1606
1607 Returns:
1608 tuple:
1609 DtbPlatdata: object to test
1610 Scanner: scanner to use
1611 """
1612 dtb_file = get_dtb_file('dtoc_test_simple.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -07001613 output = tools.get_output_filename('output')
Simon Glassfd471e22021-02-03 06:01:00 -07001614
1615 # Take a copy before messing with it
Simon Glass50aae3e2021-02-03 06:01:11 -07001616 scan = copy_scan()
Simon Glassfd471e22021-02-03 06:01:00 -07001617 plat = dtb_platdata.DtbPlatdata(scan, dtb_file, False)
1618 plat.scan_dtb()
Simon Glass50aae3e2021-02-03 06:01:11 -07001619 plat.scan_tree(False)
Simon Glassfd471e22021-02-03 06:01:00 -07001620 plat.prepare_nodes()
1621 return plat, scan
1622
1623 def test_process_nodes(self):
1624 """Test processing nodes to add various info"""
1625 plat, scan = self.setup_process_test()
1626 plat.process_nodes(True)
1627
1628 i2c_node = plat._fdt.GetNode('/i2c@0')
1629 pmic_node = plat._fdt.GetNode('/i2c@0/pmic@9')
1630 pmic = scan._drivers['sandbox_pmic']
1631 i2c = scan._drivers['sandbox_i2c']
1632 self.assertEqual('DM_DEVICE_REF(pmic_at_9)', pmic_node.dev_ref)
1633 self.assertEqual(pmic, pmic_node.driver)
1634 self.assertEqual(i2c_node, pmic_node.parent)
1635 self.assertEqual(i2c, pmic_node.parent_driver)
1636
1637 # The pmic is the only child
1638 self.assertEqual(pmic_node.parent_seq, 0)
1639 self.assertEqual([pmic_node], i2c_node.child_devs)
1640
1641 # Start and end of the list should be the child_head
1642 ref = '&DM_DEVICE_REF(i2c_at_0)->child_head'
1643 self.assertEqual(
1644 {-1: ref, 0: '&DM_DEVICE_REF(pmic_at_9)->sibling_node', 1: ref},
1645 i2c_node.child_refs)
1646
1647 def test_process_nodes_bad_parent(self):
1648 # Pretend that i2c has a parent (the pmic) and delete that driver
1649 plat, scan = self.setup_process_test()
1650
1651 i2c_node = plat._fdt.GetNode('/i2c@0')
1652 pmic_node = plat._fdt.GetNode('/i2c@0/pmic@9')
1653 del scan._drivers['sandbox_pmic']
1654 i2c_node.parent = pmic_node
1655
1656 # Process twice, the second time to generate an exception
1657 plat.process_nodes(False)
1658 with self.assertRaises(ValueError) as exc:
1659 plat.process_nodes(True)
1660 self.assertIn(
1661 "Cannot parse/find parent driver 'sandbox_pmic' for 'sandbox_i2c",
1662 str(exc.exception))
1663
1664 def test_process_nodes_bad_node(self):
1665 plat, scan = self.setup_process_test()
1666
1667 # Now remove the pmic driver
1668 del scan._drivers['sandbox_pmic']
1669
1670 # Process twice, the second time to generate an exception
1671 plat.process_nodes(False)
1672 with self.assertRaises(ValueError) as exc:
1673 plat.process_nodes(True)
1674 self.assertIn("Cannot parse/find driver for 'sandbox_pmic",
1675 str(exc.exception))
Simon Glassb9319c42021-02-03 06:01:01 -07001676
Simon Glass337d6972021-02-03 06:01:10 -07001677 def test_process_nodes_bad_uclass(self):
1678 plat, scan = self.setup_process_test()
1679
1680 self.assertIn('UCLASS_I2C', scan._uclass)
1681 del scan._uclass['UCLASS_I2C']
1682 with self.assertRaises(ValueError) as exc:
1683 plat.process_nodes(True)
1684 self.assertIn("Cannot parse/find uclass 'UCLASS_I2C' for driver 'sandbox_i2c'",
1685 str(exc.exception))
1686
Simon Glassb9319c42021-02-03 06:01:01 -07001687 def test_process_nodes_used(self):
1688 """Test processing nodes to add various info"""
1689 plat, scan = self.setup_process_test()
1690 plat.process_nodes(True)
1691
1692 pmic = scan._drivers['sandbox_pmic']
1693 self.assertTrue(pmic.used)
1694
1695 gpio = scan._drivers['sandbox_gpio']
1696 self.assertFalse(gpio.used)
Simon Glass05953522021-02-03 06:01:07 -07001697
1698 def test_alias_read(self):
1699 """Test obtaining aliases"""
1700 dtb_file = get_dtb_file('dtoc_test_inst.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -07001701 output = tools.get_output_filename('output')
Simon Glass05953522021-02-03 06:01:07 -07001702 plat = self.run_test(['struct'], dtb_file, output)
1703
1704 scan = plat._scan
1705 testfdt_node = plat._fdt.GetNode('/some-bus/test')
Simon Glass337d6972021-02-03 06:01:10 -07001706 test0_node = plat._fdt.GetNode('/some-bus/test0')
Simon Glass05953522021-02-03 06:01:07 -07001707 self.assertIn('UCLASS_TEST_FDT', scan._uclass)
1708 uc = scan._uclass['UCLASS_TEST_FDT']
Simon Glass337d6972021-02-03 06:01:10 -07001709 self.assertEqual({1: testfdt_node, 2: test0_node},
1710 uc.alias_num_to_node)
1711 self.assertEqual({'/some-bus/test': 1, '/some-bus/test0': 2},
1712 uc.alias_path_to_num)
Simon Glass05953522021-02-03 06:01:07 -07001713
1714 # Try adding an alias that doesn't exist
1715 self.assertFalse(scan.add_uclass_alias('fred', 3, None))
1716
1717 # Try adding an alias for a missing node
1718 self.assertIsNone(scan.add_uclass_alias('testfdt', 3, None))
1719
1720 def test_alias_read_bad(self):
1721 """Test invalid alias property name"""
1722 dtb_file = get_dtb_file('dtoc_test_alias_bad.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -07001723 output = tools.get_output_filename('output')
Simon Glass05953522021-02-03 06:01:07 -07001724 with self.assertRaises(ValueError) as exc:
1725 plat = self.run_test(['struct'], dtb_file, output)
1726 self.assertIn("Cannot decode alias 'i2c4-'", str(exc.exception))
1727
1728 def test_alias_read_bad_path(self):
1729 """Test alias pointing to a non-existent node"""
1730 # This line may produce a warning, so capture it:
1731 # Warning (alias_paths): /aliases:i2c4: aliases property is not a valid
1732 # node (/does/not/exist)
1733 dtb_file = get_dtb_file('dtoc_test_alias_bad_path.dts', True)
1734
Simon Glassc1aa66e2022-01-29 14:14:04 -07001735 output = tools.get_output_filename('output')
Simon Glass05953522021-02-03 06:01:07 -07001736 with self.assertRaises(ValueError) as exc:
1737 plat = self.run_test(['struct'], dtb_file, output)
1738 self.assertIn("Alias 'i2c4' path '/does/not/exist' not found",
1739 str(exc.exception))
1740
1741 def test_alias_read_bad_uclass(self):
1742 """Test alias for a uclass that doesn't exist"""
1743 dtb_file = get_dtb_file('dtoc_test_alias_bad_uc.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -07001744 output = tools.get_output_filename('output')
Simon Glass05953522021-02-03 06:01:07 -07001745 with test_util.capture_sys_output() as (stdout, _):
1746 plat = self.run_test(['struct'], dtb_file, output)
1747 self.assertEqual("Could not find uclass for alias 'other1'",
1748 stdout.getvalue().strip())
Simon Glass074197a2021-02-03 06:01:09 -07001749
1750 def test_sequence(self):
1751 """Test assignment of sequence numnbers"""
1752 dtb_file = get_dtb_file('dtoc_test_inst.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -07001753 output = tools.get_output_filename('output')
Simon Glass074197a2021-02-03 06:01:09 -07001754 plat = self.run_test(['struct'], dtb_file, output)
Simon Glass337d6972021-02-03 06:01:10 -07001755
1756 scan = plat._scan
1757 testfdt = plat._fdt.GetNode('/some-bus/test')
1758 self.assertEqual(1, testfdt.seq)
1759 i2c = plat._fdt.GetNode('/i2c')
1760
1761 # For now this uclass is not compiled in, so no sequence is assigned
1762 self.assertEqual(4, i2c.seq)
1763 spl = plat._fdt.GetNode('/spl-test')
1764 self.assertEqual(0, spl.seq)
Simon Glass50aae3e2021-02-03 06:01:11 -07001765
1766 def test_process_root(self):
1767 """Test assignment of sequence numnbers"""
1768 dtb_file = get_dtb_file('dtoc_test_simple.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -07001769 output = tools.get_output_filename('output')
Simon Glass50aae3e2021-02-03 06:01:11 -07001770
1771 # Take a copy before messing with it
1772 scan = copy_scan()
1773 plat = dtb_platdata.DtbPlatdata(scan, dtb_file, False)
1774 plat.scan_dtb()
1775 root = plat._fdt.GetRoot()
1776
1777 plat.scan_tree(False)
1778 self.assertNotIn(root, plat._valid_nodes)
1779
1780 plat.scan_tree(True)
1781 self.assertIn(root, plat._valid_nodes)
1782 self.assertEqual('root_driver',
1783 scan.get_normalized_compat_name(root)[0])
Simon Glass426d12f2021-02-03 06:01:14 -07001784
1785 def test_simple_inst(self):
1786 """Test output from some simple nodes with instantiate enabled"""
Simon Glassea74c952021-02-03 06:01:20 -07001787 dtb_file = get_dtb_file('dtoc_test_inst.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -07001788 output = tools.get_output_filename('output')
Simon Glass426d12f2021-02-03 06:01:14 -07001789
1790 self.run_test(['decl'], dtb_file, output, True)
1791 with open(output) as infile:
1792 data = infile.read()
1793
1794 self._check_strings(self.decl_text_inst, data)
Simon Glass4b91be22021-02-03 06:01:15 -07001795
Simon Glassea74c952021-02-03 06:01:20 -07001796 self.run_test(['uclass'], dtb_file, output, True)
1797 with open(output) as infile:
1798 data = infile.read()
1799
1800 self._check_strings(UCLASS_HEADER_COMMON + self.uclass_text_inst, data)
1801
Simon Glassd392d322021-02-03 06:01:21 -07001802 self.run_test(['device'], dtb_file, output, True)
1803 with open(output) as infile:
1804 data = infile.read()
1805
1806 self._check_strings(self.device_text_inst, data)
1807
Simon Glassea74c952021-02-03 06:01:20 -07001808 def test_inst_no_hdr(self):
Simon Glassd392d322021-02-03 06:01:21 -07001809 """Test dealing with a struct tsssshat has no header"""
Simon Glassea74c952021-02-03 06:01:20 -07001810 dtb_file = get_dtb_file('dtoc_test_inst.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -07001811 output = tools.get_output_filename('output')
Simon Glassea74c952021-02-03 06:01:20 -07001812
1813 # Run it once to set everything up
1814 plat = self.run_test(['decl'], dtb_file, output, True)
1815 scan = plat._scan
1816
1817 # Restart the output file and delete any record of the uclass' struct
1818 plat.setup_output(Ftype.SOURCE, output)
1819 del scan._structs['dm_test_uc_priv']
1820
1821 # Now generate the uclasses, which should provide a warning
1822 with test_util.capture_sys_output() as (stdout, _):
1823 plat.generate_uclasses()
1824 self.assertEqual(
1825 'Warning: Cannot find header file for struct dm_test_uc_priv',
1826 stdout.getvalue().strip())
Simon Glassda393412021-03-26 16:17:27 +13001827
1828 def test_missing_props(self):
1829 """Test detection of a parent node with no properties"""
1830 dtb_file = get_dtb_file('dtoc_test_noprops.dts', capture_stderr=True)
Simon Glassc1aa66e2022-01-29 14:14:04 -07001831 output = tools.get_output_filename('output')
Simon Glassda393412021-03-26 16:17:27 +13001832 with self.assertRaises(ValueError) as exc:
1833 self.run_test(['struct'], dtb_file, output)
1834 self.assertIn("Parent node '/i2c@0' has no properties - do you need",
1835 str(exc.exception))
1836
1837 def test_single_reg(self):
1838 """Test detection of a parent node with no properties"""
1839 dtb_file = get_dtb_file('dtoc_test_single_reg.dts')
Simon Glassc1aa66e2022-01-29 14:14:04 -07001840 output = tools.get_output_filename('output')
Simon Glassda393412021-03-26 16:17:27 +13001841 self.run_test(['struct'], dtb_file, output)
Simon Glass1c564692021-06-27 17:51:10 -06001842
1843 def test_missing_parent(self):
1844 """Test detection of a parent node with no properties"""
1845 dtb_file = get_dtb_file('dtoc_test_noparent.dts', capture_stderr=True)
Simon Glassc1aa66e2022-01-29 14:14:04 -07001846 output = tools.get_output_filename('output')
Simon Glass1c564692021-06-27 17:51:10 -06001847 with self.assertRaises(ValueError) as exc:
1848 self.run_test(['device'], dtb_file, output, instantiate=True)
1849 self.assertIn("Node '/i2c@0/spl-test/pmic@9' requires parent node "
1850 "'/i2c@0/spl-test' but it is not in the valid list",
1851 str(exc.exception))