blob: c6e33d3422784d38461a0511344b50a72b2d31cf [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 Glassbe749002021-02-03 06:01:15 -070051C_HEADER_PRE = '''/*
Simon Glasseb37e2d2017-11-12 21:52:17 -070052 * 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 */
Simon Glassbe749002021-02-03 06:01:15 -070057'''
Simon Glasseb37e2d2017-11-12 21:52:17 -070058
Simon Glassbe749002021-02-03 06:01:15 -070059C_HEADER = C_HEADER_PRE + '''
Simon Glass1d8364a2020-12-28 20:34:54 -070060/* Allow use of U_BOOT_DRVINFO() in this file */
Simon Glassbeddd7a2020-12-28 20:35:01 -070061#define DT_PLAT_C
Simon Glass4c73d7b2020-10-03 11:31:41 -060062
Simon Glasseb37e2d2017-11-12 21:52:17 -070063#include <common.h>
64#include <dm.h>
65#include <dt-structs.h>
66'''
67
Simon Glass768ff0a2021-02-03 06:00:51 -070068# Scanner saved from a previous run of the tests (to speed things up)
69saved_scan = None
70
Simon Glassa60cabd2020-12-28 20:34:47 -070071# This is a test so is allowed to access private things in the module it is
72# testing
73# pylint: disable=W0212
Simon Glass3bce93d2018-07-06 10:27:37 -060074
75def get_dtb_file(dts_fname, capture_stderr=False):
Simon Glass9d2eb922017-06-18 22:09:06 -060076 """Compile a .dts file to a .dtb
77
78 Args:
Simon Glassa60cabd2020-12-28 20:34:47 -070079 dts_fname (str): Filename of .dts file in the current directory
80 capture_stderr (bool): True to capture and discard stderr output
Simon Glass9d2eb922017-06-18 22:09:06 -060081
82 Returns:
Simon Glassa60cabd2020-12-28 20:34:47 -070083 str: Filename of compiled file in output directory
Simon Glass9d2eb922017-06-18 22:09:06 -060084 """
Simon Glass4f4b2402021-02-03 06:00:56 -070085 return fdt_util.EnsureCompiled(os.path.join(OUR_PATH, 'test', dts_fname),
Simon Glass3bce93d2018-07-06 10:27:37 -060086 capture_stderr=capture_stderr)
Simon Glass9d2eb922017-06-18 22:09:06 -060087
Simon Glass768ff0a2021-02-03 06:00:51 -070088
89def setup():
90 global saved_scan
91
92 # Disable warnings so that calls to get_normalized_compat_name() will not
93 # output things.
94 saved_scan = src_scan.Scanner(None, True, False)
95 saved_scan.scan_drivers()
96
97def copy_scan():
98 """Get a copy of saved_scan so that each test can start clean"""
99 return copy.deepcopy(saved_scan)
100
Simon Glass9d2eb922017-06-18 22:09:06 -0600101
102class TestDtoc(unittest.TestCase):
103 """Tests for dtoc"""
104 @classmethod
105 def setUpClass(cls):
106 tools.PrepareOutputDir(None)
Simon Glass7f5e2262020-07-07 21:32:06 -0600107 cls.maxDiff = None
Simon Glass9d2eb922017-06-18 22:09:06 -0600108
109 @classmethod
110 def tearDownClass(cls):
Simon Glassa60cabd2020-12-28 20:34:47 -0700111 tools.FinaliseOutputDir()
Simon Glass9d2eb922017-06-18 22:09:06 -0600112
Simon Glassa60cabd2020-12-28 20:34:47 -0700113 @staticmethod
114 def _write_python_string(fname, data):
Simon Glassc47c2b32018-07-06 10:27:25 -0600115 """Write a string with tabs expanded as done in this Python file
116
117 Args:
Simon Glassa60cabd2020-12-28 20:34:47 -0700118 fname (str): Filename to write to
119 data (str): Raw string to convert
Simon Glassc47c2b32018-07-06 10:27:25 -0600120 """
121 data = data.replace('\t', '\\t')
Simon Glassa60cabd2020-12-28 20:34:47 -0700122 with open(fname, 'w') as fout:
123 fout.write(data)
Simon Glassc47c2b32018-07-06 10:27:25 -0600124
Simon Glassa60cabd2020-12-28 20:34:47 -0700125 def _check_strings(self, expected, actual):
Simon Glassc47c2b32018-07-06 10:27:25 -0600126 """Check that a string matches its expected value
127
128 If the strings do not match, they are written to the /tmp directory in
129 the same Python format as is used here in the test. This allows for
130 easy comparison and update of the tests.
131
132 Args:
Simon Glassa60cabd2020-12-28 20:34:47 -0700133 expected (str): Expected string
134 actual (str): Actual string
Simon Glassc47c2b32018-07-06 10:27:25 -0600135 """
136 if expected != actual:
Simon Glassa60cabd2020-12-28 20:34:47 -0700137 self._write_python_string('/tmp/binman.expected', expected)
138 self._write_python_string('/tmp/binman.actual', actual)
Simon Glass61b88e52019-05-17 22:00:31 -0600139 print('Failures written to /tmp/binman.{expected,actual}')
Simon Glassa60cabd2020-12-28 20:34:47 -0700140 self.assertEqual(expected, actual)
Simon Glassc47c2b32018-07-06 10:27:25 -0600141
Simon Glassa60cabd2020-12-28 20:34:47 -0700142 @staticmethod
Simon Glass3809ad92021-02-03 06:01:12 -0700143 def run_test(args, dtb_file, output, instantiate=False):
Simon Glassa60cabd2020-12-28 20:34:47 -0700144 """Run a test using dtoc
Walter Lozanoa324e412020-06-25 01:10:08 -0300145
Simon Glassa60cabd2020-12-28 20:34:47 -0700146 Args:
147 args (list of str): List of arguments for dtoc
148 dtb_file (str): Filename of .dtb file
149 output (str): Filename of output file
Simon Glassbe88d2f2021-02-03 06:01:07 -0700150
151 Returns:
152 DtbPlatdata object
Simon Glassa60cabd2020-12-28 20:34:47 -0700153 """
Simon Glass80d782c42021-02-03 06:01:10 -0700154 # Make a copy of the 'scan' object, since it includes uclasses and
155 # drivers, which get updated during execution.
Simon Glass3809ad92021-02-03 06:01:12 -0700156 return dtb_platdata.run_steps(
157 args, dtb_file, False, output, [], None, instantiate,
158 warning_disabled=True, scan=copy_scan())
Walter Lozanoa324e412020-06-25 01:10:08 -0300159
Simon Glass9d2eb922017-06-18 22:09:06 -0600160 def test_name(self):
161 """Test conversion of device tree names to C identifiers"""
162 self.assertEqual('serial_at_0x12', conv_name_to_c('serial@0x12'))
163 self.assertEqual('vendor_clock_frequency',
164 conv_name_to_c('vendor,clock-frequency'))
165 self.assertEqual('rockchip_rk3399_sdhci_5_1',
166 conv_name_to_c('rockchip,rk3399-sdhci-5.1'))
167
168 def test_tab_to(self):
169 """Test operation of tab_to() function"""
170 self.assertEqual('fred ', tab_to(0, 'fred'))
171 self.assertEqual('fred\t', tab_to(1, 'fred'))
172 self.assertEqual('fred was here ', tab_to(1, 'fred was here'))
173 self.assertEqual('fred was here\t\t', tab_to(3, 'fred was here'))
174 self.assertEqual('exactly8 ', tab_to(1, 'exactly8'))
175 self.assertEqual('exactly8\t', tab_to(2, 'exactly8'))
176
177 def test_get_value(self):
178 """Test operation of get_value() function"""
179 self.assertEqual('0x45',
Simon Glassc9a032c2020-11-08 20:36:17 -0700180 get_value(fdt.Type.INT, struct.pack('>I', 0x45)))
Simon Glass9d2eb922017-06-18 22:09:06 -0600181 self.assertEqual('0x45',
Simon Glassc9a032c2020-11-08 20:36:17 -0700182 get_value(fdt.Type.BYTE, struct.pack('<I', 0x45)))
Simon Glass9d2eb922017-06-18 22:09:06 -0600183 self.assertEqual('0x0',
Simon Glassc9a032c2020-11-08 20:36:17 -0700184 get_value(fdt.Type.BYTE, struct.pack('>I', 0x45)))
185 self.assertEqual('"test"', get_value(fdt.Type.STRING, 'test'))
186 self.assertEqual('true', get_value(fdt.Type.BOOL, None))
Simon Glass9d2eb922017-06-18 22:09:06 -0600187
188 def test_get_compat_name(self):
189 """Test operation of get_compat_name() function"""
190 Prop = collections.namedtuple('Prop', ['value'])
191 Node = collections.namedtuple('Node', ['props'])
192
193 prop = Prop(['rockchip,rk3399-sdhci-5.1', 'arasan,sdhci-5.1'])
194 node = Node({'compatible': prop})
Walter Lozano5fe734c2020-07-23 00:22:03 -0300195 self.assertEqual((['rockchip_rk3399_sdhci_5_1', 'arasan_sdhci_5_1']),
Simon Glass9d2eb922017-06-18 22:09:06 -0600196 get_compat_name(node))
197
198 prop = Prop(['rockchip,rk3399-sdhci-5.1'])
199 node = Node({'compatible': prop})
Walter Lozano5fe734c2020-07-23 00:22:03 -0300200 self.assertEqual((['rockchip_rk3399_sdhci_5_1']),
Simon Glass9d2eb922017-06-18 22:09:06 -0600201 get_compat_name(node))
202
203 prop = Prop(['rockchip,rk3399-sdhci-5.1', 'arasan,sdhci-5.1', 'third'])
204 node = Node({'compatible': prop})
Walter Lozano5fe734c2020-07-23 00:22:03 -0300205 self.assertEqual((['rockchip_rk3399_sdhci_5_1',
Simon Glassa60cabd2020-12-28 20:34:47 -0700206 'arasan_sdhci_5_1', 'third']),
Simon Glass9d2eb922017-06-18 22:09:06 -0600207 get_compat_name(node))
208
209 def test_empty_file(self):
210 """Test output from a device tree file with no nodes"""
211 dtb_file = get_dtb_file('dtoc_test_empty.dts')
212 output = tools.GetOutputFilename('output')
Simon Glass768ff0a2021-02-03 06:00:51 -0700213
214 # Run this one without saved_scan to complete test coverage
Simon Glass3809ad92021-02-03 06:01:12 -0700215 dtb_platdata.run_steps(['struct'], dtb_file, False, output, [], None,
216 False)
Simon Glass9d2eb922017-06-18 22:09:06 -0600217 with open(output) as infile:
218 lines = infile.read().splitlines()
Simon Glasseb37e2d2017-11-12 21:52:17 -0700219 self.assertEqual(HEADER.splitlines(), lines)
Simon Glass9d2eb922017-06-18 22:09:06 -0600220
Walter Lozanoa324e412020-06-25 01:10:08 -0300221 self.run_test(['platdata'], dtb_file, output)
Simon Glass9d2eb922017-06-18 22:09:06 -0600222 with open(output) as infile:
223 lines = infile.read().splitlines()
Simon Glass2500de22020-12-28 20:35:05 -0700224 self.assertEqual(C_HEADER.splitlines() + [''], lines)
Simon Glass9d2eb922017-06-18 22:09:06 -0600225
Simon Glass3fa3bbb2021-02-03 06:01:14 -0700226 decl_text = DECL_HEADER + '''
227#include <dm/device-internal.h>
228#include <dm/uclass-internal.h>
229
230/* driver declarations - these allow DM_DRIVER_GET() to be used */
231DM_DRIVER_DECL(sandbox_i2c);
232DM_DRIVER_DECL(sandbox_pmic);
233DM_DRIVER_DECL(sandbox_spl_test);
234DM_DRIVER_DECL(sandbox_spl_test);
235DM_DRIVER_DECL(sandbox_spl_test);
236
237/* uclass driver declarations - needed for DM_UCLASS_DRIVER_REF() */
238DM_UCLASS_DRIVER_DECL(i2c);
239DM_UCLASS_DRIVER_DECL(misc);
240DM_UCLASS_DRIVER_DECL(pmic);
241'''
242 decl_text_inst = DECL_HEADER + '''
243#include <dm/device-internal.h>
244#include <dm/uclass-internal.h>
245
246/* driver declarations - these allow DM_DRIVER_GET() to be used */
247DM_DRIVER_DECL(sandbox_i2c);
248DM_DRIVER_DECL(sandbox_pmic);
249DM_DRIVER_DECL(root_driver);
250DM_DRIVER_DECL(sandbox_spl_test);
251DM_DRIVER_DECL(sandbox_spl_test);
252DM_DRIVER_DECL(sandbox_spl_test);
253
254/* device declarations - these allow DM_DEVICE_REF() to be used */
255DM_DEVICE_DECL(i2c_at_0);
256DM_DEVICE_DECL(pmic_at_9);
257DM_DEVICE_DECL(root);
258DM_DEVICE_DECL(spl_test);
259DM_DEVICE_DECL(spl_test2);
260DM_DEVICE_DECL(spl_test3);
261
262/* uclass driver declarations - needed for DM_UCLASS_DRIVER_REF() */
263DM_UCLASS_DRIVER_DECL(i2c);
264DM_UCLASS_DRIVER_DECL(misc);
265DM_UCLASS_DRIVER_DECL(pmic);
266DM_UCLASS_DRIVER_DECL(root);
267
268/* uclass declarations - needed for DM_UCLASS_REF() */
269DM_UCLASS_DECL(i2c);
270DM_UCLASS_DECL(misc);
271DM_UCLASS_DECL(pmic);
272DM_UCLASS_DECL(root);
273'''
Simon Glass07ee48e2020-12-28 20:34:49 -0700274 struct_text = HEADER + '''
Simon Glass32a8d222021-02-03 06:00:57 -0700275struct dtd_sandbox_i2c {
Simon Glass90e5f0a2017-08-29 14:15:51 -0600276};
Simon Glass32a8d222021-02-03 06:00:57 -0700277struct dtd_sandbox_pmic {
Simon Glass90e5f0a2017-08-29 14:15:51 -0600278\tbool\t\tlow_power;
279\tfdt64_t\t\treg[2];
280};
Simon Glass9d2eb922017-06-18 22:09:06 -0600281struct dtd_sandbox_spl_test {
Simon Glass7f5e2262020-07-07 21:32:06 -0600282\tconst char * acpi_name;
Simon Glass9d2eb922017-06-18 22:09:06 -0600283\tbool\t\tboolval;
284\tunsigned char\tbytearray[3];
285\tunsigned char\tbyteval;
286\tfdt32_t\t\tintarray[4];
287\tfdt32_t\t\tintval;
288\tunsigned char\tlongbytearray[9];
Simon Glass9c526332018-07-06 10:27:28 -0600289\tunsigned char\tnotstring[5];
Simon Glass9d2eb922017-06-18 22:09:06 -0600290\tconst char *\tstringarray[3];
291\tconst char *\tstringval;
292};
Simon Glass07ee48e2020-12-28 20:34:49 -0700293'''
Simon Glass07ee48e2020-12-28 20:34:49 -0700294 platdata_text = C_HEADER + '''
Simon Glassbe749002021-02-03 06:01:15 -0700295/*
296 * Node /i2c@0 index 0
297 * driver sandbox_i2c parent None
298 */
Simon Glass32a8d222021-02-03 06:00:57 -0700299static struct dtd_sandbox_i2c dtv_i2c_at_0 = {
Simon Glass192f8132020-10-03 11:31:25 -0600300};
Simon Glass1d8364a2020-12-28 20:34:54 -0700301U_BOOT_DRVINFO(i2c_at_0) = {
Simon Glass32a8d222021-02-03 06:00:57 -0700302\t.name\t\t= "sandbox_i2c",
Simon Glass71fa5b42020-12-03 16:55:18 -0700303\t.plat\t= &dtv_i2c_at_0,
Simon Glass39edb952020-12-03 16:55:19 -0700304\t.plat_size\t= sizeof(dtv_i2c_at_0),
Simon Glass36b15e22020-10-03 11:31:35 -0600305\t.parent_idx\t= -1,
Simon Glass192f8132020-10-03 11:31:25 -0600306};
307
Simon Glassbe749002021-02-03 06:01:15 -0700308/*
309 * Node /i2c@0/pmic@9 index 1
310 * driver sandbox_pmic parent sandbox_i2c
311 */
Simon Glass32a8d222021-02-03 06:00:57 -0700312static struct dtd_sandbox_pmic dtv_pmic_at_9 = {
Simon Glass192f8132020-10-03 11:31:25 -0600313\t.low_power\t\t= true,
314\t.reg\t\t\t= {0x9, 0x0},
315};
Simon Glass1d8364a2020-12-28 20:34:54 -0700316U_BOOT_DRVINFO(pmic_at_9) = {
Simon Glass32a8d222021-02-03 06:00:57 -0700317\t.name\t\t= "sandbox_pmic",
Simon Glass71fa5b42020-12-03 16:55:18 -0700318\t.plat\t= &dtv_pmic_at_9,
Simon Glass39edb952020-12-03 16:55:19 -0700319\t.plat_size\t= sizeof(dtv_pmic_at_9),
Simon Glass36b15e22020-10-03 11:31:35 -0600320\t.parent_idx\t= 0,
Simon Glass192f8132020-10-03 11:31:25 -0600321};
322
Simon Glassbe749002021-02-03 06:01:15 -0700323/*
324 * Node /spl-test index 2
325 * driver sandbox_spl_test parent None
326 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300327static struct dtd_sandbox_spl_test dtv_spl_test = {
Simon Glassc82de562019-05-17 22:00:32 -0600328\t.boolval\t\t= true,
Simon Glass9d2eb922017-06-18 22:09:06 -0600329\t.bytearray\t\t= {0x6, 0x0, 0x0},
330\t.byteval\t\t= 0x5,
Simon Glassc82de562019-05-17 22:00:32 -0600331\t.intarray\t\t= {0x2, 0x3, 0x4, 0x0},
Simon Glass9d2eb922017-06-18 22:09:06 -0600332\t.intval\t\t\t= 0x1,
Simon Glass131e0b02017-08-29 14:15:49 -0600333\t.longbytearray\t\t= {0x9, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf, 0x10,
334\t\t0x11},
Simon Glassc82de562019-05-17 22:00:32 -0600335\t.notstring\t\t= {0x20, 0x21, 0x22, 0x10, 0x0},
Simon Glass9d2eb922017-06-18 22:09:06 -0600336\t.stringarray\t\t= {"multi-word", "message", ""},
Simon Glassc82de562019-05-17 22:00:32 -0600337\t.stringval\t\t= "message",
Simon Glass9d2eb922017-06-18 22:09:06 -0600338};
Simon Glass1d8364a2020-12-28 20:34:54 -0700339U_BOOT_DRVINFO(spl_test) = {
Simon Glass9d2eb922017-06-18 22:09:06 -0600340\t.name\t\t= "sandbox_spl_test",
Simon Glass71fa5b42020-12-03 16:55:18 -0700341\t.plat\t= &dtv_spl_test,
Simon Glass39edb952020-12-03 16:55:19 -0700342\t.plat_size\t= sizeof(dtv_spl_test),
Simon Glass36b15e22020-10-03 11:31:35 -0600343\t.parent_idx\t= -1,
Simon Glass9d2eb922017-06-18 22:09:06 -0600344};
345
Simon Glassbe749002021-02-03 06:01:15 -0700346/*
347 * Node /spl-test2 index 3
348 * driver sandbox_spl_test parent None
349 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300350static struct dtd_sandbox_spl_test dtv_spl_test2 = {
Simon Glass7f5e2262020-07-07 21:32:06 -0600351\t.acpi_name\t\t= "\\\\_SB.GPO0",
Simon Glass9d2eb922017-06-18 22:09:06 -0600352\t.bytearray\t\t= {0x1, 0x23, 0x34},
353\t.byteval\t\t= 0x8,
Simon Glassc82de562019-05-17 22:00:32 -0600354\t.intarray\t\t= {0x5, 0x0, 0x0, 0x0},
Simon Glass9d2eb922017-06-18 22:09:06 -0600355\t.intval\t\t\t= 0x3,
Simon Glass8034e4d2020-10-03 11:31:27 -0600356\t.longbytearray\t\t= {0x9, 0xa, 0xb, 0xc, 0x0, 0x0, 0x0, 0x0,
Simon Glass131e0b02017-08-29 14:15:49 -0600357\t\t0x0},
Simon Glass9d2eb922017-06-18 22:09:06 -0600358\t.stringarray\t\t= {"another", "multi-word", "message"},
Simon Glassc82de562019-05-17 22:00:32 -0600359\t.stringval\t\t= "message2",
Simon Glass9d2eb922017-06-18 22:09:06 -0600360};
Simon Glass1d8364a2020-12-28 20:34:54 -0700361U_BOOT_DRVINFO(spl_test2) = {
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_test2,
Simon Glass39edb952020-12-03 16:55:19 -0700364\t.plat_size\t= sizeof(dtv_spl_test2),
Simon Glass36b15e22020-10-03 11:31:35 -0600365\t.parent_idx\t= -1,
Simon Glass9d2eb922017-06-18 22:09:06 -0600366};
367
Simon Glassbe749002021-02-03 06:01:15 -0700368/*
369 * Node /spl-test3 index 4
370 * driver sandbox_spl_test parent None
371 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300372static struct dtd_sandbox_spl_test dtv_spl_test3 = {
Simon Glass8034e4d2020-10-03 11:31:27 -0600373\t.longbytearray\t\t= {0x9, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf, 0x10,
374\t\t0x0},
Simon Glass9d2eb922017-06-18 22:09:06 -0600375\t.stringarray\t\t= {"one", "", ""},
376};
Simon Glass1d8364a2020-12-28 20:34:54 -0700377U_BOOT_DRVINFO(spl_test3) = {
Simon Glass9d2eb922017-06-18 22:09:06 -0600378\t.name\t\t= "sandbox_spl_test",
Simon Glass71fa5b42020-12-03 16:55:18 -0700379\t.plat\t= &dtv_spl_test3,
Simon Glass39edb952020-12-03 16:55:19 -0700380\t.plat_size\t= sizeof(dtv_spl_test3),
Simon Glass36b15e22020-10-03 11:31:35 -0600381\t.parent_idx\t= -1,
Simon Glass9d2eb922017-06-18 22:09:06 -0600382};
383
Simon Glass2500de22020-12-28 20:35:05 -0700384'''
Simon Glass07ee48e2020-12-28 20:34:49 -0700385
386 def test_simple(self):
387 """Test output from some simple nodes with various types of data"""
388 dtb_file = get_dtb_file('dtoc_test_simple.dts')
389 output = tools.GetOutputFilename('output')
390 self.run_test(['struct'], dtb_file, output)
391 with open(output) as infile:
392 data = infile.read()
393
394 self._check_strings(self.struct_text, data)
395
396 self.run_test(['platdata'], dtb_file, output)
397 with open(output) as infile:
398 data = infile.read()
399
400 self._check_strings(self.platdata_text, data)
Simon Glass9d2eb922017-06-18 22:09:06 -0600401
Simon Glass3fa3bbb2021-02-03 06:01:14 -0700402 self.run_test(['decl'], dtb_file, output)
403 with open(output) as infile:
404 data = infile.read()
405
406 self._check_strings(self.decl_text, data)
407
Simon Glass4e8e8462020-12-28 20:34:52 -0700408 # Try the 'all' command
409 self.run_test(['all'], dtb_file, output)
410 data = tools.ReadFile(output, binary=False)
Simon Glass3fa3bbb2021-02-03 06:01:14 -0700411 self._check_strings(self.decl_text + self.platdata_text +
412 self.struct_text, data)
Simon Glass4e8e8462020-12-28 20:34:52 -0700413
Walter Lozanoe675d962020-07-03 08:07:17 -0300414 def test_driver_alias(self):
415 """Test output from a device tree file with a driver alias"""
416 dtb_file = get_dtb_file('dtoc_test_driver_alias.dts')
417 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300418 self.run_test(['struct'], dtb_file, output)
Walter Lozanoe675d962020-07-03 08:07:17 -0300419 with open(output) as infile:
420 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700421 self._check_strings(HEADER + '''
Walter Lozanoe675d962020-07-03 08:07:17 -0300422struct dtd_sandbox_gpio {
423\tconst char *\tgpio_bank_name;
424\tbool\t\tgpio_controller;
425\tfdt32_t\t\tsandbox_gpio_count;
426};
Walter Lozanoe675d962020-07-03 08:07:17 -0300427''', data)
428
Walter Lozanoa324e412020-06-25 01:10:08 -0300429 self.run_test(['platdata'], dtb_file, output)
Walter Lozanoe675d962020-07-03 08:07:17 -0300430 with open(output) as infile:
431 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700432 self._check_strings(C_HEADER + '''
Simon Glassbe749002021-02-03 06:01:15 -0700433/*
434 * Node /gpios@0 index 0
435 * driver sandbox_gpio parent None
436 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300437static struct dtd_sandbox_gpio dtv_gpios_at_0 = {
Walter Lozanoe675d962020-07-03 08:07:17 -0300438\t.gpio_bank_name\t\t= "a",
439\t.gpio_controller\t= true,
440\t.sandbox_gpio_count\t= 0x14,
441};
Simon Glass1d8364a2020-12-28 20:34:54 -0700442U_BOOT_DRVINFO(gpios_at_0) = {
Walter Lozanoe675d962020-07-03 08:07:17 -0300443\t.name\t\t= "sandbox_gpio",
Simon Glass71fa5b42020-12-03 16:55:18 -0700444\t.plat\t= &dtv_gpios_at_0,
Simon Glass39edb952020-12-03 16:55:19 -0700445\t.plat_size\t= sizeof(dtv_gpios_at_0),
Simon Glass36b15e22020-10-03 11:31:35 -0600446\t.parent_idx\t= -1,
Walter Lozanoe675d962020-07-03 08:07:17 -0300447};
448
449''', data)
450
Walter Lozanoa324e412020-06-25 01:10:08 -0300451 def test_invalid_driver(self):
452 """Test output from a device tree file with an invalid driver"""
453 dtb_file = get_dtb_file('dtoc_test_invalid_driver.dts')
454 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -0700455 with test_util.capture_sys_output() as _:
Simon Glass3809ad92021-02-03 06:01:12 -0700456 dtb_platdata.run_steps(
457 ['struct'], dtb_file, False, output, [], None, False,
458 scan=copy_scan())
Walter Lozanoa324e412020-06-25 01:10:08 -0300459 with open(output) as infile:
460 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700461 self._check_strings(HEADER + '''
Walter Lozanoa324e412020-06-25 01:10:08 -0300462struct dtd_invalid {
463};
464''', data)
465
Simon Glassa60cabd2020-12-28 20:34:47 -0700466 with test_util.capture_sys_output() as _:
Simon Glass3809ad92021-02-03 06:01:12 -0700467 dtb_platdata.run_steps(
468 ['platdata'], dtb_file, False, output, [], None, False,
469 scan=copy_scan())
Walter Lozanoa324e412020-06-25 01:10:08 -0300470 with open(output) as infile:
471 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700472 self._check_strings(C_HEADER + '''
Simon Glass192f8132020-10-03 11:31:25 -0600473/* Node /spl-test index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300474static struct dtd_invalid dtv_spl_test = {
Walter Lozanoa324e412020-06-25 01:10:08 -0300475};
Simon Glass1d8364a2020-12-28 20:34:54 -0700476U_BOOT_DRVINFO(spl_test) = {
Walter Lozanoa324e412020-06-25 01:10:08 -0300477\t.name\t\t= "invalid",
Simon Glass71fa5b42020-12-03 16:55:18 -0700478\t.plat\t= &dtv_spl_test,
Simon Glass39edb952020-12-03 16:55:19 -0700479\t.plat_size\t= sizeof(dtv_spl_test),
Simon Glass36b15e22020-10-03 11:31:35 -0600480\t.parent_idx\t= -1,
Walter Lozanoa324e412020-06-25 01:10:08 -0300481};
482
483''', data)
484
Simon Glass9d2eb922017-06-18 22:09:06 -0600485 def test_phandle(self):
486 """Test output from a node containing a phandle reference"""
487 dtb_file = get_dtb_file('dtoc_test_phandle.dts')
488 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300489 self.run_test(['struct'], dtb_file, output)
Simon Glass9d2eb922017-06-18 22:09:06 -0600490 with open(output) as infile:
491 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700492 self._check_strings(HEADER + '''
Simon Glass9d2eb922017-06-18 22:09:06 -0600493struct dtd_source {
Simon Glass3deeb472017-08-29 14:15:59 -0600494\tstruct phandle_2_arg clocks[4];
Simon Glass9d2eb922017-06-18 22:09:06 -0600495};
496struct dtd_target {
497\tfdt32_t\t\tintval;
498};
499''', data)
500
Walter Lozanoa324e412020-06-25 01:10:08 -0300501 self.run_test(['platdata'], dtb_file, output)
Simon Glass9d2eb922017-06-18 22:09:06 -0600502 with open(output) as infile:
503 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700504 self._check_strings(C_HEADER + '''
Simon Glass192f8132020-10-03 11:31:25 -0600505/* Node /phandle2-target index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300506static struct dtd_target dtv_phandle2_target = {
Simon Glass3deeb472017-08-29 14:15:59 -0600507\t.intval\t\t\t= 0x1,
508};
Simon Glass1d8364a2020-12-28 20:34:54 -0700509U_BOOT_DRVINFO(phandle2_target) = {
Simon Glass3deeb472017-08-29 14:15:59 -0600510\t.name\t\t= "target",
Simon Glass71fa5b42020-12-03 16:55:18 -0700511\t.plat\t= &dtv_phandle2_target,
Simon Glass39edb952020-12-03 16:55:19 -0700512\t.plat_size\t= sizeof(dtv_phandle2_target),
Simon Glass36b15e22020-10-03 11:31:35 -0600513\t.parent_idx\t= -1,
Simon Glass3deeb472017-08-29 14:15:59 -0600514};
515
Simon Glass192f8132020-10-03 11:31:25 -0600516/* Node /phandle3-target index 1 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300517static struct dtd_target dtv_phandle3_target = {
Simon Glass3deeb472017-08-29 14:15:59 -0600518\t.intval\t\t\t= 0x2,
519};
Simon Glass1d8364a2020-12-28 20:34:54 -0700520U_BOOT_DRVINFO(phandle3_target) = {
Simon Glass3deeb472017-08-29 14:15:59 -0600521\t.name\t\t= "target",
Simon Glass71fa5b42020-12-03 16:55:18 -0700522\t.plat\t= &dtv_phandle3_target,
Simon Glass39edb952020-12-03 16:55:19 -0700523\t.plat_size\t= sizeof(dtv_phandle3_target),
Simon Glass36b15e22020-10-03 11:31:35 -0600524\t.parent_idx\t= -1,
Simon Glass3deeb472017-08-29 14:15:59 -0600525};
526
Simon Glass192f8132020-10-03 11:31:25 -0600527/* Node /phandle-source index 2 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300528static struct dtd_source dtv_phandle_source = {
Simon Glassd0cd0752017-08-29 14:15:57 -0600529\t.clocks\t\t\t= {
Simon Glass5792f4b2020-10-03 11:31:40 -0600530\t\t\t{4, {}},
531\t\t\t{0, {11}},
532\t\t\t{1, {12, 13}},
533\t\t\t{4, {}},},
Simon Glass9d2eb922017-06-18 22:09:06 -0600534};
Simon Glass1d8364a2020-12-28 20:34:54 -0700535U_BOOT_DRVINFO(phandle_source) = {
Simon Glass9d2eb922017-06-18 22:09:06 -0600536\t.name\t\t= "source",
Simon Glass71fa5b42020-12-03 16:55:18 -0700537\t.plat\t= &dtv_phandle_source,
Simon Glass39edb952020-12-03 16:55:19 -0700538\t.plat_size\t= sizeof(dtv_phandle_source),
Simon Glass36b15e22020-10-03 11:31:35 -0600539\t.parent_idx\t= -1,
Simon Glass9d2eb922017-06-18 22:09:06 -0600540};
541
Simon Glass192f8132020-10-03 11:31:25 -0600542/* Node /phandle-source2 index 3 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300543static struct dtd_source dtv_phandle_source2 = {
Simon Glass609e2b12018-07-06 10:27:31 -0600544\t.clocks\t\t\t= {
Simon Glass5792f4b2020-10-03 11:31:40 -0600545\t\t\t{4, {}},},
Simon Glass609e2b12018-07-06 10:27:31 -0600546};
Simon Glass1d8364a2020-12-28 20:34:54 -0700547U_BOOT_DRVINFO(phandle_source2) = {
Simon Glass609e2b12018-07-06 10:27:31 -0600548\t.name\t\t= "source",
Simon Glass71fa5b42020-12-03 16:55:18 -0700549\t.plat\t= &dtv_phandle_source2,
Simon Glass39edb952020-12-03 16:55:19 -0700550\t.plat_size\t= sizeof(dtv_phandle_source2),
Simon Glass36b15e22020-10-03 11:31:35 -0600551\t.parent_idx\t= -1,
Simon Glass609e2b12018-07-06 10:27:31 -0600552};
553
Simon Glass16382ce2020-12-28 20:35:04 -0700554/* Node /phandle-target index 4 */
555static struct dtd_target dtv_phandle_target = {
556\t.intval\t\t\t= 0x0,
557};
558U_BOOT_DRVINFO(phandle_target) = {
559\t.name\t\t= "target",
560\t.plat\t= &dtv_phandle_target,
561\t.plat_size\t= sizeof(dtv_phandle_target),
562\t.parent_idx\t= -1,
563};
564
Simon Glass9d2eb922017-06-18 22:09:06 -0600565''', data)
566
Simon Glass961c1ce2018-07-06 10:27:35 -0600567 def test_phandle_single(self):
568 """Test output from a node containing a phandle reference"""
569 dtb_file = get_dtb_file('dtoc_test_phandle_single.dts')
570 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300571 self.run_test(['struct'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -0600572 with open(output) as infile:
573 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700574 self._check_strings(HEADER + '''
Simon Glass961c1ce2018-07-06 10:27:35 -0600575struct dtd_source {
576\tstruct phandle_0_arg clocks[1];
577};
578struct dtd_target {
579\tfdt32_t\t\tintval;
580};
581''', data)
582
583 def test_phandle_reorder(self):
584 """Test that phandle targets are generated before their references"""
585 dtb_file = get_dtb_file('dtoc_test_phandle_reorder.dts')
586 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300587 self.run_test(['platdata'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -0600588 with open(output) as infile:
589 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700590 self._check_strings(C_HEADER + '''
Simon Glass192f8132020-10-03 11:31:25 -0600591/* Node /phandle-source2 index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300592static struct dtd_source dtv_phandle_source2 = {
Simon Glass961c1ce2018-07-06 10:27:35 -0600593\t.clocks\t\t\t= {
Simon Glass5792f4b2020-10-03 11:31:40 -0600594\t\t\t{1, {}},},
Simon Glass961c1ce2018-07-06 10:27:35 -0600595};
Simon Glass1d8364a2020-12-28 20:34:54 -0700596U_BOOT_DRVINFO(phandle_source2) = {
Simon Glass961c1ce2018-07-06 10:27:35 -0600597\t.name\t\t= "source",
Simon Glass71fa5b42020-12-03 16:55:18 -0700598\t.plat\t= &dtv_phandle_source2,
Simon Glass39edb952020-12-03 16:55:19 -0700599\t.plat_size\t= sizeof(dtv_phandle_source2),
Simon Glass36b15e22020-10-03 11:31:35 -0600600\t.parent_idx\t= -1,
Simon Glass961c1ce2018-07-06 10:27:35 -0600601};
602
Simon Glass16382ce2020-12-28 20:35:04 -0700603/* Node /phandle-target index 1 */
604static struct dtd_target dtv_phandle_target = {
605};
606U_BOOT_DRVINFO(phandle_target) = {
607\t.name\t\t= "target",
608\t.plat\t= &dtv_phandle_target,
609\t.plat_size\t= sizeof(dtv_phandle_target),
610\t.parent_idx\t= -1,
611};
612
Simon Glass961c1ce2018-07-06 10:27:35 -0600613''', data)
614
Walter Lozano5541fc02020-06-25 01:10:17 -0300615 def test_phandle_cd_gpio(self):
616 """Test that phandle targets are generated when unsing cd-gpios"""
617 dtb_file = get_dtb_file('dtoc_test_phandle_cd_gpios.dts')
618 output = tools.GetOutputFilename('output')
Simon Glass3809ad92021-02-03 06:01:12 -0700619 dtb_platdata.run_steps(
620 ['platdata'], dtb_file, False, output, [], None, False,
621 warning_disabled=True, scan=copy_scan())
Walter Lozano5541fc02020-06-25 01:10:17 -0300622 with open(output) as infile:
623 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700624 self._check_strings(C_HEADER + '''
Simon Glass192f8132020-10-03 11:31:25 -0600625/* Node /phandle2-target index 0 */
Walter Lozano5541fc02020-06-25 01:10:17 -0300626static struct dtd_target dtv_phandle2_target = {
627\t.intval\t\t\t= 0x1,
628};
Simon Glass1d8364a2020-12-28 20:34:54 -0700629U_BOOT_DRVINFO(phandle2_target) = {
Walter Lozano5541fc02020-06-25 01:10:17 -0300630\t.name\t\t= "target",
Simon Glass71fa5b42020-12-03 16:55:18 -0700631\t.plat\t= &dtv_phandle2_target,
Simon Glass39edb952020-12-03 16:55:19 -0700632\t.plat_size\t= sizeof(dtv_phandle2_target),
Simon Glass36b15e22020-10-03 11:31:35 -0600633\t.parent_idx\t= -1,
Walter Lozano5541fc02020-06-25 01:10:17 -0300634};
635
Simon Glass192f8132020-10-03 11:31:25 -0600636/* Node /phandle3-target index 1 */
Walter Lozano5541fc02020-06-25 01:10:17 -0300637static struct dtd_target dtv_phandle3_target = {
638\t.intval\t\t\t= 0x2,
639};
Simon Glass1d8364a2020-12-28 20:34:54 -0700640U_BOOT_DRVINFO(phandle3_target) = {
Walter Lozano5541fc02020-06-25 01:10:17 -0300641\t.name\t\t= "target",
Simon Glass71fa5b42020-12-03 16:55:18 -0700642\t.plat\t= &dtv_phandle3_target,
Simon Glass39edb952020-12-03 16:55:19 -0700643\t.plat_size\t= sizeof(dtv_phandle3_target),
Simon Glass36b15e22020-10-03 11:31:35 -0600644\t.parent_idx\t= -1,
Walter Lozano5541fc02020-06-25 01:10:17 -0300645};
646
Simon Glass192f8132020-10-03 11:31:25 -0600647/* Node /phandle-source index 2 */
Walter Lozano5541fc02020-06-25 01:10:17 -0300648static struct dtd_source dtv_phandle_source = {
649\t.cd_gpios\t\t= {
Simon Glass5792f4b2020-10-03 11:31:40 -0600650\t\t\t{4, {}},
651\t\t\t{0, {11}},
652\t\t\t{1, {12, 13}},
653\t\t\t{4, {}},},
Walter Lozano5541fc02020-06-25 01:10:17 -0300654};
Simon Glass1d8364a2020-12-28 20:34:54 -0700655U_BOOT_DRVINFO(phandle_source) = {
Walter Lozano5541fc02020-06-25 01:10:17 -0300656\t.name\t\t= "source",
Simon Glass71fa5b42020-12-03 16:55:18 -0700657\t.plat\t= &dtv_phandle_source,
Simon Glass39edb952020-12-03 16:55:19 -0700658\t.plat_size\t= sizeof(dtv_phandle_source),
Simon Glass36b15e22020-10-03 11:31:35 -0600659\t.parent_idx\t= -1,
Walter Lozano5541fc02020-06-25 01:10:17 -0300660};
661
Simon Glass192f8132020-10-03 11:31:25 -0600662/* Node /phandle-source2 index 3 */
Walter Lozano5541fc02020-06-25 01:10:17 -0300663static struct dtd_source dtv_phandle_source2 = {
664\t.cd_gpios\t\t= {
Simon Glass5792f4b2020-10-03 11:31:40 -0600665\t\t\t{4, {}},},
Walter Lozano5541fc02020-06-25 01:10:17 -0300666};
Simon Glass1d8364a2020-12-28 20:34:54 -0700667U_BOOT_DRVINFO(phandle_source2) = {
Walter Lozano5541fc02020-06-25 01:10:17 -0300668\t.name\t\t= "source",
Simon Glass71fa5b42020-12-03 16:55:18 -0700669\t.plat\t= &dtv_phandle_source2,
Simon Glass39edb952020-12-03 16:55:19 -0700670\t.plat_size\t= sizeof(dtv_phandle_source2),
Simon Glass36b15e22020-10-03 11:31:35 -0600671\t.parent_idx\t= -1,
Walter Lozano5541fc02020-06-25 01:10:17 -0300672};
673
Simon Glass16382ce2020-12-28 20:35:04 -0700674/* Node /phandle-target index 4 */
675static struct dtd_target dtv_phandle_target = {
676\t.intval\t\t\t= 0x0,
677};
678U_BOOT_DRVINFO(phandle_target) = {
679\t.name\t\t= "target",
680\t.plat\t= &dtv_phandle_target,
681\t.plat_size\t= sizeof(dtv_phandle_target),
682\t.parent_idx\t= -1,
683};
684
Walter Lozano5541fc02020-06-25 01:10:17 -0300685''', data)
686
Simon Glass961c1ce2018-07-06 10:27:35 -0600687 def test_phandle_bad(self):
688 """Test a node containing an invalid phandle fails"""
Simon Glass04150022018-10-01 21:12:43 -0600689 dtb_file = get_dtb_file('dtoc_test_phandle_bad.dts',
690 capture_stderr=True)
Simon Glass961c1ce2018-07-06 10:27:35 -0600691 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -0700692 with self.assertRaises(ValueError) as exc:
Walter Lozanoa324e412020-06-25 01:10:08 -0300693 self.run_test(['struct'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -0600694 self.assertIn("Cannot parse 'clocks' in node 'phandle-source'",
Simon Glassa60cabd2020-12-28 20:34:47 -0700695 str(exc.exception))
Simon Glass961c1ce2018-07-06 10:27:35 -0600696
697 def test_phandle_bad2(self):
698 """Test a phandle target missing its #*-cells property"""
Simon Glass04150022018-10-01 21:12:43 -0600699 dtb_file = get_dtb_file('dtoc_test_phandle_bad2.dts',
700 capture_stderr=True)
Simon Glass961c1ce2018-07-06 10:27:35 -0600701 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -0700702 with self.assertRaises(ValueError) as exc:
Walter Lozanoa324e412020-06-25 01:10:08 -0300703 self.run_test(['struct'], dtb_file, output)
Walter Lozano179f0b62020-06-25 01:10:16 -0300704 self.assertIn("Node 'phandle-target' has no cells property",
Simon Glassa60cabd2020-12-28 20:34:47 -0700705 str(exc.exception))
Simon Glass961c1ce2018-07-06 10:27:35 -0600706
Simon Glass1b1fe412017-08-29 14:15:50 -0600707 def test_addresses64(self):
708 """Test output from a node with a 'reg' property with na=2, ns=2"""
709 dtb_file = get_dtb_file('dtoc_test_addr64.dts')
710 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300711 self.run_test(['struct'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -0600712 with open(output) as infile:
713 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700714 self._check_strings(HEADER + '''
Simon Glass1b1fe412017-08-29 14:15:50 -0600715struct dtd_test1 {
716\tfdt64_t\t\treg[2];
717};
718struct dtd_test2 {
719\tfdt64_t\t\treg[2];
720};
721struct dtd_test3 {
722\tfdt64_t\t\treg[4];
723};
724''', data)
725
Walter Lozanoa324e412020-06-25 01:10:08 -0300726 self.run_test(['platdata'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -0600727 with open(output) as infile:
728 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700729 self._check_strings(C_HEADER + '''
Simon Glass192f8132020-10-03 11:31:25 -0600730/* Node /test1 index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300731static struct dtd_test1 dtv_test1 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600732\t.reg\t\t\t= {0x1234, 0x5678},
733};
Simon Glass1d8364a2020-12-28 20:34:54 -0700734U_BOOT_DRVINFO(test1) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600735\t.name\t\t= "test1",
Simon Glass71fa5b42020-12-03 16:55:18 -0700736\t.plat\t= &dtv_test1,
Simon Glass39edb952020-12-03 16:55:19 -0700737\t.plat_size\t= sizeof(dtv_test1),
Simon Glass36b15e22020-10-03 11:31:35 -0600738\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600739};
740
Simon Glass192f8132020-10-03 11:31:25 -0600741/* Node /test2 index 1 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300742static struct dtd_test2 dtv_test2 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600743\t.reg\t\t\t= {0x1234567890123456, 0x9876543210987654},
744};
Simon Glass1d8364a2020-12-28 20:34:54 -0700745U_BOOT_DRVINFO(test2) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600746\t.name\t\t= "test2",
Simon Glass71fa5b42020-12-03 16:55:18 -0700747\t.plat\t= &dtv_test2,
Simon Glass39edb952020-12-03 16:55:19 -0700748\t.plat_size\t= sizeof(dtv_test2),
Simon Glass36b15e22020-10-03 11:31:35 -0600749\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600750};
751
Simon Glass192f8132020-10-03 11:31:25 -0600752/* Node /test3 index 2 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300753static struct dtd_test3 dtv_test3 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600754\t.reg\t\t\t= {0x1234567890123456, 0x9876543210987654, 0x2, 0x3},
755};
Simon Glass1d8364a2020-12-28 20:34:54 -0700756U_BOOT_DRVINFO(test3) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600757\t.name\t\t= "test3",
Simon Glass71fa5b42020-12-03 16:55:18 -0700758\t.plat\t= &dtv_test3,
Simon Glass39edb952020-12-03 16:55:19 -0700759\t.plat_size\t= sizeof(dtv_test3),
Simon Glass36b15e22020-10-03 11:31:35 -0600760\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600761};
762
Simon Glass2500de22020-12-28 20:35:05 -0700763''', data)
Simon Glass1b1fe412017-08-29 14:15:50 -0600764
765 def test_addresses32(self):
766 """Test output from a node with a 'reg' property with na=1, ns=1"""
767 dtb_file = get_dtb_file('dtoc_test_addr32.dts')
768 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300769 self.run_test(['struct'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -0600770 with open(output) as infile:
771 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700772 self._check_strings(HEADER + '''
Simon Glass1b1fe412017-08-29 14:15:50 -0600773struct dtd_test1 {
774\tfdt32_t\t\treg[2];
775};
776struct dtd_test2 {
777\tfdt32_t\t\treg[4];
778};
779''', data)
780
Walter Lozanoa324e412020-06-25 01:10:08 -0300781 self.run_test(['platdata'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -0600782 with open(output) as infile:
783 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700784 self._check_strings(C_HEADER + '''
Simon Glass192f8132020-10-03 11:31:25 -0600785/* Node /test1 index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300786static struct dtd_test1 dtv_test1 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600787\t.reg\t\t\t= {0x1234, 0x5678},
788};
Simon Glass1d8364a2020-12-28 20:34:54 -0700789U_BOOT_DRVINFO(test1) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600790\t.name\t\t= "test1",
Simon Glass71fa5b42020-12-03 16:55:18 -0700791\t.plat\t= &dtv_test1,
Simon Glass39edb952020-12-03 16:55:19 -0700792\t.plat_size\t= sizeof(dtv_test1),
Simon Glass36b15e22020-10-03 11:31:35 -0600793\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600794};
795
Simon Glass192f8132020-10-03 11:31:25 -0600796/* Node /test2 index 1 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300797static struct dtd_test2 dtv_test2 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600798\t.reg\t\t\t= {0x12345678, 0x98765432, 0x2, 0x3},
799};
Simon Glass1d8364a2020-12-28 20:34:54 -0700800U_BOOT_DRVINFO(test2) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600801\t.name\t\t= "test2",
Simon Glass71fa5b42020-12-03 16:55:18 -0700802\t.plat\t= &dtv_test2,
Simon Glass39edb952020-12-03 16:55:19 -0700803\t.plat_size\t= sizeof(dtv_test2),
Simon Glass36b15e22020-10-03 11:31:35 -0600804\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600805};
806
Simon Glass2500de22020-12-28 20:35:05 -0700807''', data)
Simon Glass1b1fe412017-08-29 14:15:50 -0600808
809 def test_addresses64_32(self):
810 """Test output from a node with a 'reg' property with na=2, ns=1"""
811 dtb_file = get_dtb_file('dtoc_test_addr64_32.dts')
812 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300813 self.run_test(['struct'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -0600814 with open(output) as infile:
815 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700816 self._check_strings(HEADER + '''
Simon Glass1b1fe412017-08-29 14:15:50 -0600817struct dtd_test1 {
818\tfdt64_t\t\treg[2];
819};
820struct dtd_test2 {
821\tfdt64_t\t\treg[2];
822};
823struct dtd_test3 {
824\tfdt64_t\t\treg[4];
825};
826''', data)
827
Walter Lozanoa324e412020-06-25 01:10:08 -0300828 self.run_test(['platdata'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -0600829 with open(output) as infile:
830 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700831 self._check_strings(C_HEADER + '''
Simon Glass192f8132020-10-03 11:31:25 -0600832/* Node /test1 index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300833static struct dtd_test1 dtv_test1 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600834\t.reg\t\t\t= {0x123400000000, 0x5678},
835};
Simon Glass1d8364a2020-12-28 20:34:54 -0700836U_BOOT_DRVINFO(test1) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600837\t.name\t\t= "test1",
Simon Glass71fa5b42020-12-03 16:55:18 -0700838\t.plat\t= &dtv_test1,
Simon Glass39edb952020-12-03 16:55:19 -0700839\t.plat_size\t= sizeof(dtv_test1),
Simon Glass36b15e22020-10-03 11:31:35 -0600840\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600841};
842
Simon Glass192f8132020-10-03 11:31:25 -0600843/* Node /test2 index 1 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300844static struct dtd_test2 dtv_test2 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600845\t.reg\t\t\t= {0x1234567890123456, 0x98765432},
846};
Simon Glass1d8364a2020-12-28 20:34:54 -0700847U_BOOT_DRVINFO(test2) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600848\t.name\t\t= "test2",
Simon Glass71fa5b42020-12-03 16:55:18 -0700849\t.plat\t= &dtv_test2,
Simon Glass39edb952020-12-03 16:55:19 -0700850\t.plat_size\t= sizeof(dtv_test2),
Simon Glass36b15e22020-10-03 11:31:35 -0600851\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600852};
853
Simon Glass192f8132020-10-03 11:31:25 -0600854/* Node /test3 index 2 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300855static struct dtd_test3 dtv_test3 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600856\t.reg\t\t\t= {0x1234567890123456, 0x98765432, 0x2, 0x3},
857};
Simon Glass1d8364a2020-12-28 20:34:54 -0700858U_BOOT_DRVINFO(test3) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600859\t.name\t\t= "test3",
Simon Glass71fa5b42020-12-03 16:55:18 -0700860\t.plat\t= &dtv_test3,
Simon Glass39edb952020-12-03 16:55:19 -0700861\t.plat_size\t= sizeof(dtv_test3),
Simon Glass36b15e22020-10-03 11:31:35 -0600862\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600863};
864
Simon Glass2500de22020-12-28 20:35:05 -0700865''', data)
Simon Glass1b1fe412017-08-29 14:15:50 -0600866
867 def test_addresses32_64(self):
868 """Test output from a node with a 'reg' property with na=1, ns=2"""
869 dtb_file = get_dtb_file('dtoc_test_addr32_64.dts')
870 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300871 self.run_test(['struct'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -0600872 with open(output) as infile:
873 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700874 self._check_strings(HEADER + '''
Simon Glass1b1fe412017-08-29 14:15:50 -0600875struct dtd_test1 {
876\tfdt64_t\t\treg[2];
877};
878struct dtd_test2 {
879\tfdt64_t\t\treg[2];
880};
881struct dtd_test3 {
882\tfdt64_t\t\treg[4];
883};
884''', data)
885
Walter Lozanoa324e412020-06-25 01:10:08 -0300886 self.run_test(['platdata'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -0600887 with open(output) as infile:
888 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700889 self._check_strings(C_HEADER + '''
Simon Glass192f8132020-10-03 11:31:25 -0600890/* Node /test1 index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300891static struct dtd_test1 dtv_test1 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600892\t.reg\t\t\t= {0x1234, 0x567800000000},
893};
Simon Glass1d8364a2020-12-28 20:34:54 -0700894U_BOOT_DRVINFO(test1) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600895\t.name\t\t= "test1",
Simon Glass71fa5b42020-12-03 16:55:18 -0700896\t.plat\t= &dtv_test1,
Simon Glass39edb952020-12-03 16:55:19 -0700897\t.plat_size\t= sizeof(dtv_test1),
Simon Glass36b15e22020-10-03 11:31:35 -0600898\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600899};
900
Simon Glass192f8132020-10-03 11:31:25 -0600901/* Node /test2 index 1 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300902static struct dtd_test2 dtv_test2 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600903\t.reg\t\t\t= {0x12345678, 0x9876543210987654},
904};
Simon Glass1d8364a2020-12-28 20:34:54 -0700905U_BOOT_DRVINFO(test2) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600906\t.name\t\t= "test2",
Simon Glass71fa5b42020-12-03 16:55:18 -0700907\t.plat\t= &dtv_test2,
Simon Glass39edb952020-12-03 16:55:19 -0700908\t.plat_size\t= sizeof(dtv_test2),
Simon Glass36b15e22020-10-03 11:31:35 -0600909\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600910};
911
Simon Glass192f8132020-10-03 11:31:25 -0600912/* Node /test3 index 2 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300913static struct dtd_test3 dtv_test3 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600914\t.reg\t\t\t= {0x12345678, 0x9876543210987654, 0x2, 0x3},
915};
Simon Glass1d8364a2020-12-28 20:34:54 -0700916U_BOOT_DRVINFO(test3) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600917\t.name\t\t= "test3",
Simon Glass71fa5b42020-12-03 16:55:18 -0700918\t.plat\t= &dtv_test3,
Simon Glass39edb952020-12-03 16:55:19 -0700919\t.plat_size\t= sizeof(dtv_test3),
Simon Glass36b15e22020-10-03 11:31:35 -0600920\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600921};
922
Simon Glass2500de22020-12-28 20:35:05 -0700923''', data)
Simon Glass961c1ce2018-07-06 10:27:35 -0600924
925 def test_bad_reg(self):
926 """Test that a reg property with an invalid type generates an error"""
Simon Glass3bce93d2018-07-06 10:27:37 -0600927 # Capture stderr since dtc will emit warnings for this file
928 dtb_file = get_dtb_file('dtoc_test_bad_reg.dts', capture_stderr=True)
Simon Glass961c1ce2018-07-06 10:27:35 -0600929 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -0700930 with self.assertRaises(ValueError) as exc:
Walter Lozanoa324e412020-06-25 01:10:08 -0300931 self.run_test(['struct'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -0600932 self.assertIn("Node 'spl-test' reg property is not an int",
Simon Glassa60cabd2020-12-28 20:34:47 -0700933 str(exc.exception))
Simon Glass961c1ce2018-07-06 10:27:35 -0600934
935 def test_bad_reg2(self):
936 """Test that a reg property with an invalid cell count is detected"""
Simon Glass3bce93d2018-07-06 10:27:37 -0600937 # Capture stderr since dtc will emit warnings for this file
938 dtb_file = get_dtb_file('dtoc_test_bad_reg2.dts', capture_stderr=True)
Simon Glass961c1ce2018-07-06 10:27:35 -0600939 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -0700940 with self.assertRaises(ValueError) as exc:
Walter Lozanoa324e412020-06-25 01:10:08 -0300941 self.run_test(['struct'], dtb_file, output)
Simon Glassa60cabd2020-12-28 20:34:47 -0700942 self.assertIn(
943 "Node 'spl-test' reg property has 3 cells which is not a multiple of na + ns = 1 + 1)",
944 str(exc.exception))
Simon Glass961c1ce2018-07-06 10:27:35 -0600945
946 def test_add_prop(self):
947 """Test that a subequent node can add a new property to a struct"""
948 dtb_file = get_dtb_file('dtoc_test_add_prop.dts')
949 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300950 self.run_test(['struct'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -0600951 with open(output) as infile:
952 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700953 self._check_strings(HEADER + '''
Simon Glass961c1ce2018-07-06 10:27:35 -0600954struct dtd_sandbox_spl_test {
955\tfdt32_t\t\tintarray;
956\tfdt32_t\t\tintval;
957};
958''', data)
959
Walter Lozanoa324e412020-06-25 01:10:08 -0300960 self.run_test(['platdata'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -0600961 with open(output) as infile:
962 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700963 self._check_strings(C_HEADER + '''
Simon Glassbe749002021-02-03 06:01:15 -0700964/*
965 * Node /spl-test index 0
966 * driver sandbox_spl_test parent None
967 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300968static struct dtd_sandbox_spl_test dtv_spl_test = {
Simon Glass961c1ce2018-07-06 10:27:35 -0600969\t.intval\t\t\t= 0x1,
970};
Simon Glass1d8364a2020-12-28 20:34:54 -0700971U_BOOT_DRVINFO(spl_test) = {
Simon Glass961c1ce2018-07-06 10:27:35 -0600972\t.name\t\t= "sandbox_spl_test",
Simon Glass71fa5b42020-12-03 16:55:18 -0700973\t.plat\t= &dtv_spl_test,
Simon Glass39edb952020-12-03 16:55:19 -0700974\t.plat_size\t= sizeof(dtv_spl_test),
Simon Glass36b15e22020-10-03 11:31:35 -0600975\t.parent_idx\t= -1,
Simon Glass961c1ce2018-07-06 10:27:35 -0600976};
977
Simon Glassbe749002021-02-03 06:01:15 -0700978/*
979 * Node /spl-test2 index 1
980 * driver sandbox_spl_test parent None
981 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300982static struct dtd_sandbox_spl_test dtv_spl_test2 = {
Simon Glass961c1ce2018-07-06 10:27:35 -0600983\t.intarray\t\t= 0x5,
984};
Simon Glass1d8364a2020-12-28 20:34:54 -0700985U_BOOT_DRVINFO(spl_test2) = {
Simon Glass961c1ce2018-07-06 10:27:35 -0600986\t.name\t\t= "sandbox_spl_test",
Simon Glass71fa5b42020-12-03 16:55:18 -0700987\t.plat\t= &dtv_spl_test2,
Simon Glass39edb952020-12-03 16:55:19 -0700988\t.plat_size\t= sizeof(dtv_spl_test2),
Simon Glass36b15e22020-10-03 11:31:35 -0600989\t.parent_idx\t= -1,
Simon Glass961c1ce2018-07-06 10:27:35 -0600990};
991
Simon Glass2500de22020-12-28 20:35:05 -0700992''', data)
Simon Glass961c1ce2018-07-06 10:27:35 -0600993
Simon Glassa60cabd2020-12-28 20:34:47 -0700994 def test_stdout(self):
Simon Glass961c1ce2018-07-06 10:27:35 -0600995 """Test output to stdout"""
996 dtb_file = get_dtb_file('dtoc_test_simple.dts')
Simon Glass07ee48e2020-12-28 20:34:49 -0700997 with test_util.capture_sys_output() as (stdout, _):
Simon Glass6ca0c7a2020-12-28 20:34:48 -0700998 self.run_test(['struct'], dtb_file, None)
Simon Glass07ee48e2020-12-28 20:34:49 -0700999 self._check_strings(self.struct_text, stdout.getvalue())
Simon Glass961c1ce2018-07-06 10:27:35 -06001000
Simon Glassc3a310a82020-12-28 20:34:51 -07001001 def test_multi_to_file(self):
1002 """Test output of multiple pieces to a single file"""
1003 dtb_file = get_dtb_file('dtoc_test_simple.dts')
1004 output = tools.GetOutputFilename('output')
Simon Glass4e8e8462020-12-28 20:34:52 -07001005 self.run_test(['all'], dtb_file, output)
Simon Glassc3a310a82020-12-28 20:34:51 -07001006 data = tools.ReadFile(output, binary=False)
Simon Glass3fa3bbb2021-02-03 06:01:14 -07001007 self._check_strings(self.decl_text + self.platdata_text +
1008 self.struct_text, data)
Simon Glassc3a310a82020-12-28 20:34:51 -07001009
Simon Glassa60cabd2020-12-28 20:34:47 -07001010 def test_no_command(self):
Simon Glass961c1ce2018-07-06 10:27:35 -06001011 """Test running dtoc without a command"""
Simon Glassa60cabd2020-12-28 20:34:47 -07001012 with self.assertRaises(ValueError) as exc:
Walter Lozanoa324e412020-06-25 01:10:08 -03001013 self.run_test([], '', '')
Simon Glass961c1ce2018-07-06 10:27:35 -06001014 self.assertIn("Please specify a command: struct, platdata",
Simon Glassa60cabd2020-12-28 20:34:47 -07001015 str(exc.exception))
Simon Glass961c1ce2018-07-06 10:27:35 -06001016
Simon Glassa60cabd2020-12-28 20:34:47 -07001017 def test_bad_command(self):
Simon Glass961c1ce2018-07-06 10:27:35 -06001018 """Test running dtoc with an invalid command"""
1019 dtb_file = get_dtb_file('dtoc_test_simple.dts')
1020 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -07001021 with self.assertRaises(ValueError) as exc:
Simon Glass3fa3bbb2021-02-03 06:01:14 -07001022 self.run_test(['invalid-cmd'], dtb_file, output)
1023 self.assertIn(
1024 "Unknown command 'invalid-cmd': (use: decl, platdata, struct)",
1025 str(exc.exception))
Walter Lozanod82062b2020-07-28 19:06:23 -03001026
Simon Glass4e8e8462020-12-28 20:34:52 -07001027 def test_output_conflict(self):
1028 """Test a conflict between and output dirs and output file"""
1029 with self.assertRaises(ValueError) as exc:
Simon Glass3809ad92021-02-03 06:01:12 -07001030 dtb_platdata.run_steps(
1031 ['all'], None, False, 'out', ['cdir'], None, False,
1032 warning_disabled=True, scan=copy_scan())
Simon Glass4e8e8462020-12-28 20:34:52 -07001033 self.assertIn("Must specify either output or output_dirs, not both",
1034 str(exc.exception))
1035
1036 def test_output_dirs(self):
1037 """Test outputting files to a directory"""
1038 # Remove the directory so that files from other tests are not there
1039 tools._RemoveOutputDir()
1040 tools.PrepareOutputDir(None)
1041
1042 # This should create the .dts and .dtb in the output directory
1043 dtb_file = get_dtb_file('dtoc_test_simple.dts')
1044 outdir = tools.GetOutputDir()
1045 fnames = glob.glob(outdir + '/*')
1046 self.assertEqual(2, len(fnames))
1047
Simon Glass3809ad92021-02-03 06:01:12 -07001048 dtb_platdata.run_steps(
1049 ['all'], dtb_file, False, None, [outdir], None, False,
1050 warning_disabled=True, scan=copy_scan())
Simon Glass4e8e8462020-12-28 20:34:52 -07001051 fnames = glob.glob(outdir + '/*')
Simon Glass3fa3bbb2021-02-03 06:01:14 -07001052 self.assertEqual(5, len(fnames))
Simon Glass4e8e8462020-12-28 20:34:52 -07001053
1054 leafs = set(os.path.basename(fname) for fname in fnames)
1055 self.assertEqual(
Simon Glass3fa3bbb2021-02-03 06:01:14 -07001056 {'dt-structs-gen.h', 'source.dts', 'dt-plat.c', 'source.dtb',
1057 'dt-decl.h'},
Simon Glass4e8e8462020-12-28 20:34:52 -07001058 leafs)
Simon Glass047a4802021-02-03 06:01:00 -07001059
1060 def setup_process_test(self):
1061 """Set up a test of process_nodes()
1062
1063 This uses saved_scan but returns a deep copy of it, so it is safe to
1064 modify it in these tests
1065
1066 Returns:
1067 tuple:
1068 DtbPlatdata: object to test
1069 Scanner: scanner to use
1070 """
1071 dtb_file = get_dtb_file('dtoc_test_simple.dts')
1072 output = tools.GetOutputFilename('output')
1073
1074 # Take a copy before messing with it
Simon Glassc14fd0c2021-02-03 06:01:11 -07001075 scan = copy_scan()
Simon Glass047a4802021-02-03 06:01:00 -07001076 plat = dtb_platdata.DtbPlatdata(scan, dtb_file, False)
1077 plat.scan_dtb()
Simon Glassc14fd0c2021-02-03 06:01:11 -07001078 plat.scan_tree(False)
Simon Glass047a4802021-02-03 06:01:00 -07001079 plat.prepare_nodes()
1080 return plat, scan
1081
1082 def test_process_nodes(self):
1083 """Test processing nodes to add various info"""
1084 plat, scan = self.setup_process_test()
1085 plat.process_nodes(True)
1086
1087 i2c_node = plat._fdt.GetNode('/i2c@0')
1088 pmic_node = plat._fdt.GetNode('/i2c@0/pmic@9')
1089 pmic = scan._drivers['sandbox_pmic']
1090 i2c = scan._drivers['sandbox_i2c']
1091 self.assertEqual('DM_DEVICE_REF(pmic_at_9)', pmic_node.dev_ref)
1092 self.assertEqual(pmic, pmic_node.driver)
1093 self.assertEqual(i2c_node, pmic_node.parent)
1094 self.assertEqual(i2c, pmic_node.parent_driver)
1095
1096 # The pmic is the only child
1097 self.assertEqual(pmic_node.parent_seq, 0)
1098 self.assertEqual([pmic_node], i2c_node.child_devs)
1099
1100 # Start and end of the list should be the child_head
1101 ref = '&DM_DEVICE_REF(i2c_at_0)->child_head'
1102 self.assertEqual(
1103 {-1: ref, 0: '&DM_DEVICE_REF(pmic_at_9)->sibling_node', 1: ref},
1104 i2c_node.child_refs)
1105
1106 def test_process_nodes_bad_parent(self):
1107 # Pretend that i2c has a parent (the pmic) and delete that driver
1108 plat, scan = self.setup_process_test()
1109
1110 i2c_node = plat._fdt.GetNode('/i2c@0')
1111 pmic_node = plat._fdt.GetNode('/i2c@0/pmic@9')
1112 del scan._drivers['sandbox_pmic']
1113 i2c_node.parent = pmic_node
1114
1115 # Process twice, the second time to generate an exception
1116 plat.process_nodes(False)
1117 with self.assertRaises(ValueError) as exc:
1118 plat.process_nodes(True)
1119 self.assertIn(
1120 "Cannot parse/find parent driver 'sandbox_pmic' for 'sandbox_i2c",
1121 str(exc.exception))
1122
1123 def test_process_nodes_bad_node(self):
1124 plat, scan = self.setup_process_test()
1125
1126 # Now remove the pmic driver
1127 del scan._drivers['sandbox_pmic']
1128
1129 # Process twice, the second time to generate an exception
1130 plat.process_nodes(False)
1131 with self.assertRaises(ValueError) as exc:
1132 plat.process_nodes(True)
1133 self.assertIn("Cannot parse/find driver for 'sandbox_pmic",
1134 str(exc.exception))
Simon Glasseb3c2492021-02-03 06:01:01 -07001135
Simon Glass80d782c42021-02-03 06:01:10 -07001136 def test_process_nodes_bad_uclass(self):
1137 plat, scan = self.setup_process_test()
1138
1139 self.assertIn('UCLASS_I2C', scan._uclass)
1140 del scan._uclass['UCLASS_I2C']
1141 with self.assertRaises(ValueError) as exc:
1142 plat.process_nodes(True)
1143 self.assertIn("Cannot parse/find uclass 'UCLASS_I2C' for driver 'sandbox_i2c'",
1144 str(exc.exception))
1145
Simon Glasseb3c2492021-02-03 06:01:01 -07001146 def test_process_nodes_used(self):
1147 """Test processing nodes to add various info"""
1148 plat, scan = self.setup_process_test()
1149 plat.process_nodes(True)
1150
1151 pmic = scan._drivers['sandbox_pmic']
1152 self.assertTrue(pmic.used)
1153
1154 gpio = scan._drivers['sandbox_gpio']
1155 self.assertFalse(gpio.used)
Simon Glassbe88d2f2021-02-03 06:01:07 -07001156
1157 def test_alias_read(self):
1158 """Test obtaining aliases"""
1159 dtb_file = get_dtb_file('dtoc_test_inst.dts')
1160 output = tools.GetOutputFilename('output')
1161 plat = self.run_test(['struct'], dtb_file, output)
1162
1163 scan = plat._scan
1164 testfdt_node = plat._fdt.GetNode('/some-bus/test')
Simon Glass80d782c42021-02-03 06:01:10 -07001165 test0_node = plat._fdt.GetNode('/some-bus/test0')
Simon Glassbe88d2f2021-02-03 06:01:07 -07001166 self.assertIn('UCLASS_TEST_FDT', scan._uclass)
1167 uc = scan._uclass['UCLASS_TEST_FDT']
Simon Glass80d782c42021-02-03 06:01:10 -07001168 self.assertEqual({1: testfdt_node, 2: test0_node},
1169 uc.alias_num_to_node)
1170 self.assertEqual({'/some-bus/test': 1, '/some-bus/test0': 2},
1171 uc.alias_path_to_num)
Simon Glassbe88d2f2021-02-03 06:01:07 -07001172
1173 # Try adding an alias that doesn't exist
1174 self.assertFalse(scan.add_uclass_alias('fred', 3, None))
1175
1176 # Try adding an alias for a missing node
1177 self.assertIsNone(scan.add_uclass_alias('testfdt', 3, None))
1178
1179 def test_alias_read_bad(self):
1180 """Test invalid alias property name"""
1181 dtb_file = get_dtb_file('dtoc_test_alias_bad.dts')
1182 output = tools.GetOutputFilename('output')
1183 with self.assertRaises(ValueError) as exc:
1184 plat = self.run_test(['struct'], dtb_file, output)
1185 self.assertIn("Cannot decode alias 'i2c4-'", str(exc.exception))
1186
1187 def test_alias_read_bad_path(self):
1188 """Test alias pointing to a non-existent node"""
1189 # This line may produce a warning, so capture it:
1190 # Warning (alias_paths): /aliases:i2c4: aliases property is not a valid
1191 # node (/does/not/exist)
1192 dtb_file = get_dtb_file('dtoc_test_alias_bad_path.dts', True)
1193
1194 output = tools.GetOutputFilename('output')
1195 with self.assertRaises(ValueError) as exc:
1196 plat = self.run_test(['struct'], dtb_file, output)
1197 self.assertIn("Alias 'i2c4' path '/does/not/exist' not found",
1198 str(exc.exception))
1199
1200 def test_alias_read_bad_uclass(self):
1201 """Test alias for a uclass that doesn't exist"""
1202 dtb_file = get_dtb_file('dtoc_test_alias_bad_uc.dts')
1203 output = tools.GetOutputFilename('output')
1204 with test_util.capture_sys_output() as (stdout, _):
1205 plat = self.run_test(['struct'], dtb_file, output)
1206 self.assertEqual("Could not find uclass for alias 'other1'",
1207 stdout.getvalue().strip())
Simon Glassdf56e0b2021-02-03 06:01:09 -07001208
1209 def test_sequence(self):
1210 """Test assignment of sequence numnbers"""
1211 dtb_file = get_dtb_file('dtoc_test_inst.dts')
1212 output = tools.GetOutputFilename('output')
1213 plat = self.run_test(['struct'], dtb_file, output)
Simon Glass80d782c42021-02-03 06:01:10 -07001214
1215 scan = plat._scan
1216 testfdt = plat._fdt.GetNode('/some-bus/test')
1217 self.assertEqual(1, testfdt.seq)
1218 i2c = plat._fdt.GetNode('/i2c')
1219
1220 # For now this uclass is not compiled in, so no sequence is assigned
1221 self.assertEqual(4, i2c.seq)
1222 spl = plat._fdt.GetNode('/spl-test')
1223 self.assertEqual(0, spl.seq)
Simon Glassc14fd0c2021-02-03 06:01:11 -07001224
1225 def test_process_root(self):
1226 """Test assignment of sequence numnbers"""
1227 dtb_file = get_dtb_file('dtoc_test_simple.dts')
1228 output = tools.GetOutputFilename('output')
1229
1230 # Take a copy before messing with it
1231 scan = copy_scan()
1232 plat = dtb_platdata.DtbPlatdata(scan, dtb_file, False)
1233 plat.scan_dtb()
1234 root = plat._fdt.GetRoot()
1235
1236 plat.scan_tree(False)
1237 self.assertNotIn(root, plat._valid_nodes)
1238
1239 plat.scan_tree(True)
1240 self.assertIn(root, plat._valid_nodes)
1241 self.assertEqual('root_driver',
1242 scan.get_normalized_compat_name(root)[0])
Simon Glass3fa3bbb2021-02-03 06:01:14 -07001243
1244 def test_simple_inst(self):
1245 """Test output from some simple nodes with instantiate enabled"""
1246 dtb_file = get_dtb_file('dtoc_test_simple.dts')
1247 output = tools.GetOutputFilename('output')
1248
1249 self.run_test(['decl'], dtb_file, output, True)
1250 with open(output) as infile:
1251 data = infile.read()
1252
1253 self._check_strings(self.decl_text_inst, data)
Simon Glassbe749002021-02-03 06:01:15 -07001254
1255 self.run_test(['platdata'], dtb_file, output, True)
1256 with open(output) as infile:
1257 data = infile.read()
1258
1259 self._check_strings(C_HEADER_PRE + '''
1260/* This file is not used: --instantiate was enabled */
1261''', data)