blob: a51a7f301ce9b180cfd54299595e1b096bf8a6c5 [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 Glass9d2eb922017-06-18 22:09:06 -060019from dtb_platdata import get_value
20from dtb_platdata import tab_to
Simon Glassa60cabd2020-12-28 20:34:47 -070021from dtoc import dtb_platdata
Simon Glassa997ea52020-04-17 18:09:04 -060022from dtoc import fdt
23from dtoc import fdt_util
Simon Glass768ff0a2021-02-03 06:00:51 -070024from dtoc import src_scan
Simon Glass9065bc92020-12-28 20:35:06 -070025from dtoc.src_scan import conv_name_to_c
26from dtoc.src_scan import get_compat_name
Simon Glassa997ea52020-04-17 18:09:04 -060027from patman import test_util
28from patman import tools
Simon Glass9d2eb922017-06-18 22:09:06 -060029
Simon Glassa60cabd2020-12-28 20:34:47 -070030OUR_PATH = os.path.dirname(os.path.realpath(__file__))
Simon Glass9d2eb922017-06-18 22:09:06 -060031
32
Simon Glasseb37e2d2017-11-12 21:52:17 -070033HEADER = '''/*
34 * DO NOT MODIFY
35 *
Simon Glass6b208842020-12-28 20:35:00 -070036 * Defines the structs used to hold devicetree data.
37 * This was generated by dtoc from a .dtb (device tree binary) file.
Simon Glasseb37e2d2017-11-12 21:52:17 -070038 */
39
40#include <stdbool.h>
Masahiro Yamada75f82d02018-03-05 01:20:11 +090041#include <linux/libfdt.h>'''
Simon Glasseb37e2d2017-11-12 21:52:17 -070042
Simon Glass3fa3bbb2021-02-03 06:01:14 -070043DECL_HEADER = '''/*
44 * DO NOT MODIFY
45 *
46 * Declares externs for all device/uclass instances.
47 * This was generated by dtoc from a .dtb (device tree binary) file.
48 */
49'''
50
Simon Glasseb37e2d2017-11-12 21:52:17 -070051C_HEADER = '''/*
52 * DO NOT MODIFY
53 *
Simon Glass6b208842020-12-28 20:35:00 -070054 * Declares the U_BOOT_DRIVER() records and platform data.
55 * This was generated by dtoc from a .dtb (device tree binary) file.
Simon Glasseb37e2d2017-11-12 21:52:17 -070056 */
57
Simon Glass1d8364a2020-12-28 20:34:54 -070058/* Allow use of U_BOOT_DRVINFO() in this file */
Simon Glassbeddd7a2020-12-28 20:35:01 -070059#define DT_PLAT_C
Simon Glass4c73d7b2020-10-03 11:31:41 -060060
Simon Glasseb37e2d2017-11-12 21:52:17 -070061#include <common.h>
62#include <dm.h>
63#include <dt-structs.h>
64'''
65
Simon Glass768ff0a2021-02-03 06:00:51 -070066# Scanner saved from a previous run of the tests (to speed things up)
67saved_scan = None
68
Simon Glassa60cabd2020-12-28 20:34:47 -070069# This is a test so is allowed to access private things in the module it is
70# testing
71# pylint: disable=W0212
Simon Glass3bce93d2018-07-06 10:27:37 -060072
73def get_dtb_file(dts_fname, capture_stderr=False):
Simon Glass9d2eb922017-06-18 22:09:06 -060074 """Compile a .dts file to a .dtb
75
76 Args:
Simon Glassa60cabd2020-12-28 20:34:47 -070077 dts_fname (str): Filename of .dts file in the current directory
78 capture_stderr (bool): True to capture and discard stderr output
Simon Glass9d2eb922017-06-18 22:09:06 -060079
80 Returns:
Simon Glassa60cabd2020-12-28 20:34:47 -070081 str: Filename of compiled file in output directory
Simon Glass9d2eb922017-06-18 22:09:06 -060082 """
Simon Glass4f4b2402021-02-03 06:00:56 -070083 return fdt_util.EnsureCompiled(os.path.join(OUR_PATH, 'test', dts_fname),
Simon Glass3bce93d2018-07-06 10:27:37 -060084 capture_stderr=capture_stderr)
Simon Glass9d2eb922017-06-18 22:09:06 -060085
Simon Glass768ff0a2021-02-03 06:00:51 -070086
87def setup():
88 global saved_scan
89
90 # Disable warnings so that calls to get_normalized_compat_name() will not
91 # output things.
92 saved_scan = src_scan.Scanner(None, True, False)
93 saved_scan.scan_drivers()
94
95def copy_scan():
96 """Get a copy of saved_scan so that each test can start clean"""
97 return copy.deepcopy(saved_scan)
98
Simon Glass9d2eb922017-06-18 22:09:06 -060099
100class TestDtoc(unittest.TestCase):
101 """Tests for dtoc"""
102 @classmethod
103 def setUpClass(cls):
104 tools.PrepareOutputDir(None)
Simon Glass7f5e2262020-07-07 21:32:06 -0600105 cls.maxDiff = None
Simon Glass9d2eb922017-06-18 22:09:06 -0600106
107 @classmethod
108 def tearDownClass(cls):
Simon Glassa60cabd2020-12-28 20:34:47 -0700109 tools.FinaliseOutputDir()
Simon Glass9d2eb922017-06-18 22:09:06 -0600110
Simon Glassa60cabd2020-12-28 20:34:47 -0700111 @staticmethod
112 def _write_python_string(fname, data):
Simon Glassc47c2b32018-07-06 10:27:25 -0600113 """Write a string with tabs expanded as done in this Python file
114
115 Args:
Simon Glassa60cabd2020-12-28 20:34:47 -0700116 fname (str): Filename to write to
117 data (str): Raw string to convert
Simon Glassc47c2b32018-07-06 10:27:25 -0600118 """
119 data = data.replace('\t', '\\t')
Simon Glassa60cabd2020-12-28 20:34:47 -0700120 with open(fname, 'w') as fout:
121 fout.write(data)
Simon Glassc47c2b32018-07-06 10:27:25 -0600122
Simon Glassa60cabd2020-12-28 20:34:47 -0700123 def _check_strings(self, expected, actual):
Simon Glassc47c2b32018-07-06 10:27:25 -0600124 """Check that a string matches its expected value
125
126 If the strings do not match, they are written to the /tmp directory in
127 the same Python format as is used here in the test. This allows for
128 easy comparison and update of the tests.
129
130 Args:
Simon Glassa60cabd2020-12-28 20:34:47 -0700131 expected (str): Expected string
132 actual (str): Actual string
Simon Glassc47c2b32018-07-06 10:27:25 -0600133 """
134 if expected != actual:
Simon Glassa60cabd2020-12-28 20:34:47 -0700135 self._write_python_string('/tmp/binman.expected', expected)
136 self._write_python_string('/tmp/binman.actual', actual)
Simon Glass61b88e52019-05-17 22:00:31 -0600137 print('Failures written to /tmp/binman.{expected,actual}')
Simon Glassa60cabd2020-12-28 20:34:47 -0700138 self.assertEqual(expected, actual)
Simon Glassc47c2b32018-07-06 10:27:25 -0600139
Simon Glassa60cabd2020-12-28 20:34:47 -0700140 @staticmethod
Simon Glass3809ad92021-02-03 06:01:12 -0700141 def run_test(args, dtb_file, output, instantiate=False):
Simon Glassa60cabd2020-12-28 20:34:47 -0700142 """Run a test using dtoc
Walter Lozanoa324e412020-06-25 01:10:08 -0300143
Simon Glassa60cabd2020-12-28 20:34:47 -0700144 Args:
145 args (list of str): List of arguments for dtoc
146 dtb_file (str): Filename of .dtb file
147 output (str): Filename of output file
Simon Glassbe88d2f2021-02-03 06:01:07 -0700148
149 Returns:
150 DtbPlatdata object
Simon Glassa60cabd2020-12-28 20:34:47 -0700151 """
Simon Glass80d782c42021-02-03 06:01:10 -0700152 # Make a copy of the 'scan' object, since it includes uclasses and
153 # drivers, which get updated during execution.
Simon Glass3809ad92021-02-03 06:01:12 -0700154 return dtb_platdata.run_steps(
155 args, dtb_file, False, output, [], None, instantiate,
156 warning_disabled=True, scan=copy_scan())
Walter Lozanoa324e412020-06-25 01:10:08 -0300157
Simon Glass9d2eb922017-06-18 22:09:06 -0600158 def test_name(self):
159 """Test conversion of device tree names to C identifiers"""
160 self.assertEqual('serial_at_0x12', conv_name_to_c('serial@0x12'))
161 self.assertEqual('vendor_clock_frequency',
162 conv_name_to_c('vendor,clock-frequency'))
163 self.assertEqual('rockchip_rk3399_sdhci_5_1',
164 conv_name_to_c('rockchip,rk3399-sdhci-5.1'))
165
166 def test_tab_to(self):
167 """Test operation of tab_to() function"""
168 self.assertEqual('fred ', tab_to(0, 'fred'))
169 self.assertEqual('fred\t', tab_to(1, 'fred'))
170 self.assertEqual('fred was here ', tab_to(1, 'fred was here'))
171 self.assertEqual('fred was here\t\t', tab_to(3, 'fred was here'))
172 self.assertEqual('exactly8 ', tab_to(1, 'exactly8'))
173 self.assertEqual('exactly8\t', tab_to(2, 'exactly8'))
174
175 def test_get_value(self):
176 """Test operation of get_value() function"""
177 self.assertEqual('0x45',
Simon Glassc9a032c2020-11-08 20:36:17 -0700178 get_value(fdt.Type.INT, struct.pack('>I', 0x45)))
Simon Glass9d2eb922017-06-18 22:09:06 -0600179 self.assertEqual('0x45',
Simon Glassc9a032c2020-11-08 20:36:17 -0700180 get_value(fdt.Type.BYTE, struct.pack('<I', 0x45)))
Simon Glass9d2eb922017-06-18 22:09:06 -0600181 self.assertEqual('0x0',
Simon Glassc9a032c2020-11-08 20:36:17 -0700182 get_value(fdt.Type.BYTE, struct.pack('>I', 0x45)))
183 self.assertEqual('"test"', get_value(fdt.Type.STRING, 'test'))
184 self.assertEqual('true', get_value(fdt.Type.BOOL, None))
Simon Glass9d2eb922017-06-18 22:09:06 -0600185
186 def test_get_compat_name(self):
187 """Test operation of get_compat_name() function"""
188 Prop = collections.namedtuple('Prop', ['value'])
189 Node = collections.namedtuple('Node', ['props'])
190
191 prop = Prop(['rockchip,rk3399-sdhci-5.1', 'arasan,sdhci-5.1'])
192 node = Node({'compatible': prop})
Walter Lozano5fe734c2020-07-23 00:22:03 -0300193 self.assertEqual((['rockchip_rk3399_sdhci_5_1', 'arasan_sdhci_5_1']),
Simon Glass9d2eb922017-06-18 22:09:06 -0600194 get_compat_name(node))
195
196 prop = Prop(['rockchip,rk3399-sdhci-5.1'])
197 node = Node({'compatible': prop})
Walter Lozano5fe734c2020-07-23 00:22:03 -0300198 self.assertEqual((['rockchip_rk3399_sdhci_5_1']),
Simon Glass9d2eb922017-06-18 22:09:06 -0600199 get_compat_name(node))
200
201 prop = Prop(['rockchip,rk3399-sdhci-5.1', 'arasan,sdhci-5.1', 'third'])
202 node = Node({'compatible': prop})
Walter Lozano5fe734c2020-07-23 00:22:03 -0300203 self.assertEqual((['rockchip_rk3399_sdhci_5_1',
Simon Glassa60cabd2020-12-28 20:34:47 -0700204 'arasan_sdhci_5_1', 'third']),
Simon Glass9d2eb922017-06-18 22:09:06 -0600205 get_compat_name(node))
206
207 def test_empty_file(self):
208 """Test output from a device tree file with no nodes"""
209 dtb_file = get_dtb_file('dtoc_test_empty.dts')
210 output = tools.GetOutputFilename('output')
Simon Glass768ff0a2021-02-03 06:00:51 -0700211
212 # Run this one without saved_scan to complete test coverage
Simon Glass3809ad92021-02-03 06:01:12 -0700213 dtb_platdata.run_steps(['struct'], dtb_file, False, output, [], None,
214 False)
Simon Glass9d2eb922017-06-18 22:09:06 -0600215 with open(output) as infile:
216 lines = infile.read().splitlines()
Simon Glasseb37e2d2017-11-12 21:52:17 -0700217 self.assertEqual(HEADER.splitlines(), lines)
Simon Glass9d2eb922017-06-18 22:09:06 -0600218
Walter Lozanoa324e412020-06-25 01:10:08 -0300219 self.run_test(['platdata'], dtb_file, output)
Simon Glass9d2eb922017-06-18 22:09:06 -0600220 with open(output) as infile:
221 lines = infile.read().splitlines()
Simon Glass2500de22020-12-28 20:35:05 -0700222 self.assertEqual(C_HEADER.splitlines() + [''], lines)
Simon Glass9d2eb922017-06-18 22:09:06 -0600223
Simon Glass3fa3bbb2021-02-03 06:01:14 -0700224 decl_text = DECL_HEADER + '''
225#include <dm/device-internal.h>
226#include <dm/uclass-internal.h>
227
228/* driver declarations - these allow DM_DRIVER_GET() to be used */
229DM_DRIVER_DECL(sandbox_i2c);
230DM_DRIVER_DECL(sandbox_pmic);
231DM_DRIVER_DECL(sandbox_spl_test);
232DM_DRIVER_DECL(sandbox_spl_test);
233DM_DRIVER_DECL(sandbox_spl_test);
234
235/* uclass driver declarations - needed for DM_UCLASS_DRIVER_REF() */
236DM_UCLASS_DRIVER_DECL(i2c);
237DM_UCLASS_DRIVER_DECL(misc);
238DM_UCLASS_DRIVER_DECL(pmic);
239'''
240 decl_text_inst = DECL_HEADER + '''
241#include <dm/device-internal.h>
242#include <dm/uclass-internal.h>
243
244/* driver declarations - these allow DM_DRIVER_GET() to be used */
245DM_DRIVER_DECL(sandbox_i2c);
246DM_DRIVER_DECL(sandbox_pmic);
247DM_DRIVER_DECL(root_driver);
248DM_DRIVER_DECL(sandbox_spl_test);
249DM_DRIVER_DECL(sandbox_spl_test);
250DM_DRIVER_DECL(sandbox_spl_test);
251
252/* device declarations - these allow DM_DEVICE_REF() to be used */
253DM_DEVICE_DECL(i2c_at_0);
254DM_DEVICE_DECL(pmic_at_9);
255DM_DEVICE_DECL(root);
256DM_DEVICE_DECL(spl_test);
257DM_DEVICE_DECL(spl_test2);
258DM_DEVICE_DECL(spl_test3);
259
260/* uclass driver declarations - needed for DM_UCLASS_DRIVER_REF() */
261DM_UCLASS_DRIVER_DECL(i2c);
262DM_UCLASS_DRIVER_DECL(misc);
263DM_UCLASS_DRIVER_DECL(pmic);
264DM_UCLASS_DRIVER_DECL(root);
265
266/* uclass declarations - needed for DM_UCLASS_REF() */
267DM_UCLASS_DECL(i2c);
268DM_UCLASS_DECL(misc);
269DM_UCLASS_DECL(pmic);
270DM_UCLASS_DECL(root);
271'''
Simon Glass07ee48e2020-12-28 20:34:49 -0700272 struct_text = HEADER + '''
Simon Glass32a8d222021-02-03 06:00:57 -0700273struct dtd_sandbox_i2c {
Simon Glass90e5f0a2017-08-29 14:15:51 -0600274};
Simon Glass32a8d222021-02-03 06:00:57 -0700275struct dtd_sandbox_pmic {
Simon Glass90e5f0a2017-08-29 14:15:51 -0600276\tbool\t\tlow_power;
277\tfdt64_t\t\treg[2];
278};
Simon Glass9d2eb922017-06-18 22:09:06 -0600279struct dtd_sandbox_spl_test {
Simon Glass7f5e2262020-07-07 21:32:06 -0600280\tconst char * acpi_name;
Simon Glass9d2eb922017-06-18 22:09:06 -0600281\tbool\t\tboolval;
282\tunsigned char\tbytearray[3];
283\tunsigned char\tbyteval;
284\tfdt32_t\t\tintarray[4];
285\tfdt32_t\t\tintval;
286\tunsigned char\tlongbytearray[9];
Simon Glass9c526332018-07-06 10:27:28 -0600287\tunsigned char\tnotstring[5];
Simon Glass9d2eb922017-06-18 22:09:06 -0600288\tconst char *\tstringarray[3];
289\tconst char *\tstringval;
290};
Simon Glass07ee48e2020-12-28 20:34:49 -0700291'''
Simon Glass9d2eb922017-06-18 22:09:06 -0600292
Simon Glass07ee48e2020-12-28 20:34:49 -0700293 platdata_text = C_HEADER + '''
Simon Glass192f8132020-10-03 11:31:25 -0600294/* Node /i2c@0 index 0 */
Simon Glass32a8d222021-02-03 06:00:57 -0700295static struct dtd_sandbox_i2c dtv_i2c_at_0 = {
Simon Glass192f8132020-10-03 11:31:25 -0600296};
Simon Glass1d8364a2020-12-28 20:34:54 -0700297U_BOOT_DRVINFO(i2c_at_0) = {
Simon Glass32a8d222021-02-03 06:00:57 -0700298\t.name\t\t= "sandbox_i2c",
Simon Glass71fa5b42020-12-03 16:55:18 -0700299\t.plat\t= &dtv_i2c_at_0,
Simon Glass39edb952020-12-03 16:55:19 -0700300\t.plat_size\t= sizeof(dtv_i2c_at_0),
Simon Glass36b15e22020-10-03 11:31:35 -0600301\t.parent_idx\t= -1,
Simon Glass192f8132020-10-03 11:31:25 -0600302};
303
304/* Node /i2c@0/pmic@9 index 1 */
Simon Glass32a8d222021-02-03 06:00:57 -0700305static struct dtd_sandbox_pmic dtv_pmic_at_9 = {
Simon Glass192f8132020-10-03 11:31:25 -0600306\t.low_power\t\t= true,
307\t.reg\t\t\t= {0x9, 0x0},
308};
Simon Glass1d8364a2020-12-28 20:34:54 -0700309U_BOOT_DRVINFO(pmic_at_9) = {
Simon Glass32a8d222021-02-03 06:00:57 -0700310\t.name\t\t= "sandbox_pmic",
Simon Glass71fa5b42020-12-03 16:55:18 -0700311\t.plat\t= &dtv_pmic_at_9,
Simon Glass39edb952020-12-03 16:55:19 -0700312\t.plat_size\t= sizeof(dtv_pmic_at_9),
Simon Glass36b15e22020-10-03 11:31:35 -0600313\t.parent_idx\t= 0,
Simon Glass192f8132020-10-03 11:31:25 -0600314};
315
316/* Node /spl-test index 2 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300317static struct dtd_sandbox_spl_test dtv_spl_test = {
Simon Glassc82de562019-05-17 22:00:32 -0600318\t.boolval\t\t= true,
Simon Glass9d2eb922017-06-18 22:09:06 -0600319\t.bytearray\t\t= {0x6, 0x0, 0x0},
320\t.byteval\t\t= 0x5,
Simon Glassc82de562019-05-17 22:00:32 -0600321\t.intarray\t\t= {0x2, 0x3, 0x4, 0x0},
Simon Glass9d2eb922017-06-18 22:09:06 -0600322\t.intval\t\t\t= 0x1,
Simon Glass131e0b02017-08-29 14:15:49 -0600323\t.longbytearray\t\t= {0x9, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf, 0x10,
324\t\t0x11},
Simon Glassc82de562019-05-17 22:00:32 -0600325\t.notstring\t\t= {0x20, 0x21, 0x22, 0x10, 0x0},
Simon Glass9d2eb922017-06-18 22:09:06 -0600326\t.stringarray\t\t= {"multi-word", "message", ""},
Simon Glassc82de562019-05-17 22:00:32 -0600327\t.stringval\t\t= "message",
Simon Glass9d2eb922017-06-18 22:09:06 -0600328};
Simon Glass1d8364a2020-12-28 20:34:54 -0700329U_BOOT_DRVINFO(spl_test) = {
Simon Glass9d2eb922017-06-18 22:09:06 -0600330\t.name\t\t= "sandbox_spl_test",
Simon Glass71fa5b42020-12-03 16:55:18 -0700331\t.plat\t= &dtv_spl_test,
Simon Glass39edb952020-12-03 16:55:19 -0700332\t.plat_size\t= sizeof(dtv_spl_test),
Simon Glass36b15e22020-10-03 11:31:35 -0600333\t.parent_idx\t= -1,
Simon Glass9d2eb922017-06-18 22:09:06 -0600334};
335
Simon Glass192f8132020-10-03 11:31:25 -0600336/* Node /spl-test2 index 3 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300337static struct dtd_sandbox_spl_test dtv_spl_test2 = {
Simon Glass7f5e2262020-07-07 21:32:06 -0600338\t.acpi_name\t\t= "\\\\_SB.GPO0",
Simon Glass9d2eb922017-06-18 22:09:06 -0600339\t.bytearray\t\t= {0x1, 0x23, 0x34},
340\t.byteval\t\t= 0x8,
Simon Glassc82de562019-05-17 22:00:32 -0600341\t.intarray\t\t= {0x5, 0x0, 0x0, 0x0},
Simon Glass9d2eb922017-06-18 22:09:06 -0600342\t.intval\t\t\t= 0x3,
Simon Glass8034e4d2020-10-03 11:31:27 -0600343\t.longbytearray\t\t= {0x9, 0xa, 0xb, 0xc, 0x0, 0x0, 0x0, 0x0,
Simon Glass131e0b02017-08-29 14:15:49 -0600344\t\t0x0},
Simon Glass9d2eb922017-06-18 22:09:06 -0600345\t.stringarray\t\t= {"another", "multi-word", "message"},
Simon Glassc82de562019-05-17 22:00:32 -0600346\t.stringval\t\t= "message2",
Simon Glass9d2eb922017-06-18 22:09:06 -0600347};
Simon Glass1d8364a2020-12-28 20:34:54 -0700348U_BOOT_DRVINFO(spl_test2) = {
Simon Glass9d2eb922017-06-18 22:09:06 -0600349\t.name\t\t= "sandbox_spl_test",
Simon Glass71fa5b42020-12-03 16:55:18 -0700350\t.plat\t= &dtv_spl_test2,
Simon Glass39edb952020-12-03 16:55:19 -0700351\t.plat_size\t= sizeof(dtv_spl_test2),
Simon Glass36b15e22020-10-03 11:31:35 -0600352\t.parent_idx\t= -1,
Simon Glass9d2eb922017-06-18 22:09:06 -0600353};
354
Simon Glass192f8132020-10-03 11:31:25 -0600355/* Node /spl-test3 index 4 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300356static struct dtd_sandbox_spl_test dtv_spl_test3 = {
Simon Glass8034e4d2020-10-03 11:31:27 -0600357\t.longbytearray\t\t= {0x9, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf, 0x10,
358\t\t0x0},
Simon Glass9d2eb922017-06-18 22:09:06 -0600359\t.stringarray\t\t= {"one", "", ""},
360};
Simon Glass1d8364a2020-12-28 20:34:54 -0700361U_BOOT_DRVINFO(spl_test3) = {
Simon Glass9d2eb922017-06-18 22:09:06 -0600362\t.name\t\t= "sandbox_spl_test",
Simon Glass71fa5b42020-12-03 16:55:18 -0700363\t.plat\t= &dtv_spl_test3,
Simon Glass39edb952020-12-03 16:55:19 -0700364\t.plat_size\t= sizeof(dtv_spl_test3),
Simon Glass36b15e22020-10-03 11:31:35 -0600365\t.parent_idx\t= -1,
Simon Glass9d2eb922017-06-18 22:09:06 -0600366};
367
Simon Glass2500de22020-12-28 20:35:05 -0700368'''
Simon Glass07ee48e2020-12-28 20:34:49 -0700369
370 def test_simple(self):
371 """Test output from some simple nodes with various types of data"""
372 dtb_file = get_dtb_file('dtoc_test_simple.dts')
373 output = tools.GetOutputFilename('output')
374 self.run_test(['struct'], dtb_file, output)
375 with open(output) as infile:
376 data = infile.read()
377
378 self._check_strings(self.struct_text, data)
379
380 self.run_test(['platdata'], dtb_file, output)
381 with open(output) as infile:
382 data = infile.read()
383
384 self._check_strings(self.platdata_text, data)
Simon Glass9d2eb922017-06-18 22:09:06 -0600385
Simon Glass3fa3bbb2021-02-03 06:01:14 -0700386 self.run_test(['decl'], dtb_file, output)
387 with open(output) as infile:
388 data = infile.read()
389
390 self._check_strings(self.decl_text, data)
391
Simon Glass4e8e8462020-12-28 20:34:52 -0700392 # Try the 'all' command
393 self.run_test(['all'], dtb_file, output)
394 data = tools.ReadFile(output, binary=False)
Simon Glass3fa3bbb2021-02-03 06:01:14 -0700395 self._check_strings(self.decl_text + self.platdata_text +
396 self.struct_text, data)
Simon Glass4e8e8462020-12-28 20:34:52 -0700397
Walter Lozanoe675d962020-07-03 08:07:17 -0300398 def test_driver_alias(self):
399 """Test output from a device tree file with a driver alias"""
400 dtb_file = get_dtb_file('dtoc_test_driver_alias.dts')
401 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300402 self.run_test(['struct'], dtb_file, output)
Walter Lozanoe675d962020-07-03 08:07:17 -0300403 with open(output) as infile:
404 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700405 self._check_strings(HEADER + '''
Walter Lozanoe675d962020-07-03 08:07:17 -0300406struct dtd_sandbox_gpio {
407\tconst char *\tgpio_bank_name;
408\tbool\t\tgpio_controller;
409\tfdt32_t\t\tsandbox_gpio_count;
410};
Walter Lozanoe675d962020-07-03 08:07:17 -0300411''', data)
412
Walter Lozanoa324e412020-06-25 01:10:08 -0300413 self.run_test(['platdata'], dtb_file, output)
Walter Lozanoe675d962020-07-03 08:07:17 -0300414 with open(output) as infile:
415 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700416 self._check_strings(C_HEADER + '''
Simon Glass192f8132020-10-03 11:31:25 -0600417/* Node /gpios@0 index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300418static struct dtd_sandbox_gpio dtv_gpios_at_0 = {
Walter Lozanoe675d962020-07-03 08:07:17 -0300419\t.gpio_bank_name\t\t= "a",
420\t.gpio_controller\t= true,
421\t.sandbox_gpio_count\t= 0x14,
422};
Simon Glass1d8364a2020-12-28 20:34:54 -0700423U_BOOT_DRVINFO(gpios_at_0) = {
Walter Lozanoe675d962020-07-03 08:07:17 -0300424\t.name\t\t= "sandbox_gpio",
Simon Glass71fa5b42020-12-03 16:55:18 -0700425\t.plat\t= &dtv_gpios_at_0,
Simon Glass39edb952020-12-03 16:55:19 -0700426\t.plat_size\t= sizeof(dtv_gpios_at_0),
Simon Glass36b15e22020-10-03 11:31:35 -0600427\t.parent_idx\t= -1,
Walter Lozanoe675d962020-07-03 08:07:17 -0300428};
429
430''', data)
431
Walter Lozanoa324e412020-06-25 01:10:08 -0300432 def test_invalid_driver(self):
433 """Test output from a device tree file with an invalid driver"""
434 dtb_file = get_dtb_file('dtoc_test_invalid_driver.dts')
435 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -0700436 with test_util.capture_sys_output() as _:
Simon Glass3809ad92021-02-03 06:01:12 -0700437 dtb_platdata.run_steps(
438 ['struct'], dtb_file, False, output, [], None, False,
439 scan=copy_scan())
Walter Lozanoa324e412020-06-25 01:10:08 -0300440 with open(output) as infile:
441 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700442 self._check_strings(HEADER + '''
Walter Lozanoa324e412020-06-25 01:10:08 -0300443struct dtd_invalid {
444};
445''', data)
446
Simon Glassa60cabd2020-12-28 20:34:47 -0700447 with test_util.capture_sys_output() as _:
Simon Glass3809ad92021-02-03 06:01:12 -0700448 dtb_platdata.run_steps(
449 ['platdata'], dtb_file, False, output, [], None, False,
450 scan=copy_scan())
Walter Lozanoa324e412020-06-25 01:10:08 -0300451 with open(output) as infile:
452 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700453 self._check_strings(C_HEADER + '''
Simon Glass192f8132020-10-03 11:31:25 -0600454/* Node /spl-test index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300455static struct dtd_invalid dtv_spl_test = {
Walter Lozanoa324e412020-06-25 01:10:08 -0300456};
Simon Glass1d8364a2020-12-28 20:34:54 -0700457U_BOOT_DRVINFO(spl_test) = {
Walter Lozanoa324e412020-06-25 01:10:08 -0300458\t.name\t\t= "invalid",
Simon Glass71fa5b42020-12-03 16:55:18 -0700459\t.plat\t= &dtv_spl_test,
Simon Glass39edb952020-12-03 16:55:19 -0700460\t.plat_size\t= sizeof(dtv_spl_test),
Simon Glass36b15e22020-10-03 11:31:35 -0600461\t.parent_idx\t= -1,
Walter Lozanoa324e412020-06-25 01:10:08 -0300462};
463
464''', data)
465
Simon Glass9d2eb922017-06-18 22:09:06 -0600466 def test_phandle(self):
467 """Test output from a node containing a phandle reference"""
468 dtb_file = get_dtb_file('dtoc_test_phandle.dts')
469 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300470 self.run_test(['struct'], dtb_file, output)
Simon Glass9d2eb922017-06-18 22:09:06 -0600471 with open(output) as infile:
472 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700473 self._check_strings(HEADER + '''
Simon Glass9d2eb922017-06-18 22:09:06 -0600474struct dtd_source {
Simon Glass3deeb472017-08-29 14:15:59 -0600475\tstruct phandle_2_arg clocks[4];
Simon Glass9d2eb922017-06-18 22:09:06 -0600476};
477struct dtd_target {
478\tfdt32_t\t\tintval;
479};
480''', data)
481
Walter Lozanoa324e412020-06-25 01:10:08 -0300482 self.run_test(['platdata'], dtb_file, output)
Simon Glass9d2eb922017-06-18 22:09:06 -0600483 with open(output) as infile:
484 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700485 self._check_strings(C_HEADER + '''
Simon Glass192f8132020-10-03 11:31:25 -0600486/* Node /phandle2-target index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300487static struct dtd_target dtv_phandle2_target = {
Simon Glass3deeb472017-08-29 14:15:59 -0600488\t.intval\t\t\t= 0x1,
489};
Simon Glass1d8364a2020-12-28 20:34:54 -0700490U_BOOT_DRVINFO(phandle2_target) = {
Simon Glass3deeb472017-08-29 14:15:59 -0600491\t.name\t\t= "target",
Simon Glass71fa5b42020-12-03 16:55:18 -0700492\t.plat\t= &dtv_phandle2_target,
Simon Glass39edb952020-12-03 16:55:19 -0700493\t.plat_size\t= sizeof(dtv_phandle2_target),
Simon Glass36b15e22020-10-03 11:31:35 -0600494\t.parent_idx\t= -1,
Simon Glass3deeb472017-08-29 14:15:59 -0600495};
496
Simon Glass192f8132020-10-03 11:31:25 -0600497/* Node /phandle3-target index 1 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300498static struct dtd_target dtv_phandle3_target = {
Simon Glass3deeb472017-08-29 14:15:59 -0600499\t.intval\t\t\t= 0x2,
500};
Simon Glass1d8364a2020-12-28 20:34:54 -0700501U_BOOT_DRVINFO(phandle3_target) = {
Simon Glass3deeb472017-08-29 14:15:59 -0600502\t.name\t\t= "target",
Simon Glass71fa5b42020-12-03 16:55:18 -0700503\t.plat\t= &dtv_phandle3_target,
Simon Glass39edb952020-12-03 16:55:19 -0700504\t.plat_size\t= sizeof(dtv_phandle3_target),
Simon Glass36b15e22020-10-03 11:31:35 -0600505\t.parent_idx\t= -1,
Simon Glass3deeb472017-08-29 14:15:59 -0600506};
507
Simon Glass192f8132020-10-03 11:31:25 -0600508/* Node /phandle-source index 2 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300509static struct dtd_source dtv_phandle_source = {
Simon Glassd0cd0752017-08-29 14:15:57 -0600510\t.clocks\t\t\t= {
Simon Glass5792f4b2020-10-03 11:31:40 -0600511\t\t\t{4, {}},
512\t\t\t{0, {11}},
513\t\t\t{1, {12, 13}},
514\t\t\t{4, {}},},
Simon Glass9d2eb922017-06-18 22:09:06 -0600515};
Simon Glass1d8364a2020-12-28 20:34:54 -0700516U_BOOT_DRVINFO(phandle_source) = {
Simon Glass9d2eb922017-06-18 22:09:06 -0600517\t.name\t\t= "source",
Simon Glass71fa5b42020-12-03 16:55:18 -0700518\t.plat\t= &dtv_phandle_source,
Simon Glass39edb952020-12-03 16:55:19 -0700519\t.plat_size\t= sizeof(dtv_phandle_source),
Simon Glass36b15e22020-10-03 11:31:35 -0600520\t.parent_idx\t= -1,
Simon Glass9d2eb922017-06-18 22:09:06 -0600521};
522
Simon Glass192f8132020-10-03 11:31:25 -0600523/* Node /phandle-source2 index 3 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300524static struct dtd_source dtv_phandle_source2 = {
Simon Glass609e2b12018-07-06 10:27:31 -0600525\t.clocks\t\t\t= {
Simon Glass5792f4b2020-10-03 11:31:40 -0600526\t\t\t{4, {}},},
Simon Glass609e2b12018-07-06 10:27:31 -0600527};
Simon Glass1d8364a2020-12-28 20:34:54 -0700528U_BOOT_DRVINFO(phandle_source2) = {
Simon Glass609e2b12018-07-06 10:27:31 -0600529\t.name\t\t= "source",
Simon Glass71fa5b42020-12-03 16:55:18 -0700530\t.plat\t= &dtv_phandle_source2,
Simon Glass39edb952020-12-03 16:55:19 -0700531\t.plat_size\t= sizeof(dtv_phandle_source2),
Simon Glass36b15e22020-10-03 11:31:35 -0600532\t.parent_idx\t= -1,
Simon Glass609e2b12018-07-06 10:27:31 -0600533};
534
Simon Glass16382ce2020-12-28 20:35:04 -0700535/* Node /phandle-target index 4 */
536static struct dtd_target dtv_phandle_target = {
537\t.intval\t\t\t= 0x0,
538};
539U_BOOT_DRVINFO(phandle_target) = {
540\t.name\t\t= "target",
541\t.plat\t= &dtv_phandle_target,
542\t.plat_size\t= sizeof(dtv_phandle_target),
543\t.parent_idx\t= -1,
544};
545
Simon Glass9d2eb922017-06-18 22:09:06 -0600546''', data)
547
Simon Glass961c1ce2018-07-06 10:27:35 -0600548 def test_phandle_single(self):
549 """Test output from a node containing a phandle reference"""
550 dtb_file = get_dtb_file('dtoc_test_phandle_single.dts')
551 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300552 self.run_test(['struct'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -0600553 with open(output) as infile:
554 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700555 self._check_strings(HEADER + '''
Simon Glass961c1ce2018-07-06 10:27:35 -0600556struct dtd_source {
557\tstruct phandle_0_arg clocks[1];
558};
559struct dtd_target {
560\tfdt32_t\t\tintval;
561};
562''', data)
563
564 def test_phandle_reorder(self):
565 """Test that phandle targets are generated before their references"""
566 dtb_file = get_dtb_file('dtoc_test_phandle_reorder.dts')
567 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300568 self.run_test(['platdata'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -0600569 with open(output) as infile:
570 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700571 self._check_strings(C_HEADER + '''
Simon Glass192f8132020-10-03 11:31:25 -0600572/* Node /phandle-source2 index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300573static struct dtd_source dtv_phandle_source2 = {
Simon Glass961c1ce2018-07-06 10:27:35 -0600574\t.clocks\t\t\t= {
Simon Glass5792f4b2020-10-03 11:31:40 -0600575\t\t\t{1, {}},},
Simon Glass961c1ce2018-07-06 10:27:35 -0600576};
Simon Glass1d8364a2020-12-28 20:34:54 -0700577U_BOOT_DRVINFO(phandle_source2) = {
Simon Glass961c1ce2018-07-06 10:27:35 -0600578\t.name\t\t= "source",
Simon Glass71fa5b42020-12-03 16:55:18 -0700579\t.plat\t= &dtv_phandle_source2,
Simon Glass39edb952020-12-03 16:55:19 -0700580\t.plat_size\t= sizeof(dtv_phandle_source2),
Simon Glass36b15e22020-10-03 11:31:35 -0600581\t.parent_idx\t= -1,
Simon Glass961c1ce2018-07-06 10:27:35 -0600582};
583
Simon Glass16382ce2020-12-28 20:35:04 -0700584/* Node /phandle-target index 1 */
585static struct dtd_target dtv_phandle_target = {
586};
587U_BOOT_DRVINFO(phandle_target) = {
588\t.name\t\t= "target",
589\t.plat\t= &dtv_phandle_target,
590\t.plat_size\t= sizeof(dtv_phandle_target),
591\t.parent_idx\t= -1,
592};
593
Simon Glass961c1ce2018-07-06 10:27:35 -0600594''', data)
595
Walter Lozano5541fc02020-06-25 01:10:17 -0300596 def test_phandle_cd_gpio(self):
597 """Test that phandle targets are generated when unsing cd-gpios"""
598 dtb_file = get_dtb_file('dtoc_test_phandle_cd_gpios.dts')
599 output = tools.GetOutputFilename('output')
Simon Glass3809ad92021-02-03 06:01:12 -0700600 dtb_platdata.run_steps(
601 ['platdata'], dtb_file, False, output, [], None, False,
602 warning_disabled=True, scan=copy_scan())
Walter Lozano5541fc02020-06-25 01:10:17 -0300603 with open(output) as infile:
604 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700605 self._check_strings(C_HEADER + '''
Simon Glass192f8132020-10-03 11:31:25 -0600606/* Node /phandle2-target index 0 */
Walter Lozano5541fc02020-06-25 01:10:17 -0300607static struct dtd_target dtv_phandle2_target = {
608\t.intval\t\t\t= 0x1,
609};
Simon Glass1d8364a2020-12-28 20:34:54 -0700610U_BOOT_DRVINFO(phandle2_target) = {
Walter Lozano5541fc02020-06-25 01:10:17 -0300611\t.name\t\t= "target",
Simon Glass71fa5b42020-12-03 16:55:18 -0700612\t.plat\t= &dtv_phandle2_target,
Simon Glass39edb952020-12-03 16:55:19 -0700613\t.plat_size\t= sizeof(dtv_phandle2_target),
Simon Glass36b15e22020-10-03 11:31:35 -0600614\t.parent_idx\t= -1,
Walter Lozano5541fc02020-06-25 01:10:17 -0300615};
616
Simon Glass192f8132020-10-03 11:31:25 -0600617/* Node /phandle3-target index 1 */
Walter Lozano5541fc02020-06-25 01:10:17 -0300618static struct dtd_target dtv_phandle3_target = {
619\t.intval\t\t\t= 0x2,
620};
Simon Glass1d8364a2020-12-28 20:34:54 -0700621U_BOOT_DRVINFO(phandle3_target) = {
Walter Lozano5541fc02020-06-25 01:10:17 -0300622\t.name\t\t= "target",
Simon Glass71fa5b42020-12-03 16:55:18 -0700623\t.plat\t= &dtv_phandle3_target,
Simon Glass39edb952020-12-03 16:55:19 -0700624\t.plat_size\t= sizeof(dtv_phandle3_target),
Simon Glass36b15e22020-10-03 11:31:35 -0600625\t.parent_idx\t= -1,
Walter Lozano5541fc02020-06-25 01:10:17 -0300626};
627
Simon Glass192f8132020-10-03 11:31:25 -0600628/* Node /phandle-source index 2 */
Walter Lozano5541fc02020-06-25 01:10:17 -0300629static struct dtd_source dtv_phandle_source = {
630\t.cd_gpios\t\t= {
Simon Glass5792f4b2020-10-03 11:31:40 -0600631\t\t\t{4, {}},
632\t\t\t{0, {11}},
633\t\t\t{1, {12, 13}},
634\t\t\t{4, {}},},
Walter Lozano5541fc02020-06-25 01:10:17 -0300635};
Simon Glass1d8364a2020-12-28 20:34:54 -0700636U_BOOT_DRVINFO(phandle_source) = {
Walter Lozano5541fc02020-06-25 01:10:17 -0300637\t.name\t\t= "source",
Simon Glass71fa5b42020-12-03 16:55:18 -0700638\t.plat\t= &dtv_phandle_source,
Simon Glass39edb952020-12-03 16:55:19 -0700639\t.plat_size\t= sizeof(dtv_phandle_source),
Simon Glass36b15e22020-10-03 11:31:35 -0600640\t.parent_idx\t= -1,
Walter Lozano5541fc02020-06-25 01:10:17 -0300641};
642
Simon Glass192f8132020-10-03 11:31:25 -0600643/* Node /phandle-source2 index 3 */
Walter Lozano5541fc02020-06-25 01:10:17 -0300644static struct dtd_source dtv_phandle_source2 = {
645\t.cd_gpios\t\t= {
Simon Glass5792f4b2020-10-03 11:31:40 -0600646\t\t\t{4, {}},},
Walter Lozano5541fc02020-06-25 01:10:17 -0300647};
Simon Glass1d8364a2020-12-28 20:34:54 -0700648U_BOOT_DRVINFO(phandle_source2) = {
Walter Lozano5541fc02020-06-25 01:10:17 -0300649\t.name\t\t= "source",
Simon Glass71fa5b42020-12-03 16:55:18 -0700650\t.plat\t= &dtv_phandle_source2,
Simon Glass39edb952020-12-03 16:55:19 -0700651\t.plat_size\t= sizeof(dtv_phandle_source2),
Simon Glass36b15e22020-10-03 11:31:35 -0600652\t.parent_idx\t= -1,
Walter Lozano5541fc02020-06-25 01:10:17 -0300653};
654
Simon Glass16382ce2020-12-28 20:35:04 -0700655/* Node /phandle-target index 4 */
656static struct dtd_target dtv_phandle_target = {
657\t.intval\t\t\t= 0x0,
658};
659U_BOOT_DRVINFO(phandle_target) = {
660\t.name\t\t= "target",
661\t.plat\t= &dtv_phandle_target,
662\t.plat_size\t= sizeof(dtv_phandle_target),
663\t.parent_idx\t= -1,
664};
665
Walter Lozano5541fc02020-06-25 01:10:17 -0300666''', data)
667
Simon Glass961c1ce2018-07-06 10:27:35 -0600668 def test_phandle_bad(self):
669 """Test a node containing an invalid phandle fails"""
Simon Glass04150022018-10-01 21:12:43 -0600670 dtb_file = get_dtb_file('dtoc_test_phandle_bad.dts',
671 capture_stderr=True)
Simon Glass961c1ce2018-07-06 10:27:35 -0600672 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -0700673 with self.assertRaises(ValueError) as exc:
Walter Lozanoa324e412020-06-25 01:10:08 -0300674 self.run_test(['struct'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -0600675 self.assertIn("Cannot parse 'clocks' in node 'phandle-source'",
Simon Glassa60cabd2020-12-28 20:34:47 -0700676 str(exc.exception))
Simon Glass961c1ce2018-07-06 10:27:35 -0600677
678 def test_phandle_bad2(self):
679 """Test a phandle target missing its #*-cells property"""
Simon Glass04150022018-10-01 21:12:43 -0600680 dtb_file = get_dtb_file('dtoc_test_phandle_bad2.dts',
681 capture_stderr=True)
Simon Glass961c1ce2018-07-06 10:27:35 -0600682 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -0700683 with self.assertRaises(ValueError) as exc:
Walter Lozanoa324e412020-06-25 01:10:08 -0300684 self.run_test(['struct'], dtb_file, output)
Walter Lozano179f0b62020-06-25 01:10:16 -0300685 self.assertIn("Node 'phandle-target' has no cells property",
Simon Glassa60cabd2020-12-28 20:34:47 -0700686 str(exc.exception))
Simon Glass961c1ce2018-07-06 10:27:35 -0600687
Simon Glass1b1fe412017-08-29 14:15:50 -0600688 def test_addresses64(self):
689 """Test output from a node with a 'reg' property with na=2, ns=2"""
690 dtb_file = get_dtb_file('dtoc_test_addr64.dts')
691 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300692 self.run_test(['struct'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -0600693 with open(output) as infile:
694 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700695 self._check_strings(HEADER + '''
Simon Glass1b1fe412017-08-29 14:15:50 -0600696struct dtd_test1 {
697\tfdt64_t\t\treg[2];
698};
699struct dtd_test2 {
700\tfdt64_t\t\treg[2];
701};
702struct dtd_test3 {
703\tfdt64_t\t\treg[4];
704};
705''', data)
706
Walter Lozanoa324e412020-06-25 01:10:08 -0300707 self.run_test(['platdata'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -0600708 with open(output) as infile:
709 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700710 self._check_strings(C_HEADER + '''
Simon Glass192f8132020-10-03 11:31:25 -0600711/* Node /test1 index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300712static struct dtd_test1 dtv_test1 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600713\t.reg\t\t\t= {0x1234, 0x5678},
714};
Simon Glass1d8364a2020-12-28 20:34:54 -0700715U_BOOT_DRVINFO(test1) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600716\t.name\t\t= "test1",
Simon Glass71fa5b42020-12-03 16:55:18 -0700717\t.plat\t= &dtv_test1,
Simon Glass39edb952020-12-03 16:55:19 -0700718\t.plat_size\t= sizeof(dtv_test1),
Simon Glass36b15e22020-10-03 11:31:35 -0600719\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600720};
721
Simon Glass192f8132020-10-03 11:31:25 -0600722/* Node /test2 index 1 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300723static struct dtd_test2 dtv_test2 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600724\t.reg\t\t\t= {0x1234567890123456, 0x9876543210987654},
725};
Simon Glass1d8364a2020-12-28 20:34:54 -0700726U_BOOT_DRVINFO(test2) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600727\t.name\t\t= "test2",
Simon Glass71fa5b42020-12-03 16:55:18 -0700728\t.plat\t= &dtv_test2,
Simon Glass39edb952020-12-03 16:55:19 -0700729\t.plat_size\t= sizeof(dtv_test2),
Simon Glass36b15e22020-10-03 11:31:35 -0600730\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600731};
732
Simon Glass192f8132020-10-03 11:31:25 -0600733/* Node /test3 index 2 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300734static struct dtd_test3 dtv_test3 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600735\t.reg\t\t\t= {0x1234567890123456, 0x9876543210987654, 0x2, 0x3},
736};
Simon Glass1d8364a2020-12-28 20:34:54 -0700737U_BOOT_DRVINFO(test3) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600738\t.name\t\t= "test3",
Simon Glass71fa5b42020-12-03 16:55:18 -0700739\t.plat\t= &dtv_test3,
Simon Glass39edb952020-12-03 16:55:19 -0700740\t.plat_size\t= sizeof(dtv_test3),
Simon Glass36b15e22020-10-03 11:31:35 -0600741\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600742};
743
Simon Glass2500de22020-12-28 20:35:05 -0700744''', data)
Simon Glass1b1fe412017-08-29 14:15:50 -0600745
746 def test_addresses32(self):
747 """Test output from a node with a 'reg' property with na=1, ns=1"""
748 dtb_file = get_dtb_file('dtoc_test_addr32.dts')
749 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300750 self.run_test(['struct'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -0600751 with open(output) as infile:
752 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700753 self._check_strings(HEADER + '''
Simon Glass1b1fe412017-08-29 14:15:50 -0600754struct dtd_test1 {
755\tfdt32_t\t\treg[2];
756};
757struct dtd_test2 {
758\tfdt32_t\t\treg[4];
759};
760''', data)
761
Walter Lozanoa324e412020-06-25 01:10:08 -0300762 self.run_test(['platdata'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -0600763 with open(output) as infile:
764 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700765 self._check_strings(C_HEADER + '''
Simon Glass192f8132020-10-03 11:31:25 -0600766/* Node /test1 index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300767static struct dtd_test1 dtv_test1 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600768\t.reg\t\t\t= {0x1234, 0x5678},
769};
Simon Glass1d8364a2020-12-28 20:34:54 -0700770U_BOOT_DRVINFO(test1) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600771\t.name\t\t= "test1",
Simon Glass71fa5b42020-12-03 16:55:18 -0700772\t.plat\t= &dtv_test1,
Simon Glass39edb952020-12-03 16:55:19 -0700773\t.plat_size\t= sizeof(dtv_test1),
Simon Glass36b15e22020-10-03 11:31:35 -0600774\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600775};
776
Simon Glass192f8132020-10-03 11:31:25 -0600777/* Node /test2 index 1 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300778static struct dtd_test2 dtv_test2 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600779\t.reg\t\t\t= {0x12345678, 0x98765432, 0x2, 0x3},
780};
Simon Glass1d8364a2020-12-28 20:34:54 -0700781U_BOOT_DRVINFO(test2) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600782\t.name\t\t= "test2",
Simon Glass71fa5b42020-12-03 16:55:18 -0700783\t.plat\t= &dtv_test2,
Simon Glass39edb952020-12-03 16:55:19 -0700784\t.plat_size\t= sizeof(dtv_test2),
Simon Glass36b15e22020-10-03 11:31:35 -0600785\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600786};
787
Simon Glass2500de22020-12-28 20:35:05 -0700788''', data)
Simon Glass1b1fe412017-08-29 14:15:50 -0600789
790 def test_addresses64_32(self):
791 """Test output from a node with a 'reg' property with na=2, ns=1"""
792 dtb_file = get_dtb_file('dtoc_test_addr64_32.dts')
793 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300794 self.run_test(['struct'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -0600795 with open(output) as infile:
796 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700797 self._check_strings(HEADER + '''
Simon Glass1b1fe412017-08-29 14:15:50 -0600798struct dtd_test1 {
799\tfdt64_t\t\treg[2];
800};
801struct dtd_test2 {
802\tfdt64_t\t\treg[2];
803};
804struct dtd_test3 {
805\tfdt64_t\t\treg[4];
806};
807''', data)
808
Walter Lozanoa324e412020-06-25 01:10:08 -0300809 self.run_test(['platdata'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -0600810 with open(output) as infile:
811 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700812 self._check_strings(C_HEADER + '''
Simon Glass192f8132020-10-03 11:31:25 -0600813/* Node /test1 index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300814static struct dtd_test1 dtv_test1 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600815\t.reg\t\t\t= {0x123400000000, 0x5678},
816};
Simon Glass1d8364a2020-12-28 20:34:54 -0700817U_BOOT_DRVINFO(test1) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600818\t.name\t\t= "test1",
Simon Glass71fa5b42020-12-03 16:55:18 -0700819\t.plat\t= &dtv_test1,
Simon Glass39edb952020-12-03 16:55:19 -0700820\t.plat_size\t= sizeof(dtv_test1),
Simon Glass36b15e22020-10-03 11:31:35 -0600821\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600822};
823
Simon Glass192f8132020-10-03 11:31:25 -0600824/* Node /test2 index 1 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300825static struct dtd_test2 dtv_test2 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600826\t.reg\t\t\t= {0x1234567890123456, 0x98765432},
827};
Simon Glass1d8364a2020-12-28 20:34:54 -0700828U_BOOT_DRVINFO(test2) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600829\t.name\t\t= "test2",
Simon Glass71fa5b42020-12-03 16:55:18 -0700830\t.plat\t= &dtv_test2,
Simon Glass39edb952020-12-03 16:55:19 -0700831\t.plat_size\t= sizeof(dtv_test2),
Simon Glass36b15e22020-10-03 11:31:35 -0600832\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600833};
834
Simon Glass192f8132020-10-03 11:31:25 -0600835/* Node /test3 index 2 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300836static struct dtd_test3 dtv_test3 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600837\t.reg\t\t\t= {0x1234567890123456, 0x98765432, 0x2, 0x3},
838};
Simon Glass1d8364a2020-12-28 20:34:54 -0700839U_BOOT_DRVINFO(test3) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600840\t.name\t\t= "test3",
Simon Glass71fa5b42020-12-03 16:55:18 -0700841\t.plat\t= &dtv_test3,
Simon Glass39edb952020-12-03 16:55:19 -0700842\t.plat_size\t= sizeof(dtv_test3),
Simon Glass36b15e22020-10-03 11:31:35 -0600843\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600844};
845
Simon Glass2500de22020-12-28 20:35:05 -0700846''', data)
Simon Glass1b1fe412017-08-29 14:15:50 -0600847
848 def test_addresses32_64(self):
849 """Test output from a node with a 'reg' property with na=1, ns=2"""
850 dtb_file = get_dtb_file('dtoc_test_addr32_64.dts')
851 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300852 self.run_test(['struct'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -0600853 with open(output) as infile:
854 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700855 self._check_strings(HEADER + '''
Simon Glass1b1fe412017-08-29 14:15:50 -0600856struct dtd_test1 {
857\tfdt64_t\t\treg[2];
858};
859struct dtd_test2 {
860\tfdt64_t\t\treg[2];
861};
862struct dtd_test3 {
863\tfdt64_t\t\treg[4];
864};
865''', data)
866
Walter Lozanoa324e412020-06-25 01:10:08 -0300867 self.run_test(['platdata'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -0600868 with open(output) as infile:
869 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700870 self._check_strings(C_HEADER + '''
Simon Glass192f8132020-10-03 11:31:25 -0600871/* Node /test1 index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300872static struct dtd_test1 dtv_test1 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600873\t.reg\t\t\t= {0x1234, 0x567800000000},
874};
Simon Glass1d8364a2020-12-28 20:34:54 -0700875U_BOOT_DRVINFO(test1) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600876\t.name\t\t= "test1",
Simon Glass71fa5b42020-12-03 16:55:18 -0700877\t.plat\t= &dtv_test1,
Simon Glass39edb952020-12-03 16:55:19 -0700878\t.plat_size\t= sizeof(dtv_test1),
Simon Glass36b15e22020-10-03 11:31:35 -0600879\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600880};
881
Simon Glass192f8132020-10-03 11:31:25 -0600882/* Node /test2 index 1 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300883static struct dtd_test2 dtv_test2 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600884\t.reg\t\t\t= {0x12345678, 0x9876543210987654},
885};
Simon Glass1d8364a2020-12-28 20:34:54 -0700886U_BOOT_DRVINFO(test2) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600887\t.name\t\t= "test2",
Simon Glass71fa5b42020-12-03 16:55:18 -0700888\t.plat\t= &dtv_test2,
Simon Glass39edb952020-12-03 16:55:19 -0700889\t.plat_size\t= sizeof(dtv_test2),
Simon Glass36b15e22020-10-03 11:31:35 -0600890\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600891};
892
Simon Glass192f8132020-10-03 11:31:25 -0600893/* Node /test3 index 2 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300894static struct dtd_test3 dtv_test3 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600895\t.reg\t\t\t= {0x12345678, 0x9876543210987654, 0x2, 0x3},
896};
Simon Glass1d8364a2020-12-28 20:34:54 -0700897U_BOOT_DRVINFO(test3) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600898\t.name\t\t= "test3",
Simon Glass71fa5b42020-12-03 16:55:18 -0700899\t.plat\t= &dtv_test3,
Simon Glass39edb952020-12-03 16:55:19 -0700900\t.plat_size\t= sizeof(dtv_test3),
Simon Glass36b15e22020-10-03 11:31:35 -0600901\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600902};
903
Simon Glass2500de22020-12-28 20:35:05 -0700904''', data)
Simon Glass961c1ce2018-07-06 10:27:35 -0600905
906 def test_bad_reg(self):
907 """Test that a reg property with an invalid type generates an error"""
Simon Glass3bce93d2018-07-06 10:27:37 -0600908 # Capture stderr since dtc will emit warnings for this file
909 dtb_file = get_dtb_file('dtoc_test_bad_reg.dts', capture_stderr=True)
Simon Glass961c1ce2018-07-06 10:27:35 -0600910 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -0700911 with self.assertRaises(ValueError) as exc:
Walter Lozanoa324e412020-06-25 01:10:08 -0300912 self.run_test(['struct'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -0600913 self.assertIn("Node 'spl-test' reg property is not an int",
Simon Glassa60cabd2020-12-28 20:34:47 -0700914 str(exc.exception))
Simon Glass961c1ce2018-07-06 10:27:35 -0600915
916 def test_bad_reg2(self):
917 """Test that a reg property with an invalid cell count is detected"""
Simon Glass3bce93d2018-07-06 10:27:37 -0600918 # Capture stderr since dtc will emit warnings for this file
919 dtb_file = get_dtb_file('dtoc_test_bad_reg2.dts', capture_stderr=True)
Simon Glass961c1ce2018-07-06 10:27:35 -0600920 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -0700921 with self.assertRaises(ValueError) as exc:
Walter Lozanoa324e412020-06-25 01:10:08 -0300922 self.run_test(['struct'], dtb_file, output)
Simon Glassa60cabd2020-12-28 20:34:47 -0700923 self.assertIn(
924 "Node 'spl-test' reg property has 3 cells which is not a multiple of na + ns = 1 + 1)",
925 str(exc.exception))
Simon Glass961c1ce2018-07-06 10:27:35 -0600926
927 def test_add_prop(self):
928 """Test that a subequent node can add a new property to a struct"""
929 dtb_file = get_dtb_file('dtoc_test_add_prop.dts')
930 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300931 self.run_test(['struct'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -0600932 with open(output) as infile:
933 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700934 self._check_strings(HEADER + '''
Simon Glass961c1ce2018-07-06 10:27:35 -0600935struct dtd_sandbox_spl_test {
936\tfdt32_t\t\tintarray;
937\tfdt32_t\t\tintval;
938};
939''', data)
940
Walter Lozanoa324e412020-06-25 01:10:08 -0300941 self.run_test(['platdata'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -0600942 with open(output) as infile:
943 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700944 self._check_strings(C_HEADER + '''
Simon Glass192f8132020-10-03 11:31:25 -0600945/* Node /spl-test index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300946static struct dtd_sandbox_spl_test dtv_spl_test = {
Simon Glass961c1ce2018-07-06 10:27:35 -0600947\t.intval\t\t\t= 0x1,
948};
Simon Glass1d8364a2020-12-28 20:34:54 -0700949U_BOOT_DRVINFO(spl_test) = {
Simon Glass961c1ce2018-07-06 10:27:35 -0600950\t.name\t\t= "sandbox_spl_test",
Simon Glass71fa5b42020-12-03 16:55:18 -0700951\t.plat\t= &dtv_spl_test,
Simon Glass39edb952020-12-03 16:55:19 -0700952\t.plat_size\t= sizeof(dtv_spl_test),
Simon Glass36b15e22020-10-03 11:31:35 -0600953\t.parent_idx\t= -1,
Simon Glass961c1ce2018-07-06 10:27:35 -0600954};
955
Simon Glass192f8132020-10-03 11:31:25 -0600956/* Node /spl-test2 index 1 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300957static struct dtd_sandbox_spl_test dtv_spl_test2 = {
Simon Glass961c1ce2018-07-06 10:27:35 -0600958\t.intarray\t\t= 0x5,
959};
Simon Glass1d8364a2020-12-28 20:34:54 -0700960U_BOOT_DRVINFO(spl_test2) = {
Simon Glass961c1ce2018-07-06 10:27:35 -0600961\t.name\t\t= "sandbox_spl_test",
Simon Glass71fa5b42020-12-03 16:55:18 -0700962\t.plat\t= &dtv_spl_test2,
Simon Glass39edb952020-12-03 16:55:19 -0700963\t.plat_size\t= sizeof(dtv_spl_test2),
Simon Glass36b15e22020-10-03 11:31:35 -0600964\t.parent_idx\t= -1,
Simon Glass961c1ce2018-07-06 10:27:35 -0600965};
966
Simon Glass2500de22020-12-28 20:35:05 -0700967''', data)
Simon Glass961c1ce2018-07-06 10:27:35 -0600968
Simon Glassa60cabd2020-12-28 20:34:47 -0700969 def test_stdout(self):
Simon Glass961c1ce2018-07-06 10:27:35 -0600970 """Test output to stdout"""
971 dtb_file = get_dtb_file('dtoc_test_simple.dts')
Simon Glass07ee48e2020-12-28 20:34:49 -0700972 with test_util.capture_sys_output() as (stdout, _):
Simon Glass6ca0c7a2020-12-28 20:34:48 -0700973 self.run_test(['struct'], dtb_file, None)
Simon Glass07ee48e2020-12-28 20:34:49 -0700974 self._check_strings(self.struct_text, stdout.getvalue())
Simon Glass961c1ce2018-07-06 10:27:35 -0600975
Simon Glassc3a310a82020-12-28 20:34:51 -0700976 def test_multi_to_file(self):
977 """Test output of multiple pieces to a single file"""
978 dtb_file = get_dtb_file('dtoc_test_simple.dts')
979 output = tools.GetOutputFilename('output')
Simon Glass4e8e8462020-12-28 20:34:52 -0700980 self.run_test(['all'], dtb_file, output)
Simon Glassc3a310a82020-12-28 20:34:51 -0700981 data = tools.ReadFile(output, binary=False)
Simon Glass3fa3bbb2021-02-03 06:01:14 -0700982 self._check_strings(self.decl_text + self.platdata_text +
983 self.struct_text, data)
Simon Glassc3a310a82020-12-28 20:34:51 -0700984
Simon Glassa60cabd2020-12-28 20:34:47 -0700985 def test_no_command(self):
Simon Glass961c1ce2018-07-06 10:27:35 -0600986 """Test running dtoc without a command"""
Simon Glassa60cabd2020-12-28 20:34:47 -0700987 with self.assertRaises(ValueError) as exc:
Walter Lozanoa324e412020-06-25 01:10:08 -0300988 self.run_test([], '', '')
Simon Glass961c1ce2018-07-06 10:27:35 -0600989 self.assertIn("Please specify a command: struct, platdata",
Simon Glassa60cabd2020-12-28 20:34:47 -0700990 str(exc.exception))
Simon Glass961c1ce2018-07-06 10:27:35 -0600991
Simon Glassa60cabd2020-12-28 20:34:47 -0700992 def test_bad_command(self):
Simon Glass961c1ce2018-07-06 10:27:35 -0600993 """Test running dtoc with an invalid command"""
994 dtb_file = get_dtb_file('dtoc_test_simple.dts')
995 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -0700996 with self.assertRaises(ValueError) as exc:
Simon Glass3fa3bbb2021-02-03 06:01:14 -0700997 self.run_test(['invalid-cmd'], dtb_file, output)
998 self.assertIn(
999 "Unknown command 'invalid-cmd': (use: decl, platdata, struct)",
1000 str(exc.exception))
Walter Lozanod82062b2020-07-28 19:06:23 -03001001
Simon Glass4e8e8462020-12-28 20:34:52 -07001002 def test_output_conflict(self):
1003 """Test a conflict between and output dirs and output file"""
1004 with self.assertRaises(ValueError) as exc:
Simon Glass3809ad92021-02-03 06:01:12 -07001005 dtb_platdata.run_steps(
1006 ['all'], None, False, 'out', ['cdir'], None, False,
1007 warning_disabled=True, scan=copy_scan())
Simon Glass4e8e8462020-12-28 20:34:52 -07001008 self.assertIn("Must specify either output or output_dirs, not both",
1009 str(exc.exception))
1010
1011 def test_output_dirs(self):
1012 """Test outputting files to a directory"""
1013 # Remove the directory so that files from other tests are not there
1014 tools._RemoveOutputDir()
1015 tools.PrepareOutputDir(None)
1016
1017 # This should create the .dts and .dtb in the output directory
1018 dtb_file = get_dtb_file('dtoc_test_simple.dts')
1019 outdir = tools.GetOutputDir()
1020 fnames = glob.glob(outdir + '/*')
1021 self.assertEqual(2, len(fnames))
1022
Simon Glass3809ad92021-02-03 06:01:12 -07001023 dtb_platdata.run_steps(
1024 ['all'], dtb_file, False, None, [outdir], None, False,
1025 warning_disabled=True, scan=copy_scan())
Simon Glass4e8e8462020-12-28 20:34:52 -07001026 fnames = glob.glob(outdir + '/*')
Simon Glass3fa3bbb2021-02-03 06:01:14 -07001027 self.assertEqual(5, len(fnames))
Simon Glass4e8e8462020-12-28 20:34:52 -07001028
1029 leafs = set(os.path.basename(fname) for fname in fnames)
1030 self.assertEqual(
Simon Glass3fa3bbb2021-02-03 06:01:14 -07001031 {'dt-structs-gen.h', 'source.dts', 'dt-plat.c', 'source.dtb',
1032 'dt-decl.h'},
Simon Glass4e8e8462020-12-28 20:34:52 -07001033 leafs)
Simon Glass047a4802021-02-03 06:01:00 -07001034
1035 def setup_process_test(self):
1036 """Set up a test of process_nodes()
1037
1038 This uses saved_scan but returns a deep copy of it, so it is safe to
1039 modify it in these tests
1040
1041 Returns:
1042 tuple:
1043 DtbPlatdata: object to test
1044 Scanner: scanner to use
1045 """
1046 dtb_file = get_dtb_file('dtoc_test_simple.dts')
1047 output = tools.GetOutputFilename('output')
1048
1049 # Take a copy before messing with it
Simon Glassc14fd0c2021-02-03 06:01:11 -07001050 scan = copy_scan()
Simon Glass047a4802021-02-03 06:01:00 -07001051 plat = dtb_platdata.DtbPlatdata(scan, dtb_file, False)
1052 plat.scan_dtb()
Simon Glassc14fd0c2021-02-03 06:01:11 -07001053 plat.scan_tree(False)
Simon Glass047a4802021-02-03 06:01:00 -07001054 plat.prepare_nodes()
1055 return plat, scan
1056
1057 def test_process_nodes(self):
1058 """Test processing nodes to add various info"""
1059 plat, scan = self.setup_process_test()
1060 plat.process_nodes(True)
1061
1062 i2c_node = plat._fdt.GetNode('/i2c@0')
1063 pmic_node = plat._fdt.GetNode('/i2c@0/pmic@9')
1064 pmic = scan._drivers['sandbox_pmic']
1065 i2c = scan._drivers['sandbox_i2c']
1066 self.assertEqual('DM_DEVICE_REF(pmic_at_9)', pmic_node.dev_ref)
1067 self.assertEqual(pmic, pmic_node.driver)
1068 self.assertEqual(i2c_node, pmic_node.parent)
1069 self.assertEqual(i2c, pmic_node.parent_driver)
1070
1071 # The pmic is the only child
1072 self.assertEqual(pmic_node.parent_seq, 0)
1073 self.assertEqual([pmic_node], i2c_node.child_devs)
1074
1075 # Start and end of the list should be the child_head
1076 ref = '&DM_DEVICE_REF(i2c_at_0)->child_head'
1077 self.assertEqual(
1078 {-1: ref, 0: '&DM_DEVICE_REF(pmic_at_9)->sibling_node', 1: ref},
1079 i2c_node.child_refs)
1080
1081 def test_process_nodes_bad_parent(self):
1082 # Pretend that i2c has a parent (the pmic) and delete that driver
1083 plat, scan = self.setup_process_test()
1084
1085 i2c_node = plat._fdt.GetNode('/i2c@0')
1086 pmic_node = plat._fdt.GetNode('/i2c@0/pmic@9')
1087 del scan._drivers['sandbox_pmic']
1088 i2c_node.parent = pmic_node
1089
1090 # Process twice, the second time to generate an exception
1091 plat.process_nodes(False)
1092 with self.assertRaises(ValueError) as exc:
1093 plat.process_nodes(True)
1094 self.assertIn(
1095 "Cannot parse/find parent driver 'sandbox_pmic' for 'sandbox_i2c",
1096 str(exc.exception))
1097
1098 def test_process_nodes_bad_node(self):
1099 plat, scan = self.setup_process_test()
1100
1101 # Now remove the pmic driver
1102 del scan._drivers['sandbox_pmic']
1103
1104 # Process twice, the second time to generate an exception
1105 plat.process_nodes(False)
1106 with self.assertRaises(ValueError) as exc:
1107 plat.process_nodes(True)
1108 self.assertIn("Cannot parse/find driver for 'sandbox_pmic",
1109 str(exc.exception))
Simon Glasseb3c2492021-02-03 06:01:01 -07001110
Simon Glass80d782c42021-02-03 06:01:10 -07001111 def test_process_nodes_bad_uclass(self):
1112 plat, scan = self.setup_process_test()
1113
1114 self.assertIn('UCLASS_I2C', scan._uclass)
1115 del scan._uclass['UCLASS_I2C']
1116 with self.assertRaises(ValueError) as exc:
1117 plat.process_nodes(True)
1118 self.assertIn("Cannot parse/find uclass 'UCLASS_I2C' for driver 'sandbox_i2c'",
1119 str(exc.exception))
1120
Simon Glasseb3c2492021-02-03 06:01:01 -07001121 def test_process_nodes_used(self):
1122 """Test processing nodes to add various info"""
1123 plat, scan = self.setup_process_test()
1124 plat.process_nodes(True)
1125
1126 pmic = scan._drivers['sandbox_pmic']
1127 self.assertTrue(pmic.used)
1128
1129 gpio = scan._drivers['sandbox_gpio']
1130 self.assertFalse(gpio.used)
Simon Glassbe88d2f2021-02-03 06:01:07 -07001131
1132 def test_alias_read(self):
1133 """Test obtaining aliases"""
1134 dtb_file = get_dtb_file('dtoc_test_inst.dts')
1135 output = tools.GetOutputFilename('output')
1136 plat = self.run_test(['struct'], dtb_file, output)
1137
1138 scan = plat._scan
1139 testfdt_node = plat._fdt.GetNode('/some-bus/test')
Simon Glass80d782c42021-02-03 06:01:10 -07001140 test0_node = plat._fdt.GetNode('/some-bus/test0')
Simon Glassbe88d2f2021-02-03 06:01:07 -07001141 self.assertIn('UCLASS_TEST_FDT', scan._uclass)
1142 uc = scan._uclass['UCLASS_TEST_FDT']
Simon Glass80d782c42021-02-03 06:01:10 -07001143 self.assertEqual({1: testfdt_node, 2: test0_node},
1144 uc.alias_num_to_node)
1145 self.assertEqual({'/some-bus/test': 1, '/some-bus/test0': 2},
1146 uc.alias_path_to_num)
Simon Glassbe88d2f2021-02-03 06:01:07 -07001147
1148 # Try adding an alias that doesn't exist
1149 self.assertFalse(scan.add_uclass_alias('fred', 3, None))
1150
1151 # Try adding an alias for a missing node
1152 self.assertIsNone(scan.add_uclass_alias('testfdt', 3, None))
1153
1154 def test_alias_read_bad(self):
1155 """Test invalid alias property name"""
1156 dtb_file = get_dtb_file('dtoc_test_alias_bad.dts')
1157 output = tools.GetOutputFilename('output')
1158 with self.assertRaises(ValueError) as exc:
1159 plat = self.run_test(['struct'], dtb_file, output)
1160 self.assertIn("Cannot decode alias 'i2c4-'", str(exc.exception))
1161
1162 def test_alias_read_bad_path(self):
1163 """Test alias pointing to a non-existent node"""
1164 # This line may produce a warning, so capture it:
1165 # Warning (alias_paths): /aliases:i2c4: aliases property is not a valid
1166 # node (/does/not/exist)
1167 dtb_file = get_dtb_file('dtoc_test_alias_bad_path.dts', True)
1168
1169 output = tools.GetOutputFilename('output')
1170 with self.assertRaises(ValueError) as exc:
1171 plat = self.run_test(['struct'], dtb_file, output)
1172 self.assertIn("Alias 'i2c4' path '/does/not/exist' not found",
1173 str(exc.exception))
1174
1175 def test_alias_read_bad_uclass(self):
1176 """Test alias for a uclass that doesn't exist"""
1177 dtb_file = get_dtb_file('dtoc_test_alias_bad_uc.dts')
1178 output = tools.GetOutputFilename('output')
1179 with test_util.capture_sys_output() as (stdout, _):
1180 plat = self.run_test(['struct'], dtb_file, output)
1181 self.assertEqual("Could not find uclass for alias 'other1'",
1182 stdout.getvalue().strip())
Simon Glassdf56e0b2021-02-03 06:01:09 -07001183
1184 def test_sequence(self):
1185 """Test assignment of sequence numnbers"""
1186 dtb_file = get_dtb_file('dtoc_test_inst.dts')
1187 output = tools.GetOutputFilename('output')
1188 plat = self.run_test(['struct'], dtb_file, output)
Simon Glass80d782c42021-02-03 06:01:10 -07001189
1190 scan = plat._scan
1191 testfdt = plat._fdt.GetNode('/some-bus/test')
1192 self.assertEqual(1, testfdt.seq)
1193 i2c = plat._fdt.GetNode('/i2c')
1194
1195 # For now this uclass is not compiled in, so no sequence is assigned
1196 self.assertEqual(4, i2c.seq)
1197 spl = plat._fdt.GetNode('/spl-test')
1198 self.assertEqual(0, spl.seq)
Simon Glassc14fd0c2021-02-03 06:01:11 -07001199
1200 def test_process_root(self):
1201 """Test assignment of sequence numnbers"""
1202 dtb_file = get_dtb_file('dtoc_test_simple.dts')
1203 output = tools.GetOutputFilename('output')
1204
1205 # Take a copy before messing with it
1206 scan = copy_scan()
1207 plat = dtb_platdata.DtbPlatdata(scan, dtb_file, False)
1208 plat.scan_dtb()
1209 root = plat._fdt.GetRoot()
1210
1211 plat.scan_tree(False)
1212 self.assertNotIn(root, plat._valid_nodes)
1213
1214 plat.scan_tree(True)
1215 self.assertIn(root, plat._valid_nodes)
1216 self.assertEqual('root_driver',
1217 scan.get_normalized_compat_name(root)[0])
Simon Glass3fa3bbb2021-02-03 06:01:14 -07001218
1219 def test_simple_inst(self):
1220 """Test output from some simple nodes with instantiate enabled"""
1221 dtb_file = get_dtb_file('dtoc_test_simple.dts')
1222 output = tools.GetOutputFilename('output')
1223
1224 self.run_test(['decl'], dtb_file, output, True)
1225 with open(output) as infile:
1226 data = infile.read()
1227
1228 self._check_strings(self.decl_text_inst, data)