blob: 752061f27a4c0396d5316bb4883126b7c010998d [file] [log] [blame]
Simon Glassbfb0bb22019-10-31 07:42:55 -06001#!/usr/bin/env python3
Tom Rini10e47792018-05-06 17:58:06 -04002# SPDX-License-Identifier: GPL-2.0+
Simon Glass9d2eb922017-06-18 22:09:06 -06003# Copyright (c) 2012 The Chromium OS Authors.
4#
Simon Glass9d2eb922017-06-18 22:09:06 -06005
6"""Tests for the dtb_platdata module
7
Simon Glass70cd0d72018-07-06 10:27:20 -06008This includes unit tests for some functions and functional tests for the dtoc
9tool.
Simon Glass9d2eb922017-06-18 22:09:06 -060010"""
11
12import collections
Simon Glass768ff0a2021-02-03 06:00:51 -070013import copy
Simon Glass4e8e8462020-12-28 20:34:52 -070014import glob
Simon Glass9d2eb922017-06-18 22:09:06 -060015import os
16import struct
17import unittest
18
Simon Glassc7b4b832021-02-03 06:01:20 -070019from dtb_platdata import Ftype
Simon Glass9d2eb922017-06-18 22:09:06 -060020from dtb_platdata import get_value
21from dtb_platdata import tab_to
Simon Glassa60cabd2020-12-28 20:34:47 -070022from dtoc import dtb_platdata
Simon Glassa997ea52020-04-17 18:09:04 -060023from dtoc import fdt
24from dtoc import fdt_util
Simon Glass768ff0a2021-02-03 06:00:51 -070025from dtoc import src_scan
Simon Glass9065bc92020-12-28 20:35:06 -070026from dtoc.src_scan import conv_name_to_c
27from dtoc.src_scan import get_compat_name
Simon Glassa997ea52020-04-17 18:09:04 -060028from patman import test_util
29from patman import tools
Simon Glass9d2eb922017-06-18 22:09:06 -060030
Simon Glassa60cabd2020-12-28 20:34:47 -070031OUR_PATH = os.path.dirname(os.path.realpath(__file__))
Simon Glass9d2eb922017-06-18 22:09:06 -060032
33
Simon Glasseb37e2d2017-11-12 21:52:17 -070034HEADER = '''/*
35 * DO NOT MODIFY
36 *
Simon Glass6b208842020-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 Glasseb37e2d2017-11-12 21:52:17 -070039 */
40
41#include <stdbool.h>
Masahiro Yamada75f82d02018-03-05 01:20:11 +090042#include <linux/libfdt.h>'''
Simon Glasseb37e2d2017-11-12 21:52:17 -070043
Simon Glass3fa3bbb2021-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 Glassbe749002021-02-03 06:01:15 -070052C_HEADER_PRE = '''/*
Simon Glasseb37e2d2017-11-12 21:52:17 -070053 * DO NOT MODIFY
54 *
Simon Glass6b208842020-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 Glasseb37e2d2017-11-12 21:52:17 -070057 */
Simon Glassbe749002021-02-03 06:01:15 -070058'''
Simon Glasseb37e2d2017-11-12 21:52:17 -070059
Simon Glassbe749002021-02-03 06:01:15 -070060C_HEADER = C_HEADER_PRE + '''
Simon Glass1d8364a2020-12-28 20:34:54 -070061/* Allow use of U_BOOT_DRVINFO() in this file */
Simon Glassbeddd7a2020-12-28 20:35:01 -070062#define DT_PLAT_C
Simon Glass4c73d7b2020-10-03 11:31:41 -060063
Simon Glasseb37e2d2017-11-12 21:52:17 -070064#include <common.h>
65#include <dm.h>
66#include <dt-structs.h>
67'''
68
Simon Glassc7b4b832021-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 Glass768ff0a2021-02-03 06:00:51 -070077# Scanner saved from a previous run of the tests (to speed things up)
78saved_scan = None
79
Simon Glassa60cabd2020-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 Glass3bce93d2018-07-06 10:27:37 -060083
84def get_dtb_file(dts_fname, capture_stderr=False):
Simon Glass9d2eb922017-06-18 22:09:06 -060085 """Compile a .dts file to a .dtb
86
87 Args:
Simon Glassa60cabd2020-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 Glass9d2eb922017-06-18 22:09:06 -060090
91 Returns:
Simon Glassa60cabd2020-12-28 20:34:47 -070092 str: Filename of compiled file in output directory
Simon Glass9d2eb922017-06-18 22:09:06 -060093 """
Simon Glass4f4b2402021-02-03 06:00:56 -070094 return fdt_util.EnsureCompiled(os.path.join(OUR_PATH, 'test', dts_fname),
Simon Glass3bce93d2018-07-06 10:27:37 -060095 capture_stderr=capture_stderr)
Simon Glass9d2eb922017-06-18 22:09:06 -060096
Simon Glass768ff0a2021-02-03 06:00:51 -070097
98def setup():
99 global saved_scan
100
101 # Disable warnings so that calls to get_normalized_compat_name() will not
102 # output things.
Simon Glass695077d2021-03-26 16:17:25 +1300103 saved_scan = src_scan.Scanner(None, False)
Simon Glass768ff0a2021-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
Simon Glass9d2eb922017-06-18 22:09:06 -0600110
111class TestDtoc(unittest.TestCase):
112 """Tests for dtoc"""
113 @classmethod
114 def setUpClass(cls):
115 tools.PrepareOutputDir(None)
Simon Glass7f5e2262020-07-07 21:32:06 -0600116 cls.maxDiff = None
Simon Glass9d2eb922017-06-18 22:09:06 -0600117
118 @classmethod
119 def tearDownClass(cls):
Simon Glassa60cabd2020-12-28 20:34:47 -0700120 tools.FinaliseOutputDir()
Simon Glass9d2eb922017-06-18 22:09:06 -0600121
Simon Glassa60cabd2020-12-28 20:34:47 -0700122 @staticmethod
123 def _write_python_string(fname, data):
Simon Glassc47c2b32018-07-06 10:27:25 -0600124 """Write a string with tabs expanded as done in this Python file
125
126 Args:
Simon Glassa60cabd2020-12-28 20:34:47 -0700127 fname (str): Filename to write to
128 data (str): Raw string to convert
Simon Glassc47c2b32018-07-06 10:27:25 -0600129 """
130 data = data.replace('\t', '\\t')
Simon Glassa60cabd2020-12-28 20:34:47 -0700131 with open(fname, 'w') as fout:
132 fout.write(data)
Simon Glassc47c2b32018-07-06 10:27:25 -0600133
Simon Glassa60cabd2020-12-28 20:34:47 -0700134 def _check_strings(self, expected, actual):
Simon Glassc47c2b32018-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 Glassa60cabd2020-12-28 20:34:47 -0700142 expected (str): Expected string
143 actual (str): Actual string
Simon Glassc47c2b32018-07-06 10:27:25 -0600144 """
145 if expected != actual:
Simon Glassa60cabd2020-12-28 20:34:47 -0700146 self._write_python_string('/tmp/binman.expected', expected)
147 self._write_python_string('/tmp/binman.actual', actual)
Simon Glass61b88e52019-05-17 22:00:31 -0600148 print('Failures written to /tmp/binman.{expected,actual}')
Simon Glassa60cabd2020-12-28 20:34:47 -0700149 self.assertEqual(expected, actual)
Simon Glassc47c2b32018-07-06 10:27:25 -0600150
Simon Glassa60cabd2020-12-28 20:34:47 -0700151 @staticmethod
Simon Glass3809ad92021-02-03 06:01:12 -0700152 def run_test(args, dtb_file, output, instantiate=False):
Simon Glassa60cabd2020-12-28 20:34:47 -0700153 """Run a test using dtoc
Walter Lozanoa324e412020-06-25 01:10:08 -0300154
Simon Glassa60cabd2020-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 Glassbe88d2f2021-02-03 06:01:07 -0700159
160 Returns:
161 DtbPlatdata object
Simon Glassa60cabd2020-12-28 20:34:47 -0700162 """
Simon Glass80d782c42021-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 Glass3809ad92021-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 Lozanoa324e412020-06-25 01:10:08 -0300168
Simon Glass9d2eb922017-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 Glassc9a032c2020-11-08 20:36:17 -0700189 get_value(fdt.Type.INT, struct.pack('>I', 0x45)))
Simon Glass9d2eb922017-06-18 22:09:06 -0600190 self.assertEqual('0x45',
Simon Glassc9a032c2020-11-08 20:36:17 -0700191 get_value(fdt.Type.BYTE, struct.pack('<I', 0x45)))
Simon Glass9d2eb922017-06-18 22:09:06 -0600192 self.assertEqual('0x0',
Simon Glassc9a032c2020-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 Glass9d2eb922017-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 Lozano5fe734c2020-07-23 00:22:03 -0300204 self.assertEqual((['rockchip_rk3399_sdhci_5_1', 'arasan_sdhci_5_1']),
Simon Glass9d2eb922017-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 Lozano5fe734c2020-07-23 00:22:03 -0300209 self.assertEqual((['rockchip_rk3399_sdhci_5_1']),
Simon Glass9d2eb922017-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 Lozano5fe734c2020-07-23 00:22:03 -0300214 self.assertEqual((['rockchip_rk3399_sdhci_5_1',
Simon Glassa60cabd2020-12-28 20:34:47 -0700215 'arasan_sdhci_5_1', 'third']),
Simon Glass9d2eb922017-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')
221 output = tools.GetOutputFilename('output')
Simon Glass768ff0a2021-02-03 06:00:51 -0700222
223 # Run this one without saved_scan to complete test coverage
Simon Glass3809ad92021-02-03 06:01:12 -0700224 dtb_platdata.run_steps(['struct'], dtb_file, False, output, [], None,
225 False)
Simon Glass9d2eb922017-06-18 22:09:06 -0600226 with open(output) as infile:
227 lines = infile.read().splitlines()
Simon Glasseb37e2d2017-11-12 21:52:17 -0700228 self.assertEqual(HEADER.splitlines(), lines)
Simon Glass9d2eb922017-06-18 22:09:06 -0600229
Walter Lozanoa324e412020-06-25 01:10:08 -0300230 self.run_test(['platdata'], dtb_file, output)
Simon Glass9d2eb922017-06-18 22:09:06 -0600231 with open(output) as infile:
232 lines = infile.read().splitlines()
Simon Glass2500de22020-12-28 20:35:05 -0700233 self.assertEqual(C_HEADER.splitlines() + [''], lines)
Simon Glass9d2eb922017-06-18 22:09:06 -0600234
Simon Glass3fa3bbb2021-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 Glassed5e6ae2021-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 Glass3fa3bbb2021-02-03 06:01:14 -0700245
246/* uclass driver declarations - needed for DM_UCLASS_DRIVER_REF() */
Simon Glassed5e6ae2021-03-15 17:25:11 +1300247extern UCLASS_DRIVER(i2c);
248extern UCLASS_DRIVER(misc);
249extern UCLASS_DRIVER(pmic);
Simon Glass3fa3bbb2021-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 Glassed5e6ae2021-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 Glass3fa3bbb2021-02-03 06:01:14 -0700263
264/* device declarations - these allow DM_DEVICE_REF() to be used */
Simon Glassed5e6ae2021-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 Glass3fa3bbb2021-02-03 06:01:14 -0700272
273/* uclass driver declarations - needed for DM_UCLASS_DRIVER_REF() */
Simon Glassed5e6ae2021-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 Glass3fa3bbb2021-02-03 06:01:14 -0700279
280/* uclass declarations - needed for DM_UCLASS_REF() */
Simon Glassed5e6ae2021-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 Glass3fa3bbb2021-02-03 06:01:14 -0700286'''
Simon Glass07ee48e2020-12-28 20:34:49 -0700287 struct_text = HEADER + '''
Simon Glass32a8d222021-02-03 06:00:57 -0700288struct dtd_sandbox_i2c {
Simon Glass90e5f0a2017-08-29 14:15:51 -0600289};
Simon Glass32a8d222021-02-03 06:00:57 -0700290struct dtd_sandbox_pmic {
Simon Glass90e5f0a2017-08-29 14:15:51 -0600291\tbool\t\tlow_power;
Simon Glass94ba59e2021-03-26 16:17:26 +1300292\tfdt32_t\t\treg[1];
Simon Glass90e5f0a2017-08-29 14:15:51 -0600293};
Simon Glass9d2eb922017-06-18 22:09:06 -0600294struct dtd_sandbox_spl_test {
Simon Glass7f5e2262020-07-07 21:32:06 -0600295\tconst char * acpi_name;
Simon Glass9d2eb922017-06-18 22:09:06 -0600296\tbool\t\tboolval;
297\tunsigned char\tbytearray[3];
298\tunsigned char\tbyteval;
Simon Glassa7d66982021-07-28 19:23:10 -0600299\tfdt32_t\t\tintarray[3];
Simon Glass9d2eb922017-06-18 22:09:06 -0600300\tfdt32_t\t\tintval;
301\tunsigned char\tlongbytearray[9];
Simon Glass43118322021-07-28 19:23:11 -0600302\tfdt32_t\t\tmaybe_empty_int[1];
Simon Glass9c526332018-07-06 10:27:28 -0600303\tunsigned char\tnotstring[5];
Simon Glass9d2eb922017-06-18 22:09:06 -0600304\tconst char *\tstringarray[3];
305\tconst char *\tstringval;
306};
Simon Glass07ee48e2020-12-28 20:34:49 -0700307'''
Simon Glass07ee48e2020-12-28 20:34:49 -0700308 platdata_text = C_HEADER + '''
Simon Glassbe749002021-02-03 06:01:15 -0700309/*
Simon Glasse2119082021-02-03 06:01:19 -0700310 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
311 *
312 * idx driver_info driver
313 * --- -------------------- --------------------
314 * 0: i2c_at_0 sandbox_i2c
315 * 1: pmic_at_9 sandbox_pmic
316 * 2: spl_test sandbox_spl_test
317 * 3: spl_test2 sandbox_spl_test
318 * 4: spl_test3 sandbox_spl_test
319 * --- -------------------- --------------------
320 */
321
322/*
Simon Glassbe749002021-02-03 06:01:15 -0700323 * Node /i2c@0 index 0
324 * driver sandbox_i2c parent None
325 */
Simon Glass32a8d222021-02-03 06:00:57 -0700326static struct dtd_sandbox_i2c dtv_i2c_at_0 = {
Simon Glass192f8132020-10-03 11:31:25 -0600327};
Simon Glass1d8364a2020-12-28 20:34:54 -0700328U_BOOT_DRVINFO(i2c_at_0) = {
Simon Glass32a8d222021-02-03 06:00:57 -0700329\t.name\t\t= "sandbox_i2c",
Simon Glasse2119082021-02-03 06:01:19 -0700330\t.plat\t\t= &dtv_i2c_at_0,
Simon Glass39edb952020-12-03 16:55:19 -0700331\t.plat_size\t= sizeof(dtv_i2c_at_0),
Simon Glass36b15e22020-10-03 11:31:35 -0600332\t.parent_idx\t= -1,
Simon Glass192f8132020-10-03 11:31:25 -0600333};
334
Simon Glassbe749002021-02-03 06:01:15 -0700335/*
336 * Node /i2c@0/pmic@9 index 1
337 * driver sandbox_pmic parent sandbox_i2c
338 */
Simon Glass32a8d222021-02-03 06:00:57 -0700339static struct dtd_sandbox_pmic dtv_pmic_at_9 = {
Simon Glass192f8132020-10-03 11:31:25 -0600340\t.low_power\t\t= true,
Simon Glass94ba59e2021-03-26 16:17:26 +1300341\t.reg\t\t\t= {0x9},
Simon Glass192f8132020-10-03 11:31:25 -0600342};
Simon Glass1d8364a2020-12-28 20:34:54 -0700343U_BOOT_DRVINFO(pmic_at_9) = {
Simon Glass32a8d222021-02-03 06:00:57 -0700344\t.name\t\t= "sandbox_pmic",
Simon Glasse2119082021-02-03 06:01:19 -0700345\t.plat\t\t= &dtv_pmic_at_9,
Simon Glass39edb952020-12-03 16:55:19 -0700346\t.plat_size\t= sizeof(dtv_pmic_at_9),
Simon Glass36b15e22020-10-03 11:31:35 -0600347\t.parent_idx\t= 0,
Simon Glass192f8132020-10-03 11:31:25 -0600348};
349
Simon Glassbe749002021-02-03 06:01:15 -0700350/*
351 * Node /spl-test index 2
352 * driver sandbox_spl_test parent None
353 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300354static struct dtd_sandbox_spl_test dtv_spl_test = {
Simon Glassc82de562019-05-17 22:00:32 -0600355\t.boolval\t\t= true,
Simon Glass9d2eb922017-06-18 22:09:06 -0600356\t.bytearray\t\t= {0x6, 0x0, 0x0},
357\t.byteval\t\t= 0x5,
Simon Glassa7d66982021-07-28 19:23:10 -0600358\t.intarray\t\t= {0x2, 0x3, 0x4},
Simon Glass9d2eb922017-06-18 22:09:06 -0600359\t.intval\t\t\t= 0x1,
Simon Glass131e0b02017-08-29 14:15:49 -0600360\t.longbytearray\t\t= {0x9, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf, 0x10,
361\t\t0x11},
Simon Glass43118322021-07-28 19:23:11 -0600362\t.maybe_empty_int\t= {0x0},
Simon Glassc82de562019-05-17 22:00:32 -0600363\t.notstring\t\t= {0x20, 0x21, 0x22, 0x10, 0x0},
Simon Glass9d2eb922017-06-18 22:09:06 -0600364\t.stringarray\t\t= {"multi-word", "message", ""},
Simon Glassc82de562019-05-17 22:00:32 -0600365\t.stringval\t\t= "message",
Simon Glass9d2eb922017-06-18 22:09:06 -0600366};
Simon Glass1d8364a2020-12-28 20:34:54 -0700367U_BOOT_DRVINFO(spl_test) = {
Simon Glass9d2eb922017-06-18 22:09:06 -0600368\t.name\t\t= "sandbox_spl_test",
Simon Glasse2119082021-02-03 06:01:19 -0700369\t.plat\t\t= &dtv_spl_test,
Simon Glass39edb952020-12-03 16:55:19 -0700370\t.plat_size\t= sizeof(dtv_spl_test),
Simon Glass36b15e22020-10-03 11:31:35 -0600371\t.parent_idx\t= -1,
Simon Glass9d2eb922017-06-18 22:09:06 -0600372};
373
Simon Glassbe749002021-02-03 06:01:15 -0700374/*
375 * Node /spl-test2 index 3
376 * driver sandbox_spl_test parent None
377 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300378static struct dtd_sandbox_spl_test dtv_spl_test2 = {
Simon Glass7f5e2262020-07-07 21:32:06 -0600379\t.acpi_name\t\t= "\\\\_SB.GPO0",
Simon Glass9d2eb922017-06-18 22:09:06 -0600380\t.bytearray\t\t= {0x1, 0x23, 0x34},
381\t.byteval\t\t= 0x8,
Simon Glassa7d66982021-07-28 19:23:10 -0600382\t.intarray\t\t= {0x5, 0x0, 0x0},
Simon Glass9d2eb922017-06-18 22:09:06 -0600383\t.intval\t\t\t= 0x3,
Simon Glass8034e4d2020-10-03 11:31:27 -0600384\t.longbytearray\t\t= {0x9, 0xa, 0xb, 0xc, 0x0, 0x0, 0x0, 0x0,
Simon Glass131e0b02017-08-29 14:15:49 -0600385\t\t0x0},
Simon Glass9d2eb922017-06-18 22:09:06 -0600386\t.stringarray\t\t= {"another", "multi-word", "message"},
Simon Glassc82de562019-05-17 22:00:32 -0600387\t.stringval\t\t= "message2",
Simon Glass9d2eb922017-06-18 22:09:06 -0600388};
Simon Glass1d8364a2020-12-28 20:34:54 -0700389U_BOOT_DRVINFO(spl_test2) = {
Simon Glass9d2eb922017-06-18 22:09:06 -0600390\t.name\t\t= "sandbox_spl_test",
Simon Glasse2119082021-02-03 06:01:19 -0700391\t.plat\t\t= &dtv_spl_test2,
Simon Glass39edb952020-12-03 16:55:19 -0700392\t.plat_size\t= sizeof(dtv_spl_test2),
Simon Glass36b15e22020-10-03 11:31:35 -0600393\t.parent_idx\t= -1,
Simon Glass9d2eb922017-06-18 22:09:06 -0600394};
395
Simon Glassbe749002021-02-03 06:01:15 -0700396/*
397 * Node /spl-test3 index 4
398 * driver sandbox_spl_test parent None
399 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300400static struct dtd_sandbox_spl_test dtv_spl_test3 = {
Simon Glass8034e4d2020-10-03 11:31:27 -0600401\t.longbytearray\t\t= {0x9, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf, 0x10,
402\t\t0x0},
Simon Glass43118322021-07-28 19:23:11 -0600403\t.maybe_empty_int\t= {0x1},
Simon Glass9d2eb922017-06-18 22:09:06 -0600404\t.stringarray\t\t= {"one", "", ""},
405};
Simon Glass1d8364a2020-12-28 20:34:54 -0700406U_BOOT_DRVINFO(spl_test3) = {
Simon Glass9d2eb922017-06-18 22:09:06 -0600407\t.name\t\t= "sandbox_spl_test",
Simon Glasse2119082021-02-03 06:01:19 -0700408\t.plat\t\t= &dtv_spl_test3,
Simon Glass39edb952020-12-03 16:55:19 -0700409\t.plat_size\t= sizeof(dtv_spl_test3),
Simon Glass36b15e22020-10-03 11:31:35 -0600410\t.parent_idx\t= -1,
Simon Glass9d2eb922017-06-18 22:09:06 -0600411};
412
Simon Glass2500de22020-12-28 20:35:05 -0700413'''
Simon Glassc7b4b832021-02-03 06:01:20 -0700414 uclass_text_inst = '''
415
416#include <common.h>
417#include <dm.h>
418#include <dt-structs.h>
419
420/*
Simon Glassfea2f252021-02-03 06:01:21 -0700421 * uclass declarations, ordered by 'struct uclass' linker_list idx:
422 * 0: i2c
423 * 1: misc
424 * 2: root
425 * 3: testbus
426 * 4: testfdt
Simon Glassc7b4b832021-02-03 06:01:20 -0700427 *
Simon Glassfea2f252021-02-03 06:01:21 -0700428 * Sequence numbers allocated in each uclass:
Simon Glassc7b4b832021-02-03 06:01:20 -0700429 * i2c: UCLASS_I2C
430 * 4: /i2c
431 * misc: UCLASS_MISC
432 * 0: /spl-test
433 * 1: /spl-test3
434 * root: UCLASS_ROOT
435 * 0: /
436 * testbus: UCLASS_TEST_BUS
437 * 2: /some-bus
438 * testfdt: UCLASS_TEST_FDT
439 * 1: /some-bus/test
440 * 2: /some-bus/test0
441 */
442
443struct list_head uclass_head = {
444 .prev = &DM_UCLASS_REF(testfdt)->sibling_node,
445 .next = &DM_UCLASS_REF(i2c)->sibling_node,
446};
447
448DM_UCLASS_INST(i2c) = {
449 .uc_drv = DM_UCLASS_DRIVER_REF(i2c),
450 .sibling_node = {
451 .prev = &uclass_head,
452 .next = &DM_UCLASS_REF(misc)->sibling_node,
453 },
454 .dev_head = {
455 .prev = &DM_DEVICE_REF(i2c)->uclass_node,
456 .next = &DM_DEVICE_REF(i2c)->uclass_node,
457 },
458};
459
460DM_UCLASS_INST(misc) = {
461 .uc_drv = DM_UCLASS_DRIVER_REF(misc),
462 .sibling_node = {
463 .prev = &DM_UCLASS_REF(i2c)->sibling_node,
464 .next = &DM_UCLASS_REF(root)->sibling_node,
465 },
466 .dev_head = {
467 .prev = &DM_DEVICE_REF(spl_test3)->uclass_node,
468 .next = &DM_DEVICE_REF(spl_test)->uclass_node,
469 },
470};
471
472DM_UCLASS_INST(root) = {
473 .uc_drv = DM_UCLASS_DRIVER_REF(root),
474 .sibling_node = {
475 .prev = &DM_UCLASS_REF(misc)->sibling_node,
476 .next = &DM_UCLASS_REF(testbus)->sibling_node,
477 },
478 .dev_head = {
479 .prev = &DM_DEVICE_REF(root)->uclass_node,
480 .next = &DM_DEVICE_REF(root)->uclass_node,
481 },
482};
483
484DM_UCLASS_INST(testbus) = {
485 .uc_drv = DM_UCLASS_DRIVER_REF(testbus),
486 .sibling_node = {
487 .prev = &DM_UCLASS_REF(root)->sibling_node,
488 .next = &DM_UCLASS_REF(testfdt)->sibling_node,
489 },
490 .dev_head = {
491 .prev = &DM_DEVICE_REF(some_bus)->uclass_node,
492 .next = &DM_DEVICE_REF(some_bus)->uclass_node,
493 },
494};
495
496#include <dm/test.h>
497u8 _testfdt_priv_[sizeof(struct dm_test_uc_priv)]
498 __attribute__ ((section (".priv_data")));
499DM_UCLASS_INST(testfdt) = {
500 .priv_ = _testfdt_priv_,
501 .uc_drv = DM_UCLASS_DRIVER_REF(testfdt),
502 .sibling_node = {
503 .prev = &DM_UCLASS_REF(testbus)->sibling_node,
504 .next = &uclass_head,
505 },
506 .dev_head = {
507 .prev = &DM_DEVICE_REF(test0)->uclass_node,
508 .next = &DM_DEVICE_REF(test)->uclass_node,
509 },
510};
511
Simon Glassfea2f252021-02-03 06:01:21 -0700512'''
513 device_text_inst = '''/*
514 * DO NOT MODIFY
515 *
516 * Declares the DM_DEVICE_INST() records.
517 * This was generated by dtoc from a .dtb (device tree binary) file.
518 */
519
520#include <common.h>
521#include <dm.h>
522#include <dt-structs.h>
523
524/*
525 * udevice declarations, ordered by 'struct udevice' linker_list position:
526 *
527 * idx udevice driver
528 * --- -------------------- --------------------
529 * 0: i2c sandbox_i2c
530 * 1: root root_driver
531 * 2: some_bus denx_u_boot_test_bus
532 * 3: spl_test sandbox_spl_test
533 * 4: spl_test3 sandbox_spl_test
534 * 5: test denx_u_boot_fdt_test
535 * 6: test0 denx_u_boot_fdt_test
536 * --- -------------------- --------------------
537 */
538
539/*
540 * Node /i2c index 0
541 * driver sandbox_i2c parent root_driver
542*/
543static struct dtd_sandbox_i2c dtv_i2c = {
544\t.intval\t\t\t= 0x3,
545};
546
547#include <asm/i2c.h>
548u8 _sandbox_i2c_priv_i2c[sizeof(struct sandbox_i2c_priv)]
549\t__attribute__ ((section (".priv_data")));
550#include <i2c.h>
551u8 _sandbox_i2c_uc_priv_i2c[sizeof(struct dm_i2c_bus)]
552\t__attribute__ ((section (".priv_data")));
553
554DM_DEVICE_INST(i2c) = {
555\t.driver\t\t= DM_DRIVER_REF(sandbox_i2c),
556\t.name\t\t= "sandbox_i2c",
557\t.plat_\t\t= &dtv_i2c,
558\t.priv_\t\t= _sandbox_i2c_priv_i2c,
559\t.uclass\t\t= DM_UCLASS_REF(i2c),
560\t.uclass_priv_ = _sandbox_i2c_uc_priv_i2c,
561\t.uclass_node\t= {
562\t\t.prev = &DM_UCLASS_REF(i2c)->dev_head,
563\t\t.next = &DM_UCLASS_REF(i2c)->dev_head,
564\t},
565\t.child_head\t= {
566\t\t.prev = &DM_DEVICE_REF(i2c)->child_head,
567\t\t.next = &DM_DEVICE_REF(i2c)->child_head,
568\t},
569\t.sibling_node\t= {
570\t\t.prev = &DM_DEVICE_REF(root)->child_head,
571\t\t.next = &DM_DEVICE_REF(some_bus)->sibling_node,
572\t},
573\t.seq_ = 4,
574};
575
576/*
577 * Node / index 1
578 * driver root_driver parent None
579*/
580static struct dtd_root_driver dtv_root = {
581};
582
583DM_DEVICE_INST(root) = {
584\t.driver\t\t= DM_DRIVER_REF(root_driver),
585\t.name\t\t= "root_driver",
586\t.plat_\t\t= &dtv_root,
587\t.uclass\t\t= DM_UCLASS_REF(root),
588\t.uclass_node\t= {
589\t\t.prev = &DM_UCLASS_REF(root)->dev_head,
590\t\t.next = &DM_UCLASS_REF(root)->dev_head,
591\t},
592\t.child_head\t= {
593\t\t.prev = &DM_DEVICE_REF(spl_test3)->sibling_node,
594\t\t.next = &DM_DEVICE_REF(i2c)->sibling_node,
595\t},
596\t.seq_ = 0,
597};
598
599/*
600 * Node /some-bus index 2
601 * driver denx_u_boot_test_bus parent root_driver
602*/
603
604#include <dm/test.h>
605struct dm_test_pdata __attribute__ ((section (".priv_data")))
606\t_denx_u_boot_test_bus_plat_some_bus = {
607\t.dtplat = {
608\t\t.ping_add\t\t= 0x4,
609\t\t.ping_expect\t\t= 0x4,
610\t\t.reg\t\t\t= {0x3, 0x1},
611\t},
612};
613#include <dm/test.h>
614u8 _denx_u_boot_test_bus_priv_some_bus[sizeof(struct dm_test_priv)]
615\t__attribute__ ((section (".priv_data")));
616#include <dm/test.h>
617u8 _denx_u_boot_test_bus_ucplat_some_bus[sizeof(struct dm_test_uclass_priv)]
618\t__attribute__ ((section (".priv_data")));
619#include <test.h>
620
621DM_DEVICE_INST(some_bus) = {
622\t.driver\t\t= DM_DRIVER_REF(denx_u_boot_test_bus),
623\t.name\t\t= "denx_u_boot_test_bus",
624\t.plat_\t\t= &_denx_u_boot_test_bus_plat_some_bus,
625\t.uclass_plat_\t= _denx_u_boot_test_bus_ucplat_some_bus,
626\t.driver_data\t= DM_TEST_TYPE_FIRST,
627\t.priv_\t\t= _denx_u_boot_test_bus_priv_some_bus,
628\t.uclass\t\t= DM_UCLASS_REF(testbus),
629\t.uclass_node\t= {
630\t\t.prev = &DM_UCLASS_REF(testbus)->dev_head,
631\t\t.next = &DM_UCLASS_REF(testbus)->dev_head,
632\t},
633\t.child_head\t= {
634\t\t.prev = &DM_DEVICE_REF(test0)->sibling_node,
635\t\t.next = &DM_DEVICE_REF(test)->sibling_node,
636\t},
637\t.sibling_node\t= {
638\t\t.prev = &DM_DEVICE_REF(i2c)->sibling_node,
639\t\t.next = &DM_DEVICE_REF(spl_test)->sibling_node,
640\t},
641\t.seq_ = 2,
642};
643
644/*
645 * Node /spl-test index 3
646 * driver sandbox_spl_test parent root_driver
647*/
648static struct dtd_sandbox_spl_test dtv_spl_test = {
649\t.boolval\t\t= true,
650\t.intval\t\t\t= 0x1,
651};
652
653DM_DEVICE_INST(spl_test) = {
654\t.driver\t\t= DM_DRIVER_REF(sandbox_spl_test),
655\t.name\t\t= "sandbox_spl_test",
656\t.plat_\t\t= &dtv_spl_test,
657\t.uclass\t\t= DM_UCLASS_REF(misc),
658\t.uclass_node\t= {
659\t\t.prev = &DM_UCLASS_REF(misc)->dev_head,
660\t\t.next = &DM_DEVICE_REF(spl_test3)->uclass_node,
661\t},
662\t.child_head\t= {
663\t\t.prev = &DM_DEVICE_REF(spl_test)->child_head,
664\t\t.next = &DM_DEVICE_REF(spl_test)->child_head,
665\t},
666\t.sibling_node\t= {
667\t\t.prev = &DM_DEVICE_REF(some_bus)->sibling_node,
668\t\t.next = &DM_DEVICE_REF(spl_test3)->sibling_node,
669\t},
670\t.seq_ = 0,
671};
672
673/*
674 * Node /spl-test3 index 4
675 * driver sandbox_spl_test parent root_driver
676*/
677static struct dtd_sandbox_spl_test dtv_spl_test3 = {
678\t.longbytearray\t\t= {0x90a0b0c, 0xd0e0f10},
679\t.stringarray\t\t= "one",
680};
681
682DM_DEVICE_INST(spl_test3) = {
683\t.driver\t\t= DM_DRIVER_REF(sandbox_spl_test),
684\t.name\t\t= "sandbox_spl_test",
685\t.plat_\t\t= &dtv_spl_test3,
686\t.uclass\t\t= DM_UCLASS_REF(misc),
687\t.uclass_node\t= {
688\t\t.prev = &DM_DEVICE_REF(spl_test)->uclass_node,
689\t\t.next = &DM_UCLASS_REF(misc)->dev_head,
690\t},
691\t.child_head\t= {
692\t\t.prev = &DM_DEVICE_REF(spl_test3)->child_head,
693\t\t.next = &DM_DEVICE_REF(spl_test3)->child_head,
694\t},
695\t.sibling_node\t= {
696\t\t.prev = &DM_DEVICE_REF(spl_test)->sibling_node,
697\t\t.next = &DM_DEVICE_REF(root)->child_head,
698\t},
699\t.seq_ = 1,
700};
701
702/*
703 * Node /some-bus/test index 5
704 * driver denx_u_boot_fdt_test parent denx_u_boot_test_bus
705*/
706
707#include <dm/test.h>
708struct dm_test_pdata __attribute__ ((section (".priv_data")))
709\t_denx_u_boot_fdt_test_plat_test = {
710\t.dtplat = {
711\t\t.ping_add\t\t= 0x5,
712\t\t.ping_expect\t\t= 0x5,
Simon Glass94ba59e2021-03-26 16:17:26 +1300713\t\t.reg\t\t\t= {0x5},
Simon Glassfea2f252021-02-03 06:01:21 -0700714\t},
715};
716#include <dm/test.h>
717u8 _denx_u_boot_fdt_test_priv_test[sizeof(struct dm_test_priv)]
718\t__attribute__ ((section (".priv_data")));
719#include <dm/test.h>
720u8 _denx_u_boot_fdt_test_parent_plat_test[sizeof(struct dm_test_parent_plat)]
721\t__attribute__ ((section (".priv_data")));
722#include <dm/test.h>
723u8 _denx_u_boot_fdt_test_parent_priv_test[sizeof(struct dm_test_parent_data)]
724\t__attribute__ ((section (".priv_data")));
725
726DM_DEVICE_INST(test) = {
727\t.driver\t\t= DM_DRIVER_REF(denx_u_boot_fdt_test),
728\t.name\t\t= "denx_u_boot_fdt_test",
729\t.plat_\t\t= &_denx_u_boot_fdt_test_plat_test,
730\t.parent_plat_\t= _denx_u_boot_fdt_test_parent_plat_test,
731\t.driver_data\t= DM_TEST_TYPE_FIRST,
732\t.parent\t\t= DM_DEVICE_REF(some_bus),
733\t.priv_\t\t= _denx_u_boot_fdt_test_priv_test,
734\t.uclass\t\t= DM_UCLASS_REF(testfdt),
735\t.parent_priv_\t= _denx_u_boot_fdt_test_parent_priv_test,
736\t.uclass_node\t= {
737\t\t.prev = &DM_UCLASS_REF(testfdt)->dev_head,
738\t\t.next = &DM_DEVICE_REF(test0)->uclass_node,
739\t},
740\t.child_head\t= {
741\t\t.prev = &DM_DEVICE_REF(test)->child_head,
742\t\t.next = &DM_DEVICE_REF(test)->child_head,
743\t},
744\t.sibling_node\t= {
745\t\t.prev = &DM_DEVICE_REF(some_bus)->child_head,
746\t\t.next = &DM_DEVICE_REF(test0)->sibling_node,
747\t},
748\t.seq_ = 1,
749};
750
751/*
752 * Node /some-bus/test0 index 6
753 * driver denx_u_boot_fdt_test parent denx_u_boot_test_bus
754*/
755
756#include <dm/test.h>
757struct dm_test_pdata __attribute__ ((section (".priv_data")))
758\t_denx_u_boot_fdt_test_plat_test0 = {
759\t.dtplat = {
760\t},
761};
762#include <dm/test.h>
763u8 _denx_u_boot_fdt_test_priv_test0[sizeof(struct dm_test_priv)]
764\t__attribute__ ((section (".priv_data")));
765#include <dm/test.h>
766u8 _denx_u_boot_fdt_test_parent_plat_test0[sizeof(struct dm_test_parent_plat)]
767\t__attribute__ ((section (".priv_data")));
768#include <dm/test.h>
769u8 _denx_u_boot_fdt_test_parent_priv_test0[sizeof(struct dm_test_parent_data)]
770\t__attribute__ ((section (".priv_data")));
771
772DM_DEVICE_INST(test0) = {
773\t.driver\t\t= DM_DRIVER_REF(denx_u_boot_fdt_test),
774\t.name\t\t= "denx_u_boot_fdt_test",
775\t.plat_\t\t= &_denx_u_boot_fdt_test_plat_test0,
776\t.parent_plat_\t= _denx_u_boot_fdt_test_parent_plat_test0,
777\t.driver_data\t= DM_TEST_TYPE_SECOND,
778\t.parent\t\t= DM_DEVICE_REF(some_bus),
779\t.priv_\t\t= _denx_u_boot_fdt_test_priv_test0,
780\t.uclass\t\t= DM_UCLASS_REF(testfdt),
781\t.parent_priv_\t= _denx_u_boot_fdt_test_parent_priv_test0,
782\t.uclass_node\t= {
783\t\t.prev = &DM_DEVICE_REF(test)->uclass_node,
784\t\t.next = &DM_UCLASS_REF(testfdt)->dev_head,
785\t},
786\t.child_head\t= {
787\t\t.prev = &DM_DEVICE_REF(test0)->child_head,
788\t\t.next = &DM_DEVICE_REF(test0)->child_head,
789\t},
790\t.sibling_node\t= {
791\t\t.prev = &DM_DEVICE_REF(test)->sibling_node,
792\t\t.next = &DM_DEVICE_REF(some_bus)->child_head,
793\t},
794\t.seq_ = 2,
795};
796
797'''
Simon Glass07ee48e2020-12-28 20:34:49 -0700798
799 def test_simple(self):
800 """Test output from some simple nodes with various types of data"""
801 dtb_file = get_dtb_file('dtoc_test_simple.dts')
802 output = tools.GetOutputFilename('output')
803 self.run_test(['struct'], dtb_file, output)
804 with open(output) as infile:
805 data = infile.read()
806
807 self._check_strings(self.struct_text, data)
808
809 self.run_test(['platdata'], dtb_file, output)
810 with open(output) as infile:
811 data = infile.read()
812
813 self._check_strings(self.platdata_text, data)
Simon Glass9d2eb922017-06-18 22:09:06 -0600814
Simon Glass3fa3bbb2021-02-03 06:01:14 -0700815 self.run_test(['decl'], dtb_file, output)
816 with open(output) as infile:
817 data = infile.read()
818
819 self._check_strings(self.decl_text, data)
820
Simon Glass4e8e8462020-12-28 20:34:52 -0700821 # Try the 'all' command
822 self.run_test(['all'], dtb_file, output)
823 data = tools.ReadFile(output, binary=False)
Simon Glassfea2f252021-02-03 06:01:21 -0700824 self._check_strings(
Simon Glass705b84b2021-04-27 08:19:48 +1200825 self.decl_text + self.platdata_text + self.struct_text, data)
Simon Glass4e8e8462020-12-28 20:34:52 -0700826
Walter Lozanoe675d962020-07-03 08:07:17 -0300827 def test_driver_alias(self):
828 """Test output from a device tree file with a driver alias"""
829 dtb_file = get_dtb_file('dtoc_test_driver_alias.dts')
830 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300831 self.run_test(['struct'], dtb_file, output)
Walter Lozanoe675d962020-07-03 08:07:17 -0300832 with open(output) as infile:
833 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700834 self._check_strings(HEADER + '''
Walter Lozanoe675d962020-07-03 08:07:17 -0300835struct dtd_sandbox_gpio {
836\tconst char *\tgpio_bank_name;
837\tbool\t\tgpio_controller;
838\tfdt32_t\t\tsandbox_gpio_count;
839};
Walter Lozanoe675d962020-07-03 08:07:17 -0300840''', data)
841
Walter Lozanoa324e412020-06-25 01:10:08 -0300842 self.run_test(['platdata'], dtb_file, output)
Walter Lozanoe675d962020-07-03 08:07:17 -0300843 with open(output) as infile:
844 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700845 self._check_strings(C_HEADER + '''
Simon Glassbe749002021-02-03 06:01:15 -0700846/*
Simon Glasse2119082021-02-03 06:01:19 -0700847 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
848 *
849 * idx driver_info driver
850 * --- -------------------- --------------------
851 * 0: gpios_at_0 sandbox_gpio
852 * --- -------------------- --------------------
853 */
854
855/*
Simon Glassbe749002021-02-03 06:01:15 -0700856 * Node /gpios@0 index 0
857 * driver sandbox_gpio parent None
858 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300859static struct dtd_sandbox_gpio dtv_gpios_at_0 = {
Walter Lozanoe675d962020-07-03 08:07:17 -0300860\t.gpio_bank_name\t\t= "a",
861\t.gpio_controller\t= true,
862\t.sandbox_gpio_count\t= 0x14,
863};
Simon Glass1d8364a2020-12-28 20:34:54 -0700864U_BOOT_DRVINFO(gpios_at_0) = {
Walter Lozanoe675d962020-07-03 08:07:17 -0300865\t.name\t\t= "sandbox_gpio",
Simon Glasse2119082021-02-03 06:01:19 -0700866\t.plat\t\t= &dtv_gpios_at_0,
Simon Glass39edb952020-12-03 16:55:19 -0700867\t.plat_size\t= sizeof(dtv_gpios_at_0),
Simon Glass36b15e22020-10-03 11:31:35 -0600868\t.parent_idx\t= -1,
Walter Lozanoe675d962020-07-03 08:07:17 -0300869};
870
871''', data)
872
Walter Lozanoa324e412020-06-25 01:10:08 -0300873 def test_invalid_driver(self):
874 """Test output from a device tree file with an invalid driver"""
875 dtb_file = get_dtb_file('dtoc_test_invalid_driver.dts')
876 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -0700877 with test_util.capture_sys_output() as _:
Simon Glass3809ad92021-02-03 06:01:12 -0700878 dtb_platdata.run_steps(
879 ['struct'], dtb_file, False, output, [], None, False,
880 scan=copy_scan())
Walter Lozanoa324e412020-06-25 01:10:08 -0300881 with open(output) as infile:
882 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700883 self._check_strings(HEADER + '''
Walter Lozanoa324e412020-06-25 01:10:08 -0300884struct dtd_invalid {
885};
886''', data)
887
Simon Glassa60cabd2020-12-28 20:34:47 -0700888 with test_util.capture_sys_output() as _:
Simon Glass3809ad92021-02-03 06:01:12 -0700889 dtb_platdata.run_steps(
890 ['platdata'], dtb_file, False, output, [], None, False,
891 scan=copy_scan())
Walter Lozanoa324e412020-06-25 01:10:08 -0300892 with open(output) as infile:
893 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700894 self._check_strings(C_HEADER + '''
Simon Glasse2119082021-02-03 06:01:19 -0700895/*
896 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
897 *
898 * idx driver_info driver
899 * --- -------------------- --------------------
900 * 0: spl_test invalid
901 * --- -------------------- --------------------
902 */
903
Simon Glass192f8132020-10-03 11:31:25 -0600904/* Node /spl-test index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300905static struct dtd_invalid dtv_spl_test = {
Walter Lozanoa324e412020-06-25 01:10:08 -0300906};
Simon Glass1d8364a2020-12-28 20:34:54 -0700907U_BOOT_DRVINFO(spl_test) = {
Walter Lozanoa324e412020-06-25 01:10:08 -0300908\t.name\t\t= "invalid",
Simon Glasse2119082021-02-03 06:01:19 -0700909\t.plat\t\t= &dtv_spl_test,
Simon Glass39edb952020-12-03 16:55:19 -0700910\t.plat_size\t= sizeof(dtv_spl_test),
Simon Glass36b15e22020-10-03 11:31:35 -0600911\t.parent_idx\t= -1,
Walter Lozanoa324e412020-06-25 01:10:08 -0300912};
913
914''', data)
915
Simon Glass9d2eb922017-06-18 22:09:06 -0600916 def test_phandle(self):
917 """Test output from a node containing a phandle reference"""
918 dtb_file = get_dtb_file('dtoc_test_phandle.dts')
919 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300920 self.run_test(['struct'], dtb_file, output)
Simon Glass9d2eb922017-06-18 22:09:06 -0600921 with open(output) as infile:
922 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700923 self._check_strings(HEADER + '''
Simon Glass9d2eb922017-06-18 22:09:06 -0600924struct dtd_source {
Simon Glass3deeb472017-08-29 14:15:59 -0600925\tstruct phandle_2_arg clocks[4];
Simon Glass9d2eb922017-06-18 22:09:06 -0600926};
927struct dtd_target {
928\tfdt32_t\t\tintval;
929};
930''', data)
931
Walter Lozanoa324e412020-06-25 01:10:08 -0300932 self.run_test(['platdata'], dtb_file, output)
Simon Glass9d2eb922017-06-18 22:09:06 -0600933 with open(output) as infile:
934 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700935 self._check_strings(C_HEADER + '''
Simon Glasse2119082021-02-03 06:01:19 -0700936/*
937 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
938 *
939 * idx driver_info driver
940 * --- -------------------- --------------------
941 * 0: phandle2_target target
942 * 1: phandle3_target target
943 * 2: phandle_source source
944 * 3: phandle_source2 source
945 * 4: phandle_target target
946 * --- -------------------- --------------------
947 */
948
Simon Glass192f8132020-10-03 11:31:25 -0600949/* Node /phandle2-target index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300950static struct dtd_target dtv_phandle2_target = {
Simon Glass3deeb472017-08-29 14:15:59 -0600951\t.intval\t\t\t= 0x1,
952};
Simon Glass1d8364a2020-12-28 20:34:54 -0700953U_BOOT_DRVINFO(phandle2_target) = {
Simon Glass3deeb472017-08-29 14:15:59 -0600954\t.name\t\t= "target",
Simon Glasse2119082021-02-03 06:01:19 -0700955\t.plat\t\t= &dtv_phandle2_target,
Simon Glass39edb952020-12-03 16:55:19 -0700956\t.plat_size\t= sizeof(dtv_phandle2_target),
Simon Glass36b15e22020-10-03 11:31:35 -0600957\t.parent_idx\t= -1,
Simon Glass3deeb472017-08-29 14:15:59 -0600958};
959
Simon Glass192f8132020-10-03 11:31:25 -0600960/* Node /phandle3-target index 1 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300961static struct dtd_target dtv_phandle3_target = {
Simon Glass3deeb472017-08-29 14:15:59 -0600962\t.intval\t\t\t= 0x2,
963};
Simon Glass1d8364a2020-12-28 20:34:54 -0700964U_BOOT_DRVINFO(phandle3_target) = {
Simon Glass3deeb472017-08-29 14:15:59 -0600965\t.name\t\t= "target",
Simon Glasse2119082021-02-03 06:01:19 -0700966\t.plat\t\t= &dtv_phandle3_target,
Simon Glass39edb952020-12-03 16:55:19 -0700967\t.plat_size\t= sizeof(dtv_phandle3_target),
Simon Glass36b15e22020-10-03 11:31:35 -0600968\t.parent_idx\t= -1,
Simon Glass3deeb472017-08-29 14:15:59 -0600969};
970
Simon Glass192f8132020-10-03 11:31:25 -0600971/* Node /phandle-source index 2 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300972static struct dtd_source dtv_phandle_source = {
Simon Glassd0cd0752017-08-29 14:15:57 -0600973\t.clocks\t\t\t= {
Simon Glass5792f4b2020-10-03 11:31:40 -0600974\t\t\t{4, {}},
975\t\t\t{0, {11}},
976\t\t\t{1, {12, 13}},
977\t\t\t{4, {}},},
Simon Glass9d2eb922017-06-18 22:09:06 -0600978};
Simon Glass1d8364a2020-12-28 20:34:54 -0700979U_BOOT_DRVINFO(phandle_source) = {
Simon Glass9d2eb922017-06-18 22:09:06 -0600980\t.name\t\t= "source",
Simon Glasse2119082021-02-03 06:01:19 -0700981\t.plat\t\t= &dtv_phandle_source,
Simon Glass39edb952020-12-03 16:55:19 -0700982\t.plat_size\t= sizeof(dtv_phandle_source),
Simon Glass36b15e22020-10-03 11:31:35 -0600983\t.parent_idx\t= -1,
Simon Glass9d2eb922017-06-18 22:09:06 -0600984};
985
Simon Glass192f8132020-10-03 11:31:25 -0600986/* Node /phandle-source2 index 3 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300987static struct dtd_source dtv_phandle_source2 = {
Simon Glass609e2b12018-07-06 10:27:31 -0600988\t.clocks\t\t\t= {
Simon Glass5792f4b2020-10-03 11:31:40 -0600989\t\t\t{4, {}},},
Simon Glass609e2b12018-07-06 10:27:31 -0600990};
Simon Glass1d8364a2020-12-28 20:34:54 -0700991U_BOOT_DRVINFO(phandle_source2) = {
Simon Glass609e2b12018-07-06 10:27:31 -0600992\t.name\t\t= "source",
Simon Glasse2119082021-02-03 06:01:19 -0700993\t.plat\t\t= &dtv_phandle_source2,
Simon Glass39edb952020-12-03 16:55:19 -0700994\t.plat_size\t= sizeof(dtv_phandle_source2),
Simon Glass36b15e22020-10-03 11:31:35 -0600995\t.parent_idx\t= -1,
Simon Glass609e2b12018-07-06 10:27:31 -0600996};
997
Simon Glass16382ce2020-12-28 20:35:04 -0700998/* Node /phandle-target index 4 */
999static struct dtd_target dtv_phandle_target = {
1000\t.intval\t\t\t= 0x0,
1001};
1002U_BOOT_DRVINFO(phandle_target) = {
1003\t.name\t\t= "target",
Simon Glasse2119082021-02-03 06:01:19 -07001004\t.plat\t\t= &dtv_phandle_target,
Simon Glass16382ce2020-12-28 20:35:04 -07001005\t.plat_size\t= sizeof(dtv_phandle_target),
1006\t.parent_idx\t= -1,
1007};
1008
Simon Glass9d2eb922017-06-18 22:09:06 -06001009''', data)
1010
Simon Glass961c1ce2018-07-06 10:27:35 -06001011 def test_phandle_single(self):
1012 """Test output from a node containing a phandle reference"""
1013 dtb_file = get_dtb_file('dtoc_test_phandle_single.dts')
1014 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -03001015 self.run_test(['struct'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -06001016 with open(output) as infile:
1017 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -07001018 self._check_strings(HEADER + '''
Simon Glass961c1ce2018-07-06 10:27:35 -06001019struct dtd_source {
1020\tstruct phandle_0_arg clocks[1];
1021};
1022struct dtd_target {
1023\tfdt32_t\t\tintval;
1024};
1025''', data)
1026
1027 def test_phandle_reorder(self):
1028 """Test that phandle targets are generated before their references"""
1029 dtb_file = get_dtb_file('dtoc_test_phandle_reorder.dts')
1030 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -03001031 self.run_test(['platdata'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -06001032 with open(output) as infile:
1033 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -07001034 self._check_strings(C_HEADER + '''
Simon Glasse2119082021-02-03 06:01:19 -07001035/*
1036 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
1037 *
1038 * idx driver_info driver
1039 * --- -------------------- --------------------
1040 * 0: phandle_source2 source
1041 * 1: phandle_target target
1042 * --- -------------------- --------------------
1043 */
1044
Simon Glass192f8132020-10-03 11:31:25 -06001045/* Node /phandle-source2 index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -03001046static struct dtd_source dtv_phandle_source2 = {
Simon Glass961c1ce2018-07-06 10:27:35 -06001047\t.clocks\t\t\t= {
Simon Glass5792f4b2020-10-03 11:31:40 -06001048\t\t\t{1, {}},},
Simon Glass961c1ce2018-07-06 10:27:35 -06001049};
Simon Glass1d8364a2020-12-28 20:34:54 -07001050U_BOOT_DRVINFO(phandle_source2) = {
Simon Glass961c1ce2018-07-06 10:27:35 -06001051\t.name\t\t= "source",
Simon Glasse2119082021-02-03 06:01:19 -07001052\t.plat\t\t= &dtv_phandle_source2,
Simon Glass39edb952020-12-03 16:55:19 -07001053\t.plat_size\t= sizeof(dtv_phandle_source2),
Simon Glass36b15e22020-10-03 11:31:35 -06001054\t.parent_idx\t= -1,
Simon Glass961c1ce2018-07-06 10:27:35 -06001055};
1056
Simon Glass16382ce2020-12-28 20:35:04 -07001057/* Node /phandle-target index 1 */
1058static struct dtd_target dtv_phandle_target = {
1059};
1060U_BOOT_DRVINFO(phandle_target) = {
1061\t.name\t\t= "target",
Simon Glasse2119082021-02-03 06:01:19 -07001062\t.plat\t\t= &dtv_phandle_target,
Simon Glass16382ce2020-12-28 20:35:04 -07001063\t.plat_size\t= sizeof(dtv_phandle_target),
1064\t.parent_idx\t= -1,
1065};
1066
Simon Glass961c1ce2018-07-06 10:27:35 -06001067''', data)
1068
Walter Lozano5541fc02020-06-25 01:10:17 -03001069 def test_phandle_cd_gpio(self):
1070 """Test that phandle targets are generated when unsing cd-gpios"""
1071 dtb_file = get_dtb_file('dtoc_test_phandle_cd_gpios.dts')
1072 output = tools.GetOutputFilename('output')
Simon Glass3809ad92021-02-03 06:01:12 -07001073 dtb_platdata.run_steps(
1074 ['platdata'], dtb_file, False, output, [], None, False,
1075 warning_disabled=True, scan=copy_scan())
Walter Lozano5541fc02020-06-25 01:10:17 -03001076 with open(output) as infile:
1077 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -07001078 self._check_strings(C_HEADER + '''
Simon Glasse2119082021-02-03 06:01:19 -07001079/*
1080 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
1081 *
1082 * idx driver_info driver
1083 * --- -------------------- --------------------
1084 * 0: phandle2_target target
1085 * 1: phandle3_target target
1086 * 2: phandle_source source
1087 * 3: phandle_source2 source
1088 * 4: phandle_target target
1089 * --- -------------------- --------------------
1090 */
1091
Simon Glass192f8132020-10-03 11:31:25 -06001092/* Node /phandle2-target index 0 */
Walter Lozano5541fc02020-06-25 01:10:17 -03001093static struct dtd_target dtv_phandle2_target = {
1094\t.intval\t\t\t= 0x1,
1095};
Simon Glass1d8364a2020-12-28 20:34:54 -07001096U_BOOT_DRVINFO(phandle2_target) = {
Walter Lozano5541fc02020-06-25 01:10:17 -03001097\t.name\t\t= "target",
Simon Glasse2119082021-02-03 06:01:19 -07001098\t.plat\t\t= &dtv_phandle2_target,
Simon Glass39edb952020-12-03 16:55:19 -07001099\t.plat_size\t= sizeof(dtv_phandle2_target),
Simon Glass36b15e22020-10-03 11:31:35 -06001100\t.parent_idx\t= -1,
Walter Lozano5541fc02020-06-25 01:10:17 -03001101};
1102
Simon Glass192f8132020-10-03 11:31:25 -06001103/* Node /phandle3-target index 1 */
Walter Lozano5541fc02020-06-25 01:10:17 -03001104static struct dtd_target dtv_phandle3_target = {
1105\t.intval\t\t\t= 0x2,
1106};
Simon Glass1d8364a2020-12-28 20:34:54 -07001107U_BOOT_DRVINFO(phandle3_target) = {
Walter Lozano5541fc02020-06-25 01:10:17 -03001108\t.name\t\t= "target",
Simon Glasse2119082021-02-03 06:01:19 -07001109\t.plat\t\t= &dtv_phandle3_target,
Simon Glass39edb952020-12-03 16:55:19 -07001110\t.plat_size\t= sizeof(dtv_phandle3_target),
Simon Glass36b15e22020-10-03 11:31:35 -06001111\t.parent_idx\t= -1,
Walter Lozano5541fc02020-06-25 01:10:17 -03001112};
1113
Simon Glass192f8132020-10-03 11:31:25 -06001114/* Node /phandle-source index 2 */
Walter Lozano5541fc02020-06-25 01:10:17 -03001115static struct dtd_source dtv_phandle_source = {
1116\t.cd_gpios\t\t= {
Simon Glass5792f4b2020-10-03 11:31:40 -06001117\t\t\t{4, {}},
1118\t\t\t{0, {11}},
1119\t\t\t{1, {12, 13}},
1120\t\t\t{4, {}},},
Walter Lozano5541fc02020-06-25 01:10:17 -03001121};
Simon Glass1d8364a2020-12-28 20:34:54 -07001122U_BOOT_DRVINFO(phandle_source) = {
Walter Lozano5541fc02020-06-25 01:10:17 -03001123\t.name\t\t= "source",
Simon Glasse2119082021-02-03 06:01:19 -07001124\t.plat\t\t= &dtv_phandle_source,
Simon Glass39edb952020-12-03 16:55:19 -07001125\t.plat_size\t= sizeof(dtv_phandle_source),
Simon Glass36b15e22020-10-03 11:31:35 -06001126\t.parent_idx\t= -1,
Walter Lozano5541fc02020-06-25 01:10:17 -03001127};
1128
Simon Glass192f8132020-10-03 11:31:25 -06001129/* Node /phandle-source2 index 3 */
Walter Lozano5541fc02020-06-25 01:10:17 -03001130static struct dtd_source dtv_phandle_source2 = {
1131\t.cd_gpios\t\t= {
Simon Glass5792f4b2020-10-03 11:31:40 -06001132\t\t\t{4, {}},},
Walter Lozano5541fc02020-06-25 01:10:17 -03001133};
Simon Glass1d8364a2020-12-28 20:34:54 -07001134U_BOOT_DRVINFO(phandle_source2) = {
Walter Lozano5541fc02020-06-25 01:10:17 -03001135\t.name\t\t= "source",
Simon Glasse2119082021-02-03 06:01:19 -07001136\t.plat\t\t= &dtv_phandle_source2,
Simon Glass39edb952020-12-03 16:55:19 -07001137\t.plat_size\t= sizeof(dtv_phandle_source2),
Simon Glass36b15e22020-10-03 11:31:35 -06001138\t.parent_idx\t= -1,
Walter Lozano5541fc02020-06-25 01:10:17 -03001139};
1140
Simon Glass16382ce2020-12-28 20:35:04 -07001141/* Node /phandle-target index 4 */
1142static struct dtd_target dtv_phandle_target = {
1143\t.intval\t\t\t= 0x0,
1144};
1145U_BOOT_DRVINFO(phandle_target) = {
1146\t.name\t\t= "target",
Simon Glasse2119082021-02-03 06:01:19 -07001147\t.plat\t\t= &dtv_phandle_target,
Simon Glass16382ce2020-12-28 20:35:04 -07001148\t.plat_size\t= sizeof(dtv_phandle_target),
1149\t.parent_idx\t= -1,
1150};
1151
Walter Lozano5541fc02020-06-25 01:10:17 -03001152''', data)
1153
Simon Glass961c1ce2018-07-06 10:27:35 -06001154 def test_phandle_bad(self):
1155 """Test a node containing an invalid phandle fails"""
Simon Glass04150022018-10-01 21:12:43 -06001156 dtb_file = get_dtb_file('dtoc_test_phandle_bad.dts',
1157 capture_stderr=True)
Simon Glass961c1ce2018-07-06 10:27:35 -06001158 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -07001159 with self.assertRaises(ValueError) as exc:
Walter Lozanoa324e412020-06-25 01:10:08 -03001160 self.run_test(['struct'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -06001161 self.assertIn("Cannot parse 'clocks' in node 'phandle-source'",
Simon Glassa60cabd2020-12-28 20:34:47 -07001162 str(exc.exception))
Simon Glass961c1ce2018-07-06 10:27:35 -06001163
1164 def test_phandle_bad2(self):
1165 """Test a phandle target missing its #*-cells property"""
Simon Glass04150022018-10-01 21:12:43 -06001166 dtb_file = get_dtb_file('dtoc_test_phandle_bad2.dts',
1167 capture_stderr=True)
Simon Glass961c1ce2018-07-06 10:27:35 -06001168 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -07001169 with self.assertRaises(ValueError) as exc:
Walter Lozanoa324e412020-06-25 01:10:08 -03001170 self.run_test(['struct'], dtb_file, output)
Walter Lozano179f0b62020-06-25 01:10:16 -03001171 self.assertIn("Node 'phandle-target' has no cells property",
Simon Glassa60cabd2020-12-28 20:34:47 -07001172 str(exc.exception))
Simon Glass961c1ce2018-07-06 10:27:35 -06001173
Simon Glass1b1fe412017-08-29 14:15:50 -06001174 def test_addresses64(self):
1175 """Test output from a node with a 'reg' property with na=2, ns=2"""
1176 dtb_file = get_dtb_file('dtoc_test_addr64.dts')
1177 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -03001178 self.run_test(['struct'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -06001179 with open(output) as infile:
1180 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -07001181 self._check_strings(HEADER + '''
Simon Glass1b1fe412017-08-29 14:15:50 -06001182struct dtd_test1 {
1183\tfdt64_t\t\treg[2];
1184};
1185struct dtd_test2 {
1186\tfdt64_t\t\treg[2];
1187};
1188struct dtd_test3 {
1189\tfdt64_t\t\treg[4];
1190};
1191''', data)
1192
Walter Lozanoa324e412020-06-25 01:10:08 -03001193 self.run_test(['platdata'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -06001194 with open(output) as infile:
1195 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -07001196 self._check_strings(C_HEADER + '''
Simon Glasse2119082021-02-03 06:01:19 -07001197/*
1198 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
1199 *
1200 * idx driver_info driver
1201 * --- -------------------- --------------------
1202 * 0: test1 test1
1203 * 1: test2 test2
1204 * 2: test3 test3
1205 * --- -------------------- --------------------
1206 */
1207
Simon Glass192f8132020-10-03 11:31:25 -06001208/* Node /test1 index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -03001209static struct dtd_test1 dtv_test1 = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001210\t.reg\t\t\t= {0x1234, 0x5678},
1211};
Simon Glass1d8364a2020-12-28 20:34:54 -07001212U_BOOT_DRVINFO(test1) = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001213\t.name\t\t= "test1",
Simon Glasse2119082021-02-03 06:01:19 -07001214\t.plat\t\t= &dtv_test1,
Simon Glass39edb952020-12-03 16:55:19 -07001215\t.plat_size\t= sizeof(dtv_test1),
Simon Glass36b15e22020-10-03 11:31:35 -06001216\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -06001217};
1218
Simon Glass192f8132020-10-03 11:31:25 -06001219/* Node /test2 index 1 */
Walter Lozanodc5b4372020-06-25 01:10:13 -03001220static struct dtd_test2 dtv_test2 = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001221\t.reg\t\t\t= {0x1234567890123456, 0x9876543210987654},
1222};
Simon Glass1d8364a2020-12-28 20:34:54 -07001223U_BOOT_DRVINFO(test2) = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001224\t.name\t\t= "test2",
Simon Glasse2119082021-02-03 06:01:19 -07001225\t.plat\t\t= &dtv_test2,
Simon Glass39edb952020-12-03 16:55:19 -07001226\t.plat_size\t= sizeof(dtv_test2),
Simon Glass36b15e22020-10-03 11:31:35 -06001227\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -06001228};
1229
Simon Glass192f8132020-10-03 11:31:25 -06001230/* Node /test3 index 2 */
Walter Lozanodc5b4372020-06-25 01:10:13 -03001231static struct dtd_test3 dtv_test3 = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001232\t.reg\t\t\t= {0x1234567890123456, 0x9876543210987654, 0x2, 0x3},
1233};
Simon Glass1d8364a2020-12-28 20:34:54 -07001234U_BOOT_DRVINFO(test3) = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001235\t.name\t\t= "test3",
Simon Glasse2119082021-02-03 06:01:19 -07001236\t.plat\t\t= &dtv_test3,
Simon Glass39edb952020-12-03 16:55:19 -07001237\t.plat_size\t= sizeof(dtv_test3),
Simon Glass36b15e22020-10-03 11:31:35 -06001238\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -06001239};
1240
Simon Glass2500de22020-12-28 20:35:05 -07001241''', data)
Simon Glass1b1fe412017-08-29 14:15:50 -06001242
1243 def test_addresses32(self):
1244 """Test output from a node with a 'reg' property with na=1, ns=1"""
1245 dtb_file = get_dtb_file('dtoc_test_addr32.dts')
1246 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -03001247 self.run_test(['struct'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -06001248 with open(output) as infile:
1249 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -07001250 self._check_strings(HEADER + '''
Simon Glass1b1fe412017-08-29 14:15:50 -06001251struct dtd_test1 {
1252\tfdt32_t\t\treg[2];
1253};
1254struct dtd_test2 {
1255\tfdt32_t\t\treg[4];
1256};
1257''', data)
1258
Walter Lozanoa324e412020-06-25 01:10:08 -03001259 self.run_test(['platdata'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -06001260 with open(output) as infile:
1261 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -07001262 self._check_strings(C_HEADER + '''
Simon Glasse2119082021-02-03 06:01:19 -07001263/*
1264 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
1265 *
1266 * idx driver_info driver
1267 * --- -------------------- --------------------
1268 * 0: test1 test1
1269 * 1: test2 test2
1270 * --- -------------------- --------------------
1271 */
1272
Simon Glass192f8132020-10-03 11:31:25 -06001273/* Node /test1 index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -03001274static struct dtd_test1 dtv_test1 = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001275\t.reg\t\t\t= {0x1234, 0x5678},
1276};
Simon Glass1d8364a2020-12-28 20:34:54 -07001277U_BOOT_DRVINFO(test1) = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001278\t.name\t\t= "test1",
Simon Glasse2119082021-02-03 06:01:19 -07001279\t.plat\t\t= &dtv_test1,
Simon Glass39edb952020-12-03 16:55:19 -07001280\t.plat_size\t= sizeof(dtv_test1),
Simon Glass36b15e22020-10-03 11:31:35 -06001281\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -06001282};
1283
Simon Glass192f8132020-10-03 11:31:25 -06001284/* Node /test2 index 1 */
Walter Lozanodc5b4372020-06-25 01:10:13 -03001285static struct dtd_test2 dtv_test2 = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001286\t.reg\t\t\t= {0x12345678, 0x98765432, 0x2, 0x3},
1287};
Simon Glass1d8364a2020-12-28 20:34:54 -07001288U_BOOT_DRVINFO(test2) = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001289\t.name\t\t= "test2",
Simon Glasse2119082021-02-03 06:01:19 -07001290\t.plat\t\t= &dtv_test2,
Simon Glass39edb952020-12-03 16:55:19 -07001291\t.plat_size\t= sizeof(dtv_test2),
Simon Glass36b15e22020-10-03 11:31:35 -06001292\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -06001293};
1294
Simon Glass2500de22020-12-28 20:35:05 -07001295''', data)
Simon Glass1b1fe412017-08-29 14:15:50 -06001296
1297 def test_addresses64_32(self):
1298 """Test output from a node with a 'reg' property with na=2, ns=1"""
1299 dtb_file = get_dtb_file('dtoc_test_addr64_32.dts')
1300 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -03001301 self.run_test(['struct'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -06001302 with open(output) as infile:
1303 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -07001304 self._check_strings(HEADER + '''
Simon Glass1b1fe412017-08-29 14:15:50 -06001305struct dtd_test1 {
1306\tfdt64_t\t\treg[2];
1307};
1308struct dtd_test2 {
1309\tfdt64_t\t\treg[2];
1310};
1311struct dtd_test3 {
1312\tfdt64_t\t\treg[4];
1313};
1314''', data)
1315
Walter Lozanoa324e412020-06-25 01:10:08 -03001316 self.run_test(['platdata'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -06001317 with open(output) as infile:
1318 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -07001319 self._check_strings(C_HEADER + '''
Simon Glasse2119082021-02-03 06:01:19 -07001320/*
1321 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
1322 *
1323 * idx driver_info driver
1324 * --- -------------------- --------------------
1325 * 0: test1 test1
1326 * 1: test2 test2
1327 * 2: test3 test3
1328 * --- -------------------- --------------------
1329 */
1330
Simon Glass192f8132020-10-03 11:31:25 -06001331/* Node /test1 index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -03001332static struct dtd_test1 dtv_test1 = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001333\t.reg\t\t\t= {0x123400000000, 0x5678},
1334};
Simon Glass1d8364a2020-12-28 20:34:54 -07001335U_BOOT_DRVINFO(test1) = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001336\t.name\t\t= "test1",
Simon Glasse2119082021-02-03 06:01:19 -07001337\t.plat\t\t= &dtv_test1,
Simon Glass39edb952020-12-03 16:55:19 -07001338\t.plat_size\t= sizeof(dtv_test1),
Simon Glass36b15e22020-10-03 11:31:35 -06001339\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -06001340};
1341
Simon Glass192f8132020-10-03 11:31:25 -06001342/* Node /test2 index 1 */
Walter Lozanodc5b4372020-06-25 01:10:13 -03001343static struct dtd_test2 dtv_test2 = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001344\t.reg\t\t\t= {0x1234567890123456, 0x98765432},
1345};
Simon Glass1d8364a2020-12-28 20:34:54 -07001346U_BOOT_DRVINFO(test2) = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001347\t.name\t\t= "test2",
Simon Glasse2119082021-02-03 06:01:19 -07001348\t.plat\t\t= &dtv_test2,
Simon Glass39edb952020-12-03 16:55:19 -07001349\t.plat_size\t= sizeof(dtv_test2),
Simon Glass36b15e22020-10-03 11:31:35 -06001350\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -06001351};
1352
Simon Glass192f8132020-10-03 11:31:25 -06001353/* Node /test3 index 2 */
Walter Lozanodc5b4372020-06-25 01:10:13 -03001354static struct dtd_test3 dtv_test3 = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001355\t.reg\t\t\t= {0x1234567890123456, 0x98765432, 0x2, 0x3},
1356};
Simon Glass1d8364a2020-12-28 20:34:54 -07001357U_BOOT_DRVINFO(test3) = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001358\t.name\t\t= "test3",
Simon Glasse2119082021-02-03 06:01:19 -07001359\t.plat\t\t= &dtv_test3,
Simon Glass39edb952020-12-03 16:55:19 -07001360\t.plat_size\t= sizeof(dtv_test3),
Simon Glass36b15e22020-10-03 11:31:35 -06001361\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -06001362};
1363
Simon Glass2500de22020-12-28 20:35:05 -07001364''', data)
Simon Glass1b1fe412017-08-29 14:15:50 -06001365
1366 def test_addresses32_64(self):
1367 """Test output from a node with a 'reg' property with na=1, ns=2"""
1368 dtb_file = get_dtb_file('dtoc_test_addr32_64.dts')
1369 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -03001370 self.run_test(['struct'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -06001371 with open(output) as infile:
1372 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -07001373 self._check_strings(HEADER + '''
Simon Glass1b1fe412017-08-29 14:15:50 -06001374struct dtd_test1 {
1375\tfdt64_t\t\treg[2];
1376};
1377struct dtd_test2 {
1378\tfdt64_t\t\treg[2];
1379};
1380struct dtd_test3 {
1381\tfdt64_t\t\treg[4];
1382};
1383''', data)
1384
Walter Lozanoa324e412020-06-25 01:10:08 -03001385 self.run_test(['platdata'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -06001386 with open(output) as infile:
1387 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -07001388 self._check_strings(C_HEADER + '''
Simon Glasse2119082021-02-03 06:01:19 -07001389/*
1390 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
1391 *
1392 * idx driver_info driver
1393 * --- -------------------- --------------------
1394 * 0: test1 test1
1395 * 1: test2 test2
1396 * 2: test3 test3
1397 * --- -------------------- --------------------
1398 */
1399
Simon Glass192f8132020-10-03 11:31:25 -06001400/* Node /test1 index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -03001401static struct dtd_test1 dtv_test1 = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001402\t.reg\t\t\t= {0x1234, 0x567800000000},
1403};
Simon Glass1d8364a2020-12-28 20:34:54 -07001404U_BOOT_DRVINFO(test1) = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001405\t.name\t\t= "test1",
Simon Glasse2119082021-02-03 06:01:19 -07001406\t.plat\t\t= &dtv_test1,
Simon Glass39edb952020-12-03 16:55:19 -07001407\t.plat_size\t= sizeof(dtv_test1),
Simon Glass36b15e22020-10-03 11:31:35 -06001408\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -06001409};
1410
Simon Glass192f8132020-10-03 11:31:25 -06001411/* Node /test2 index 1 */
Walter Lozanodc5b4372020-06-25 01:10:13 -03001412static struct dtd_test2 dtv_test2 = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001413\t.reg\t\t\t= {0x12345678, 0x9876543210987654},
1414};
Simon Glass1d8364a2020-12-28 20:34:54 -07001415U_BOOT_DRVINFO(test2) = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001416\t.name\t\t= "test2",
Simon Glasse2119082021-02-03 06:01:19 -07001417\t.plat\t\t= &dtv_test2,
Simon Glass39edb952020-12-03 16:55:19 -07001418\t.plat_size\t= sizeof(dtv_test2),
Simon Glass36b15e22020-10-03 11:31:35 -06001419\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -06001420};
1421
Simon Glass192f8132020-10-03 11:31:25 -06001422/* Node /test3 index 2 */
Walter Lozanodc5b4372020-06-25 01:10:13 -03001423static struct dtd_test3 dtv_test3 = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001424\t.reg\t\t\t= {0x12345678, 0x9876543210987654, 0x2, 0x3},
1425};
Simon Glass1d8364a2020-12-28 20:34:54 -07001426U_BOOT_DRVINFO(test3) = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001427\t.name\t\t= "test3",
Simon Glasse2119082021-02-03 06:01:19 -07001428\t.plat\t\t= &dtv_test3,
Simon Glass39edb952020-12-03 16:55:19 -07001429\t.plat_size\t= sizeof(dtv_test3),
Simon Glass36b15e22020-10-03 11:31:35 -06001430\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -06001431};
1432
Simon Glass2500de22020-12-28 20:35:05 -07001433''', data)
Simon Glass961c1ce2018-07-06 10:27:35 -06001434
1435 def test_bad_reg(self):
1436 """Test that a reg property with an invalid type generates an error"""
Simon Glass3bce93d2018-07-06 10:27:37 -06001437 # Capture stderr since dtc will emit warnings for this file
1438 dtb_file = get_dtb_file('dtoc_test_bad_reg.dts', capture_stderr=True)
Simon Glass961c1ce2018-07-06 10:27:35 -06001439 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -07001440 with self.assertRaises(ValueError) as exc:
Walter Lozanoa324e412020-06-25 01:10:08 -03001441 self.run_test(['struct'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -06001442 self.assertIn("Node 'spl-test' reg property is not an int",
Simon Glassa60cabd2020-12-28 20:34:47 -07001443 str(exc.exception))
Simon Glass961c1ce2018-07-06 10:27:35 -06001444
1445 def test_bad_reg2(self):
1446 """Test that a reg property with an invalid cell count is detected"""
Simon Glass3bce93d2018-07-06 10:27:37 -06001447 # Capture stderr since dtc will emit warnings for this file
1448 dtb_file = get_dtb_file('dtoc_test_bad_reg2.dts', capture_stderr=True)
Simon Glass961c1ce2018-07-06 10:27:35 -06001449 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -07001450 with self.assertRaises(ValueError) as exc:
Walter Lozanoa324e412020-06-25 01:10:08 -03001451 self.run_test(['struct'], dtb_file, output)
Simon Glassa60cabd2020-12-28 20:34:47 -07001452 self.assertIn(
Simon Glass4415dc12021-03-26 16:17:27 +13001453 "Node 'spl-test' (parent '/') reg property has 3 cells which is not a multiple of na + ns = 1 + 1)",
Simon Glassa60cabd2020-12-28 20:34:47 -07001454 str(exc.exception))
Simon Glass961c1ce2018-07-06 10:27:35 -06001455
1456 def test_add_prop(self):
1457 """Test that a subequent node can add a new property to a struct"""
1458 dtb_file = get_dtb_file('dtoc_test_add_prop.dts')
1459 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -03001460 self.run_test(['struct'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -06001461 with open(output) as infile:
1462 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -07001463 self._check_strings(HEADER + '''
Simon Glass961c1ce2018-07-06 10:27:35 -06001464struct dtd_sandbox_spl_test {
1465\tfdt32_t\t\tintarray;
1466\tfdt32_t\t\tintval;
1467};
1468''', data)
1469
Walter Lozanoa324e412020-06-25 01:10:08 -03001470 self.run_test(['platdata'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -06001471 with open(output) as infile:
1472 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -07001473 self._check_strings(C_HEADER + '''
Simon Glassbe749002021-02-03 06:01:15 -07001474/*
Simon Glasse2119082021-02-03 06:01:19 -07001475 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
1476 *
1477 * idx driver_info driver
1478 * --- -------------------- --------------------
1479 * 0: spl_test sandbox_spl_test
1480 * 1: spl_test2 sandbox_spl_test
1481 * --- -------------------- --------------------
1482 */
1483
1484/*
Simon Glassbe749002021-02-03 06:01:15 -07001485 * Node /spl-test index 0
1486 * driver sandbox_spl_test parent None
1487 */
Walter Lozanodc5b4372020-06-25 01:10:13 -03001488static struct dtd_sandbox_spl_test dtv_spl_test = {
Simon Glass961c1ce2018-07-06 10:27:35 -06001489\t.intval\t\t\t= 0x1,
1490};
Simon Glass1d8364a2020-12-28 20:34:54 -07001491U_BOOT_DRVINFO(spl_test) = {
Simon Glass961c1ce2018-07-06 10:27:35 -06001492\t.name\t\t= "sandbox_spl_test",
Simon Glasse2119082021-02-03 06:01:19 -07001493\t.plat\t\t= &dtv_spl_test,
Simon Glass39edb952020-12-03 16:55:19 -07001494\t.plat_size\t= sizeof(dtv_spl_test),
Simon Glass36b15e22020-10-03 11:31:35 -06001495\t.parent_idx\t= -1,
Simon Glass961c1ce2018-07-06 10:27:35 -06001496};
1497
Simon Glassbe749002021-02-03 06:01:15 -07001498/*
1499 * Node /spl-test2 index 1
1500 * driver sandbox_spl_test parent None
1501 */
Walter Lozanodc5b4372020-06-25 01:10:13 -03001502static struct dtd_sandbox_spl_test dtv_spl_test2 = {
Simon Glass961c1ce2018-07-06 10:27:35 -06001503\t.intarray\t\t= 0x5,
1504};
Simon Glass1d8364a2020-12-28 20:34:54 -07001505U_BOOT_DRVINFO(spl_test2) = {
Simon Glass961c1ce2018-07-06 10:27:35 -06001506\t.name\t\t= "sandbox_spl_test",
Simon Glasse2119082021-02-03 06:01:19 -07001507\t.plat\t\t= &dtv_spl_test2,
Simon Glass39edb952020-12-03 16:55:19 -07001508\t.plat_size\t= sizeof(dtv_spl_test2),
Simon Glass36b15e22020-10-03 11:31:35 -06001509\t.parent_idx\t= -1,
Simon Glass961c1ce2018-07-06 10:27:35 -06001510};
1511
Simon Glass2500de22020-12-28 20:35:05 -07001512''', data)
Simon Glass961c1ce2018-07-06 10:27:35 -06001513
Simon Glassa60cabd2020-12-28 20:34:47 -07001514 def test_stdout(self):
Simon Glass961c1ce2018-07-06 10:27:35 -06001515 """Test output to stdout"""
1516 dtb_file = get_dtb_file('dtoc_test_simple.dts')
Simon Glass07ee48e2020-12-28 20:34:49 -07001517 with test_util.capture_sys_output() as (stdout, _):
Simon Glass6ca0c7a2020-12-28 20:34:48 -07001518 self.run_test(['struct'], dtb_file, None)
Simon Glass07ee48e2020-12-28 20:34:49 -07001519 self._check_strings(self.struct_text, stdout.getvalue())
Simon Glass961c1ce2018-07-06 10:27:35 -06001520
Simon Glassc3a310a82020-12-28 20:34:51 -07001521 def test_multi_to_file(self):
1522 """Test output of multiple pieces to a single file"""
1523 dtb_file = get_dtb_file('dtoc_test_simple.dts')
1524 output = tools.GetOutputFilename('output')
Simon Glass4e8e8462020-12-28 20:34:52 -07001525 self.run_test(['all'], dtb_file, output)
Simon Glassc3a310a82020-12-28 20:34:51 -07001526 data = tools.ReadFile(output, binary=False)
Simon Glassfea2f252021-02-03 06:01:21 -07001527 self._check_strings(
Simon Glass705b84b2021-04-27 08:19:48 +12001528 self.decl_text + self.platdata_text + self.struct_text, data)
Simon Glassc3a310a82020-12-28 20:34:51 -07001529
Simon Glassa60cabd2020-12-28 20:34:47 -07001530 def test_no_command(self):
Simon Glass961c1ce2018-07-06 10:27:35 -06001531 """Test running dtoc without a command"""
Simon Glassa60cabd2020-12-28 20:34:47 -07001532 with self.assertRaises(ValueError) as exc:
Walter Lozanoa324e412020-06-25 01:10:08 -03001533 self.run_test([], '', '')
Simon Glass961c1ce2018-07-06 10:27:35 -06001534 self.assertIn("Please specify a command: struct, platdata",
Simon Glassa60cabd2020-12-28 20:34:47 -07001535 str(exc.exception))
Simon Glass961c1ce2018-07-06 10:27:35 -06001536
Simon Glassa60cabd2020-12-28 20:34:47 -07001537 def test_bad_command(self):
Simon Glass961c1ce2018-07-06 10:27:35 -06001538 """Test running dtoc with an invalid command"""
1539 dtb_file = get_dtb_file('dtoc_test_simple.dts')
1540 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -07001541 with self.assertRaises(ValueError) as exc:
Simon Glass3fa3bbb2021-02-03 06:01:14 -07001542 self.run_test(['invalid-cmd'], dtb_file, output)
1543 self.assertIn(
Simon Glassdb2b9ca2021-03-25 06:40:51 +13001544 "Unknown command 'invalid-cmd': (use: decl, platdata, struct)",
Simon Glass3fa3bbb2021-02-03 06:01:14 -07001545 str(exc.exception))
Walter Lozanod82062b2020-07-28 19:06:23 -03001546
Simon Glass4e8e8462020-12-28 20:34:52 -07001547 def test_output_conflict(self):
1548 """Test a conflict between and output dirs and output file"""
1549 with self.assertRaises(ValueError) as exc:
Simon Glass3809ad92021-02-03 06:01:12 -07001550 dtb_platdata.run_steps(
1551 ['all'], None, False, 'out', ['cdir'], None, False,
1552 warning_disabled=True, scan=copy_scan())
Simon Glass4e8e8462020-12-28 20:34:52 -07001553 self.assertIn("Must specify either output or output_dirs, not both",
1554 str(exc.exception))
1555
Simon Glass705b84b2021-04-27 08:19:48 +12001556 def check_output_dirs(self, instantiate):
Simon Glass4e8e8462020-12-28 20:34:52 -07001557 # Remove the directory so that files from other tests are not there
1558 tools._RemoveOutputDir()
1559 tools.PrepareOutputDir(None)
1560
1561 # This should create the .dts and .dtb in the output directory
1562 dtb_file = get_dtb_file('dtoc_test_simple.dts')
1563 outdir = tools.GetOutputDir()
1564 fnames = glob.glob(outdir + '/*')
1565 self.assertEqual(2, len(fnames))
1566
Simon Glass3809ad92021-02-03 06:01:12 -07001567 dtb_platdata.run_steps(
Simon Glass705b84b2021-04-27 08:19:48 +12001568 ['all'], dtb_file, False, None, [outdir], None, instantiate,
Simon Glass3809ad92021-02-03 06:01:12 -07001569 warning_disabled=True, scan=copy_scan())
Simon Glass4e8e8462020-12-28 20:34:52 -07001570 fnames = glob.glob(outdir + '/*')
Simon Glass705b84b2021-04-27 08:19:48 +12001571 return fnames
1572
1573 def test_output_dirs(self):
1574 """Test outputting files to a directory"""
1575 fnames = self.check_output_dirs(False)
1576 self.assertEqual(5, len(fnames))
Simon Glass4e8e8462020-12-28 20:34:52 -07001577
1578 leafs = set(os.path.basename(fname) for fname in fnames)
1579 self.assertEqual(
Simon Glass3fa3bbb2021-02-03 06:01:14 -07001580 {'dt-structs-gen.h', 'source.dts', 'dt-plat.c', 'source.dtb',
Simon Glass705b84b2021-04-27 08:19:48 +12001581 'dt-decl.h'},
1582 leafs)
1583
1584 def test_output_dirs_inst(self):
1585 """Test outputting files to a directory with instantiation"""
1586 fnames = self.check_output_dirs(True)
1587 self.assertEqual(6, len(fnames))
1588
1589 leafs = set(os.path.basename(fname) for fname in fnames)
1590 self.assertEqual(
1591 {'dt-structs-gen.h', 'source.dts', 'source.dtb',
Simon Glassfea2f252021-02-03 06:01:21 -07001592 'dt-uclass.c', 'dt-decl.h', 'dt-device.c'},
Simon Glass4e8e8462020-12-28 20:34:52 -07001593 leafs)
Simon Glass047a4802021-02-03 06:01:00 -07001594
1595 def setup_process_test(self):
1596 """Set up a test of process_nodes()
1597
1598 This uses saved_scan but returns a deep copy of it, so it is safe to
1599 modify it in these tests
1600
1601 Returns:
1602 tuple:
1603 DtbPlatdata: object to test
1604 Scanner: scanner to use
1605 """
1606 dtb_file = get_dtb_file('dtoc_test_simple.dts')
1607 output = tools.GetOutputFilename('output')
1608
1609 # Take a copy before messing with it
Simon Glassc14fd0c2021-02-03 06:01:11 -07001610 scan = copy_scan()
Simon Glass047a4802021-02-03 06:01:00 -07001611 plat = dtb_platdata.DtbPlatdata(scan, dtb_file, False)
1612 plat.scan_dtb()
Simon Glassc14fd0c2021-02-03 06:01:11 -07001613 plat.scan_tree(False)
Simon Glass047a4802021-02-03 06:01:00 -07001614 plat.prepare_nodes()
1615 return plat, scan
1616
1617 def test_process_nodes(self):
1618 """Test processing nodes to add various info"""
1619 plat, scan = self.setup_process_test()
1620 plat.process_nodes(True)
1621
1622 i2c_node = plat._fdt.GetNode('/i2c@0')
1623 pmic_node = plat._fdt.GetNode('/i2c@0/pmic@9')
1624 pmic = scan._drivers['sandbox_pmic']
1625 i2c = scan._drivers['sandbox_i2c']
1626 self.assertEqual('DM_DEVICE_REF(pmic_at_9)', pmic_node.dev_ref)
1627 self.assertEqual(pmic, pmic_node.driver)
1628 self.assertEqual(i2c_node, pmic_node.parent)
1629 self.assertEqual(i2c, pmic_node.parent_driver)
1630
1631 # The pmic is the only child
1632 self.assertEqual(pmic_node.parent_seq, 0)
1633 self.assertEqual([pmic_node], i2c_node.child_devs)
1634
1635 # Start and end of the list should be the child_head
1636 ref = '&DM_DEVICE_REF(i2c_at_0)->child_head'
1637 self.assertEqual(
1638 {-1: ref, 0: '&DM_DEVICE_REF(pmic_at_9)->sibling_node', 1: ref},
1639 i2c_node.child_refs)
1640
1641 def test_process_nodes_bad_parent(self):
1642 # Pretend that i2c has a parent (the pmic) and delete that driver
1643 plat, scan = self.setup_process_test()
1644
1645 i2c_node = plat._fdt.GetNode('/i2c@0')
1646 pmic_node = plat._fdt.GetNode('/i2c@0/pmic@9')
1647 del scan._drivers['sandbox_pmic']
1648 i2c_node.parent = pmic_node
1649
1650 # Process twice, the second time to generate an exception
1651 plat.process_nodes(False)
1652 with self.assertRaises(ValueError) as exc:
1653 plat.process_nodes(True)
1654 self.assertIn(
1655 "Cannot parse/find parent driver 'sandbox_pmic' for 'sandbox_i2c",
1656 str(exc.exception))
1657
1658 def test_process_nodes_bad_node(self):
1659 plat, scan = self.setup_process_test()
1660
1661 # Now remove the pmic driver
1662 del scan._drivers['sandbox_pmic']
1663
1664 # Process twice, the second time to generate an exception
1665 plat.process_nodes(False)
1666 with self.assertRaises(ValueError) as exc:
1667 plat.process_nodes(True)
1668 self.assertIn("Cannot parse/find driver for 'sandbox_pmic",
1669 str(exc.exception))
Simon Glasseb3c2492021-02-03 06:01:01 -07001670
Simon Glass80d782c42021-02-03 06:01:10 -07001671 def test_process_nodes_bad_uclass(self):
1672 plat, scan = self.setup_process_test()
1673
1674 self.assertIn('UCLASS_I2C', scan._uclass)
1675 del scan._uclass['UCLASS_I2C']
1676 with self.assertRaises(ValueError) as exc:
1677 plat.process_nodes(True)
1678 self.assertIn("Cannot parse/find uclass 'UCLASS_I2C' for driver 'sandbox_i2c'",
1679 str(exc.exception))
1680
Simon Glasseb3c2492021-02-03 06:01:01 -07001681 def test_process_nodes_used(self):
1682 """Test processing nodes to add various info"""
1683 plat, scan = self.setup_process_test()
1684 plat.process_nodes(True)
1685
1686 pmic = scan._drivers['sandbox_pmic']
1687 self.assertTrue(pmic.used)
1688
1689 gpio = scan._drivers['sandbox_gpio']
1690 self.assertFalse(gpio.used)
Simon Glassbe88d2f2021-02-03 06:01:07 -07001691
1692 def test_alias_read(self):
1693 """Test obtaining aliases"""
1694 dtb_file = get_dtb_file('dtoc_test_inst.dts')
1695 output = tools.GetOutputFilename('output')
1696 plat = self.run_test(['struct'], dtb_file, output)
1697
1698 scan = plat._scan
1699 testfdt_node = plat._fdt.GetNode('/some-bus/test')
Simon Glass80d782c42021-02-03 06:01:10 -07001700 test0_node = plat._fdt.GetNode('/some-bus/test0')
Simon Glassbe88d2f2021-02-03 06:01:07 -07001701 self.assertIn('UCLASS_TEST_FDT', scan._uclass)
1702 uc = scan._uclass['UCLASS_TEST_FDT']
Simon Glass80d782c42021-02-03 06:01:10 -07001703 self.assertEqual({1: testfdt_node, 2: test0_node},
1704 uc.alias_num_to_node)
1705 self.assertEqual({'/some-bus/test': 1, '/some-bus/test0': 2},
1706 uc.alias_path_to_num)
Simon Glassbe88d2f2021-02-03 06:01:07 -07001707
1708 # Try adding an alias that doesn't exist
1709 self.assertFalse(scan.add_uclass_alias('fred', 3, None))
1710
1711 # Try adding an alias for a missing node
1712 self.assertIsNone(scan.add_uclass_alias('testfdt', 3, None))
1713
1714 def test_alias_read_bad(self):
1715 """Test invalid alias property name"""
1716 dtb_file = get_dtb_file('dtoc_test_alias_bad.dts')
1717 output = tools.GetOutputFilename('output')
1718 with self.assertRaises(ValueError) as exc:
1719 plat = self.run_test(['struct'], dtb_file, output)
1720 self.assertIn("Cannot decode alias 'i2c4-'", str(exc.exception))
1721
1722 def test_alias_read_bad_path(self):
1723 """Test alias pointing to a non-existent node"""
1724 # This line may produce a warning, so capture it:
1725 # Warning (alias_paths): /aliases:i2c4: aliases property is not a valid
1726 # node (/does/not/exist)
1727 dtb_file = get_dtb_file('dtoc_test_alias_bad_path.dts', True)
1728
1729 output = tools.GetOutputFilename('output')
1730 with self.assertRaises(ValueError) as exc:
1731 plat = self.run_test(['struct'], dtb_file, output)
1732 self.assertIn("Alias 'i2c4' path '/does/not/exist' not found",
1733 str(exc.exception))
1734
1735 def test_alias_read_bad_uclass(self):
1736 """Test alias for a uclass that doesn't exist"""
1737 dtb_file = get_dtb_file('dtoc_test_alias_bad_uc.dts')
1738 output = tools.GetOutputFilename('output')
1739 with test_util.capture_sys_output() as (stdout, _):
1740 plat = self.run_test(['struct'], dtb_file, output)
1741 self.assertEqual("Could not find uclass for alias 'other1'",
1742 stdout.getvalue().strip())
Simon Glassdf56e0b2021-02-03 06:01:09 -07001743
1744 def test_sequence(self):
1745 """Test assignment of sequence numnbers"""
1746 dtb_file = get_dtb_file('dtoc_test_inst.dts')
1747 output = tools.GetOutputFilename('output')
1748 plat = self.run_test(['struct'], dtb_file, output)
Simon Glass80d782c42021-02-03 06:01:10 -07001749
1750 scan = plat._scan
1751 testfdt = plat._fdt.GetNode('/some-bus/test')
1752 self.assertEqual(1, testfdt.seq)
1753 i2c = plat._fdt.GetNode('/i2c')
1754
1755 # For now this uclass is not compiled in, so no sequence is assigned
1756 self.assertEqual(4, i2c.seq)
1757 spl = plat._fdt.GetNode('/spl-test')
1758 self.assertEqual(0, spl.seq)
Simon Glassc14fd0c2021-02-03 06:01:11 -07001759
1760 def test_process_root(self):
1761 """Test assignment of sequence numnbers"""
1762 dtb_file = get_dtb_file('dtoc_test_simple.dts')
1763 output = tools.GetOutputFilename('output')
1764
1765 # Take a copy before messing with it
1766 scan = copy_scan()
1767 plat = dtb_platdata.DtbPlatdata(scan, dtb_file, False)
1768 plat.scan_dtb()
1769 root = plat._fdt.GetRoot()
1770
1771 plat.scan_tree(False)
1772 self.assertNotIn(root, plat._valid_nodes)
1773
1774 plat.scan_tree(True)
1775 self.assertIn(root, plat._valid_nodes)
1776 self.assertEqual('root_driver',
1777 scan.get_normalized_compat_name(root)[0])
Simon Glass3fa3bbb2021-02-03 06:01:14 -07001778
1779 def test_simple_inst(self):
1780 """Test output from some simple nodes with instantiate enabled"""
Simon Glassc7b4b832021-02-03 06:01:20 -07001781 dtb_file = get_dtb_file('dtoc_test_inst.dts')
Simon Glass3fa3bbb2021-02-03 06:01:14 -07001782 output = tools.GetOutputFilename('output')
1783
1784 self.run_test(['decl'], dtb_file, output, True)
1785 with open(output) as infile:
1786 data = infile.read()
1787
1788 self._check_strings(self.decl_text_inst, data)
Simon Glassbe749002021-02-03 06:01:15 -07001789
Simon Glassc7b4b832021-02-03 06:01:20 -07001790 self.run_test(['uclass'], dtb_file, output, True)
1791 with open(output) as infile:
1792 data = infile.read()
1793
1794 self._check_strings(UCLASS_HEADER_COMMON + self.uclass_text_inst, data)
1795
Simon Glassfea2f252021-02-03 06:01:21 -07001796 self.run_test(['device'], dtb_file, output, True)
1797 with open(output) as infile:
1798 data = infile.read()
1799
1800 self._check_strings(self.device_text_inst, data)
1801
Simon Glassc7b4b832021-02-03 06:01:20 -07001802 def test_inst_no_hdr(self):
Simon Glassfea2f252021-02-03 06:01:21 -07001803 """Test dealing with a struct tsssshat has no header"""
Simon Glassc7b4b832021-02-03 06:01:20 -07001804 dtb_file = get_dtb_file('dtoc_test_inst.dts')
1805 output = tools.GetOutputFilename('output')
1806
1807 # Run it once to set everything up
1808 plat = self.run_test(['decl'], dtb_file, output, True)
1809 scan = plat._scan
1810
1811 # Restart the output file and delete any record of the uclass' struct
1812 plat.setup_output(Ftype.SOURCE, output)
1813 del scan._structs['dm_test_uc_priv']
1814
1815 # Now generate the uclasses, which should provide a warning
1816 with test_util.capture_sys_output() as (stdout, _):
1817 plat.generate_uclasses()
1818 self.assertEqual(
1819 'Warning: Cannot find header file for struct dm_test_uc_priv',
1820 stdout.getvalue().strip())
Simon Glass4415dc12021-03-26 16:17:27 +13001821
1822 def test_missing_props(self):
1823 """Test detection of a parent node with no properties"""
1824 dtb_file = get_dtb_file('dtoc_test_noprops.dts', capture_stderr=True)
1825 output = tools.GetOutputFilename('output')
1826 with self.assertRaises(ValueError) as exc:
1827 self.run_test(['struct'], dtb_file, output)
1828 self.assertIn("Parent node '/i2c@0' has no properties - do you need",
1829 str(exc.exception))
1830
1831 def test_single_reg(self):
1832 """Test detection of a parent node with no properties"""
1833 dtb_file = get_dtb_file('dtoc_test_single_reg.dts')
1834 output = tools.GetOutputFilename('output')
1835 self.run_test(['struct'], dtb_file, output)
Simon Glass9ebd5512021-06-27 17:51:10 -06001836
1837 def test_missing_parent(self):
1838 """Test detection of a parent node with no properties"""
1839 dtb_file = get_dtb_file('dtoc_test_noparent.dts', capture_stderr=True)
1840 output = tools.GetOutputFilename('output')
1841 with self.assertRaises(ValueError) as exc:
1842 self.run_test(['device'], dtb_file, output, instantiate=True)
1843 self.assertIn("Node '/i2c@0/spl-test/pmic@9' requires parent node "
1844 "'/i2c@0/spl-test' but it is not in the valid list",
1845 str(exc.exception))