blob: 053d140664ea67c479dbe6ea29c9d13454bf6bd9 [file] [log] [blame]
Simon Glassbfb0bb22019-10-31 07:42:55 -06001#!/usr/bin/env python3
Tom Rini10e47792018-05-06 17:58:06 -04002# SPDX-License-Identifier: GPL-2.0+
Simon Glass9d2eb922017-06-18 22:09:06 -06003# Copyright (c) 2012 The Chromium OS Authors.
4#
Simon Glass9d2eb922017-06-18 22:09:06 -06005
6"""Tests for the dtb_platdata module
7
Simon Glass70cd0d72018-07-06 10:27:20 -06008This includes unit tests for some functions and functional tests for the dtoc
9tool.
Simon Glass9d2eb922017-06-18 22:09:06 -060010"""
11
12import collections
Simon Glass768ff0a2021-02-03 06:00:51 -070013import copy
Simon Glass4e8e8462020-12-28 20:34:52 -070014import glob
Simon Glass9d2eb922017-06-18 22:09:06 -060015import os
16import struct
17import unittest
18
Simon Glassc7b4b832021-02-03 06:01:20 -070019from dtb_platdata import Ftype
Simon Glass9d2eb922017-06-18 22:09:06 -060020from dtb_platdata import get_value
21from dtb_platdata import tab_to
Simon Glassa60cabd2020-12-28 20:34:47 -070022from dtoc import dtb_platdata
Simon Glassa997ea52020-04-17 18:09:04 -060023from dtoc import fdt
24from dtoc import fdt_util
Simon Glass768ff0a2021-02-03 06:00:51 -070025from dtoc import src_scan
Simon Glass9065bc92020-12-28 20:35:06 -070026from dtoc.src_scan import conv_name_to_c
27from dtoc.src_scan import get_compat_name
Simon Glassa997ea52020-04-17 18:09:04 -060028from patman import test_util
29from patman import tools
Simon Glass9d2eb922017-06-18 22:09:06 -060030
Simon Glassa60cabd2020-12-28 20:34:47 -070031OUR_PATH = os.path.dirname(os.path.realpath(__file__))
Simon Glass9d2eb922017-06-18 22:09:06 -060032
33
Simon Glasseb37e2d2017-11-12 21:52:17 -070034HEADER = '''/*
35 * DO NOT MODIFY
36 *
Simon Glass6b208842020-12-28 20:35:00 -070037 * Defines the structs used to hold devicetree data.
38 * This was generated by dtoc from a .dtb (device tree binary) file.
Simon Glasseb37e2d2017-11-12 21:52:17 -070039 */
40
41#include <stdbool.h>
Masahiro Yamada75f82d02018-03-05 01:20:11 +090042#include <linux/libfdt.h>'''
Simon Glasseb37e2d2017-11-12 21:52:17 -070043
Simon Glass3fa3bbb2021-02-03 06:01:14 -070044DECL_HEADER = '''/*
45 * DO NOT MODIFY
46 *
47 * Declares externs for all device/uclass instances.
48 * This was generated by dtoc from a .dtb (device tree binary) file.
49 */
50'''
51
Simon Glassbe749002021-02-03 06:01:15 -070052C_HEADER_PRE = '''/*
Simon Glasseb37e2d2017-11-12 21:52:17 -070053 * DO NOT MODIFY
54 *
Simon Glass6b208842020-12-28 20:35:00 -070055 * Declares the U_BOOT_DRIVER() records and platform data.
56 * This was generated by dtoc from a .dtb (device tree binary) file.
Simon Glasseb37e2d2017-11-12 21:52:17 -070057 */
Simon Glassbe749002021-02-03 06:01:15 -070058'''
Simon Glasseb37e2d2017-11-12 21:52:17 -070059
Simon Glassbe749002021-02-03 06:01:15 -070060C_HEADER = C_HEADER_PRE + '''
Simon Glass1d8364a2020-12-28 20:34:54 -070061/* Allow use of U_BOOT_DRVINFO() in this file */
Simon Glassbeddd7a2020-12-28 20:35:01 -070062#define DT_PLAT_C
Simon Glass4c73d7b2020-10-03 11:31:41 -060063
Simon Glasseb37e2d2017-11-12 21:52:17 -070064#include <common.h>
65#include <dm.h>
66#include <dt-structs.h>
67'''
68
Simon Glassc7b4b832021-02-03 06:01:20 -070069UCLASS_HEADER_COMMON = '''/*
70 * DO NOT MODIFY
71 *
72 * Declares the uclass instances (struct uclass).
73 * This was generated by dtoc from a .dtb (device tree binary) file.
74 */
75'''
76
77UCLASS_HEADER = UCLASS_HEADER_COMMON + '''
78/* This file is not used: --instantiate was not enabled */
79'''
80
Simon Glass768ff0a2021-02-03 06:00:51 -070081# Scanner saved from a previous run of the tests (to speed things up)
82saved_scan = None
83
Simon Glassa60cabd2020-12-28 20:34:47 -070084# This is a test so is allowed to access private things in the module it is
85# testing
86# pylint: disable=W0212
Simon Glass3bce93d2018-07-06 10:27:37 -060087
88def get_dtb_file(dts_fname, capture_stderr=False):
Simon Glass9d2eb922017-06-18 22:09:06 -060089 """Compile a .dts file to a .dtb
90
91 Args:
Simon Glassa60cabd2020-12-28 20:34:47 -070092 dts_fname (str): Filename of .dts file in the current directory
93 capture_stderr (bool): True to capture and discard stderr output
Simon Glass9d2eb922017-06-18 22:09:06 -060094
95 Returns:
Simon Glassa60cabd2020-12-28 20:34:47 -070096 str: Filename of compiled file in output directory
Simon Glass9d2eb922017-06-18 22:09:06 -060097 """
Simon Glass4f4b2402021-02-03 06:00:56 -070098 return fdt_util.EnsureCompiled(os.path.join(OUR_PATH, 'test', dts_fname),
Simon Glass3bce93d2018-07-06 10:27:37 -060099 capture_stderr=capture_stderr)
Simon Glass9d2eb922017-06-18 22:09:06 -0600100
Simon Glass768ff0a2021-02-03 06:00:51 -0700101
102def setup():
103 global saved_scan
104
105 # Disable warnings so that calls to get_normalized_compat_name() will not
106 # output things.
107 saved_scan = src_scan.Scanner(None, True, False)
108 saved_scan.scan_drivers()
109
110def copy_scan():
111 """Get a copy of saved_scan so that each test can start clean"""
112 return copy.deepcopy(saved_scan)
113
Simon Glass9d2eb922017-06-18 22:09:06 -0600114
115class TestDtoc(unittest.TestCase):
116 """Tests for dtoc"""
117 @classmethod
118 def setUpClass(cls):
119 tools.PrepareOutputDir(None)
Simon Glass7f5e2262020-07-07 21:32:06 -0600120 cls.maxDiff = None
Simon Glass9d2eb922017-06-18 22:09:06 -0600121
122 @classmethod
123 def tearDownClass(cls):
Simon Glassa60cabd2020-12-28 20:34:47 -0700124 tools.FinaliseOutputDir()
Simon Glass9d2eb922017-06-18 22:09:06 -0600125
Simon Glassa60cabd2020-12-28 20:34:47 -0700126 @staticmethod
127 def _write_python_string(fname, data):
Simon Glassc47c2b32018-07-06 10:27:25 -0600128 """Write a string with tabs expanded as done in this Python file
129
130 Args:
Simon Glassa60cabd2020-12-28 20:34:47 -0700131 fname (str): Filename to write to
132 data (str): Raw string to convert
Simon Glassc47c2b32018-07-06 10:27:25 -0600133 """
134 data = data.replace('\t', '\\t')
Simon Glassa60cabd2020-12-28 20:34:47 -0700135 with open(fname, 'w') as fout:
136 fout.write(data)
Simon Glassc47c2b32018-07-06 10:27:25 -0600137
Simon Glassa60cabd2020-12-28 20:34:47 -0700138 def _check_strings(self, expected, actual):
Simon Glassc47c2b32018-07-06 10:27:25 -0600139 """Check that a string matches its expected value
140
141 If the strings do not match, they are written to the /tmp directory in
142 the same Python format as is used here in the test. This allows for
143 easy comparison and update of the tests.
144
145 Args:
Simon Glassa60cabd2020-12-28 20:34:47 -0700146 expected (str): Expected string
147 actual (str): Actual string
Simon Glassc47c2b32018-07-06 10:27:25 -0600148 """
149 if expected != actual:
Simon Glassa60cabd2020-12-28 20:34:47 -0700150 self._write_python_string('/tmp/binman.expected', expected)
151 self._write_python_string('/tmp/binman.actual', actual)
Simon Glass61b88e52019-05-17 22:00:31 -0600152 print('Failures written to /tmp/binman.{expected,actual}')
Simon Glassa60cabd2020-12-28 20:34:47 -0700153 self.assertEqual(expected, actual)
Simon Glassc47c2b32018-07-06 10:27:25 -0600154
Simon Glassa60cabd2020-12-28 20:34:47 -0700155 @staticmethod
Simon Glass3809ad92021-02-03 06:01:12 -0700156 def run_test(args, dtb_file, output, instantiate=False):
Simon Glassa60cabd2020-12-28 20:34:47 -0700157 """Run a test using dtoc
Walter Lozanoa324e412020-06-25 01:10:08 -0300158
Simon Glassa60cabd2020-12-28 20:34:47 -0700159 Args:
160 args (list of str): List of arguments for dtoc
161 dtb_file (str): Filename of .dtb file
162 output (str): Filename of output file
Simon Glassbe88d2f2021-02-03 06:01:07 -0700163
164 Returns:
165 DtbPlatdata object
Simon Glassa60cabd2020-12-28 20:34:47 -0700166 """
Simon Glass80d782c42021-02-03 06:01:10 -0700167 # Make a copy of the 'scan' object, since it includes uclasses and
168 # drivers, which get updated during execution.
Simon Glass3809ad92021-02-03 06:01:12 -0700169 return dtb_platdata.run_steps(
170 args, dtb_file, False, output, [], None, instantiate,
171 warning_disabled=True, scan=copy_scan())
Walter Lozanoa324e412020-06-25 01:10:08 -0300172
Simon Glass9d2eb922017-06-18 22:09:06 -0600173 def test_name(self):
174 """Test conversion of device tree names to C identifiers"""
175 self.assertEqual('serial_at_0x12', conv_name_to_c('serial@0x12'))
176 self.assertEqual('vendor_clock_frequency',
177 conv_name_to_c('vendor,clock-frequency'))
178 self.assertEqual('rockchip_rk3399_sdhci_5_1',
179 conv_name_to_c('rockchip,rk3399-sdhci-5.1'))
180
181 def test_tab_to(self):
182 """Test operation of tab_to() function"""
183 self.assertEqual('fred ', tab_to(0, 'fred'))
184 self.assertEqual('fred\t', tab_to(1, 'fred'))
185 self.assertEqual('fred was here ', tab_to(1, 'fred was here'))
186 self.assertEqual('fred was here\t\t', tab_to(3, 'fred was here'))
187 self.assertEqual('exactly8 ', tab_to(1, 'exactly8'))
188 self.assertEqual('exactly8\t', tab_to(2, 'exactly8'))
189
190 def test_get_value(self):
191 """Test operation of get_value() function"""
192 self.assertEqual('0x45',
Simon Glassc9a032c2020-11-08 20:36:17 -0700193 get_value(fdt.Type.INT, struct.pack('>I', 0x45)))
Simon Glass9d2eb922017-06-18 22:09:06 -0600194 self.assertEqual('0x45',
Simon Glassc9a032c2020-11-08 20:36:17 -0700195 get_value(fdt.Type.BYTE, struct.pack('<I', 0x45)))
Simon Glass9d2eb922017-06-18 22:09:06 -0600196 self.assertEqual('0x0',
Simon Glassc9a032c2020-11-08 20:36:17 -0700197 get_value(fdt.Type.BYTE, struct.pack('>I', 0x45)))
198 self.assertEqual('"test"', get_value(fdt.Type.STRING, 'test'))
199 self.assertEqual('true', get_value(fdt.Type.BOOL, None))
Simon Glass9d2eb922017-06-18 22:09:06 -0600200
201 def test_get_compat_name(self):
202 """Test operation of get_compat_name() function"""
203 Prop = collections.namedtuple('Prop', ['value'])
204 Node = collections.namedtuple('Node', ['props'])
205
206 prop = Prop(['rockchip,rk3399-sdhci-5.1', 'arasan,sdhci-5.1'])
207 node = Node({'compatible': prop})
Walter Lozano5fe734c2020-07-23 00:22:03 -0300208 self.assertEqual((['rockchip_rk3399_sdhci_5_1', 'arasan_sdhci_5_1']),
Simon Glass9d2eb922017-06-18 22:09:06 -0600209 get_compat_name(node))
210
211 prop = Prop(['rockchip,rk3399-sdhci-5.1'])
212 node = Node({'compatible': prop})
Walter Lozano5fe734c2020-07-23 00:22:03 -0300213 self.assertEqual((['rockchip_rk3399_sdhci_5_1']),
Simon Glass9d2eb922017-06-18 22:09:06 -0600214 get_compat_name(node))
215
216 prop = Prop(['rockchip,rk3399-sdhci-5.1', 'arasan,sdhci-5.1', 'third'])
217 node = Node({'compatible': prop})
Walter Lozano5fe734c2020-07-23 00:22:03 -0300218 self.assertEqual((['rockchip_rk3399_sdhci_5_1',
Simon Glassa60cabd2020-12-28 20:34:47 -0700219 'arasan_sdhci_5_1', 'third']),
Simon Glass9d2eb922017-06-18 22:09:06 -0600220 get_compat_name(node))
221
222 def test_empty_file(self):
223 """Test output from a device tree file with no nodes"""
224 dtb_file = get_dtb_file('dtoc_test_empty.dts')
225 output = tools.GetOutputFilename('output')
Simon Glass768ff0a2021-02-03 06:00:51 -0700226
227 # Run this one without saved_scan to complete test coverage
Simon Glass3809ad92021-02-03 06:01:12 -0700228 dtb_platdata.run_steps(['struct'], dtb_file, False, output, [], None,
229 False)
Simon Glass9d2eb922017-06-18 22:09:06 -0600230 with open(output) as infile:
231 lines = infile.read().splitlines()
Simon Glasseb37e2d2017-11-12 21:52:17 -0700232 self.assertEqual(HEADER.splitlines(), lines)
Simon Glass9d2eb922017-06-18 22:09:06 -0600233
Walter Lozanoa324e412020-06-25 01:10:08 -0300234 self.run_test(['platdata'], dtb_file, output)
Simon Glass9d2eb922017-06-18 22:09:06 -0600235 with open(output) as infile:
236 lines = infile.read().splitlines()
Simon Glass2500de22020-12-28 20:35:05 -0700237 self.assertEqual(C_HEADER.splitlines() + [''], lines)
Simon Glass9d2eb922017-06-18 22:09:06 -0600238
Simon Glass3fa3bbb2021-02-03 06:01:14 -0700239 decl_text = DECL_HEADER + '''
240#include <dm/device-internal.h>
241#include <dm/uclass-internal.h>
242
243/* driver declarations - these allow DM_DRIVER_GET() to be used */
244DM_DRIVER_DECL(sandbox_i2c);
245DM_DRIVER_DECL(sandbox_pmic);
246DM_DRIVER_DECL(sandbox_spl_test);
247DM_DRIVER_DECL(sandbox_spl_test);
248DM_DRIVER_DECL(sandbox_spl_test);
249
250/* uclass driver declarations - needed for DM_UCLASS_DRIVER_REF() */
251DM_UCLASS_DRIVER_DECL(i2c);
252DM_UCLASS_DRIVER_DECL(misc);
253DM_UCLASS_DRIVER_DECL(pmic);
254'''
255 decl_text_inst = DECL_HEADER + '''
256#include <dm/device-internal.h>
257#include <dm/uclass-internal.h>
258
259/* driver declarations - these allow DM_DRIVER_GET() to be used */
260DM_DRIVER_DECL(sandbox_i2c);
Simon Glass3fa3bbb2021-02-03 06:01:14 -0700261DM_DRIVER_DECL(root_driver);
Simon Glassc7b4b832021-02-03 06:01:20 -0700262DM_DRIVER_DECL(denx_u_boot_test_bus);
Simon Glass3fa3bbb2021-02-03 06:01:14 -0700263DM_DRIVER_DECL(sandbox_spl_test);
264DM_DRIVER_DECL(sandbox_spl_test);
Simon Glassc7b4b832021-02-03 06:01:20 -0700265DM_DRIVER_DECL(denx_u_boot_fdt_test);
266DM_DRIVER_DECL(denx_u_boot_fdt_test);
Simon Glass3fa3bbb2021-02-03 06:01:14 -0700267
268/* device declarations - these allow DM_DEVICE_REF() to be used */
Simon Glassc7b4b832021-02-03 06:01:20 -0700269DM_DEVICE_DECL(i2c);
Simon Glass3fa3bbb2021-02-03 06:01:14 -0700270DM_DEVICE_DECL(root);
Simon Glassc7b4b832021-02-03 06:01:20 -0700271DM_DEVICE_DECL(some_bus);
Simon Glass3fa3bbb2021-02-03 06:01:14 -0700272DM_DEVICE_DECL(spl_test);
Simon Glass3fa3bbb2021-02-03 06:01:14 -0700273DM_DEVICE_DECL(spl_test3);
Simon Glassc7b4b832021-02-03 06:01:20 -0700274DM_DEVICE_DECL(test);
275DM_DEVICE_DECL(test0);
Simon Glass3fa3bbb2021-02-03 06:01:14 -0700276
277/* uclass driver declarations - needed for DM_UCLASS_DRIVER_REF() */
278DM_UCLASS_DRIVER_DECL(i2c);
279DM_UCLASS_DRIVER_DECL(misc);
Simon Glass3fa3bbb2021-02-03 06:01:14 -0700280DM_UCLASS_DRIVER_DECL(root);
Simon Glassc7b4b832021-02-03 06:01:20 -0700281DM_UCLASS_DRIVER_DECL(testbus);
282DM_UCLASS_DRIVER_DECL(testfdt);
Simon Glass3fa3bbb2021-02-03 06:01:14 -0700283
284/* uclass declarations - needed for DM_UCLASS_REF() */
285DM_UCLASS_DECL(i2c);
286DM_UCLASS_DECL(misc);
Simon Glass3fa3bbb2021-02-03 06:01:14 -0700287DM_UCLASS_DECL(root);
Simon Glassc7b4b832021-02-03 06:01:20 -0700288DM_UCLASS_DECL(testbus);
289DM_UCLASS_DECL(testfdt);
Simon Glass3fa3bbb2021-02-03 06:01:14 -0700290'''
Simon Glass07ee48e2020-12-28 20:34:49 -0700291 struct_text = HEADER + '''
Simon Glass32a8d222021-02-03 06:00:57 -0700292struct dtd_sandbox_i2c {
Simon Glass90e5f0a2017-08-29 14:15:51 -0600293};
Simon Glass32a8d222021-02-03 06:00:57 -0700294struct dtd_sandbox_pmic {
Simon Glass90e5f0a2017-08-29 14:15:51 -0600295\tbool\t\tlow_power;
296\tfdt64_t\t\treg[2];
297};
Simon Glass9d2eb922017-06-18 22:09:06 -0600298struct dtd_sandbox_spl_test {
Simon Glass7f5e2262020-07-07 21:32:06 -0600299\tconst char * acpi_name;
Simon Glass9d2eb922017-06-18 22:09:06 -0600300\tbool\t\tboolval;
301\tunsigned char\tbytearray[3];
302\tunsigned char\tbyteval;
303\tfdt32_t\t\tintarray[4];
304\tfdt32_t\t\tintval;
305\tunsigned char\tlongbytearray[9];
Simon Glass9c526332018-07-06 10:27:28 -0600306\tunsigned char\tnotstring[5];
Simon Glass9d2eb922017-06-18 22:09:06 -0600307\tconst char *\tstringarray[3];
308\tconst char *\tstringval;
309};
Simon Glass07ee48e2020-12-28 20:34:49 -0700310'''
Simon Glass07ee48e2020-12-28 20:34:49 -0700311 platdata_text = C_HEADER + '''
Simon Glassbe749002021-02-03 06:01:15 -0700312/*
Simon Glasse2119082021-02-03 06:01:19 -0700313 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
314 *
315 * idx driver_info driver
316 * --- -------------------- --------------------
317 * 0: i2c_at_0 sandbox_i2c
318 * 1: pmic_at_9 sandbox_pmic
319 * 2: spl_test sandbox_spl_test
320 * 3: spl_test2 sandbox_spl_test
321 * 4: spl_test3 sandbox_spl_test
322 * --- -------------------- --------------------
323 */
324
325/*
Simon Glassbe749002021-02-03 06:01:15 -0700326 * Node /i2c@0 index 0
327 * driver sandbox_i2c parent None
328 */
Simon Glass32a8d222021-02-03 06:00:57 -0700329static struct dtd_sandbox_i2c dtv_i2c_at_0 = {
Simon Glass192f8132020-10-03 11:31:25 -0600330};
Simon Glass1d8364a2020-12-28 20:34:54 -0700331U_BOOT_DRVINFO(i2c_at_0) = {
Simon Glass32a8d222021-02-03 06:00:57 -0700332\t.name\t\t= "sandbox_i2c",
Simon Glasse2119082021-02-03 06:01:19 -0700333\t.plat\t\t= &dtv_i2c_at_0,
Simon Glass39edb952020-12-03 16:55:19 -0700334\t.plat_size\t= sizeof(dtv_i2c_at_0),
Simon Glass36b15e22020-10-03 11:31:35 -0600335\t.parent_idx\t= -1,
Simon Glass192f8132020-10-03 11:31:25 -0600336};
337
Simon Glassbe749002021-02-03 06:01:15 -0700338/*
339 * Node /i2c@0/pmic@9 index 1
340 * driver sandbox_pmic parent sandbox_i2c
341 */
Simon Glass32a8d222021-02-03 06:00:57 -0700342static struct dtd_sandbox_pmic dtv_pmic_at_9 = {
Simon Glass192f8132020-10-03 11:31:25 -0600343\t.low_power\t\t= true,
344\t.reg\t\t\t= {0x9, 0x0},
345};
Simon Glass1d8364a2020-12-28 20:34:54 -0700346U_BOOT_DRVINFO(pmic_at_9) = {
Simon Glass32a8d222021-02-03 06:00:57 -0700347\t.name\t\t= "sandbox_pmic",
Simon Glasse2119082021-02-03 06:01:19 -0700348\t.plat\t\t= &dtv_pmic_at_9,
Simon Glass39edb952020-12-03 16:55:19 -0700349\t.plat_size\t= sizeof(dtv_pmic_at_9),
Simon Glass36b15e22020-10-03 11:31:35 -0600350\t.parent_idx\t= 0,
Simon Glass192f8132020-10-03 11:31:25 -0600351};
352
Simon Glassbe749002021-02-03 06:01:15 -0700353/*
354 * Node /spl-test index 2
355 * driver sandbox_spl_test parent None
356 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300357static struct dtd_sandbox_spl_test dtv_spl_test = {
Simon Glassc82de562019-05-17 22:00:32 -0600358\t.boolval\t\t= true,
Simon Glass9d2eb922017-06-18 22:09:06 -0600359\t.bytearray\t\t= {0x6, 0x0, 0x0},
360\t.byteval\t\t= 0x5,
Simon Glassc82de562019-05-17 22:00:32 -0600361\t.intarray\t\t= {0x2, 0x3, 0x4, 0x0},
Simon Glass9d2eb922017-06-18 22:09:06 -0600362\t.intval\t\t\t= 0x1,
Simon Glass131e0b02017-08-29 14:15:49 -0600363\t.longbytearray\t\t= {0x9, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf, 0x10,
364\t\t0x11},
Simon Glassc82de562019-05-17 22:00:32 -0600365\t.notstring\t\t= {0x20, 0x21, 0x22, 0x10, 0x0},
Simon Glass9d2eb922017-06-18 22:09:06 -0600366\t.stringarray\t\t= {"multi-word", "message", ""},
Simon Glassc82de562019-05-17 22:00:32 -0600367\t.stringval\t\t= "message",
Simon Glass9d2eb922017-06-18 22:09:06 -0600368};
Simon Glass1d8364a2020-12-28 20:34:54 -0700369U_BOOT_DRVINFO(spl_test) = {
Simon Glass9d2eb922017-06-18 22:09:06 -0600370\t.name\t\t= "sandbox_spl_test",
Simon Glasse2119082021-02-03 06:01:19 -0700371\t.plat\t\t= &dtv_spl_test,
Simon Glass39edb952020-12-03 16:55:19 -0700372\t.plat_size\t= sizeof(dtv_spl_test),
Simon Glass36b15e22020-10-03 11:31:35 -0600373\t.parent_idx\t= -1,
Simon Glass9d2eb922017-06-18 22:09:06 -0600374};
375
Simon Glassbe749002021-02-03 06:01:15 -0700376/*
377 * Node /spl-test2 index 3
378 * driver sandbox_spl_test parent None
379 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300380static struct dtd_sandbox_spl_test dtv_spl_test2 = {
Simon Glass7f5e2262020-07-07 21:32:06 -0600381\t.acpi_name\t\t= "\\\\_SB.GPO0",
Simon Glass9d2eb922017-06-18 22:09:06 -0600382\t.bytearray\t\t= {0x1, 0x23, 0x34},
383\t.byteval\t\t= 0x8,
Simon Glassc82de562019-05-17 22:00:32 -0600384\t.intarray\t\t= {0x5, 0x0, 0x0, 0x0},
Simon Glass9d2eb922017-06-18 22:09:06 -0600385\t.intval\t\t\t= 0x3,
Simon Glass8034e4d2020-10-03 11:31:27 -0600386\t.longbytearray\t\t= {0x9, 0xa, 0xb, 0xc, 0x0, 0x0, 0x0, 0x0,
Simon Glass131e0b02017-08-29 14:15:49 -0600387\t\t0x0},
Simon Glass9d2eb922017-06-18 22:09:06 -0600388\t.stringarray\t\t= {"another", "multi-word", "message"},
Simon Glassc82de562019-05-17 22:00:32 -0600389\t.stringval\t\t= "message2",
Simon Glass9d2eb922017-06-18 22:09:06 -0600390};
Simon Glass1d8364a2020-12-28 20:34:54 -0700391U_BOOT_DRVINFO(spl_test2) = {
Simon Glass9d2eb922017-06-18 22:09:06 -0600392\t.name\t\t= "sandbox_spl_test",
Simon Glasse2119082021-02-03 06:01:19 -0700393\t.plat\t\t= &dtv_spl_test2,
Simon Glass39edb952020-12-03 16:55:19 -0700394\t.plat_size\t= sizeof(dtv_spl_test2),
Simon Glass36b15e22020-10-03 11:31:35 -0600395\t.parent_idx\t= -1,
Simon Glass9d2eb922017-06-18 22:09:06 -0600396};
397
Simon Glassbe749002021-02-03 06:01:15 -0700398/*
399 * Node /spl-test3 index 4
400 * driver sandbox_spl_test parent None
401 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300402static struct dtd_sandbox_spl_test dtv_spl_test3 = {
Simon Glass8034e4d2020-10-03 11:31:27 -0600403\t.longbytearray\t\t= {0x9, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf, 0x10,
404\t\t0x0},
Simon Glass9d2eb922017-06-18 22:09:06 -0600405\t.stringarray\t\t= {"one", "", ""},
406};
Simon Glass1d8364a2020-12-28 20:34:54 -0700407U_BOOT_DRVINFO(spl_test3) = {
Simon Glass9d2eb922017-06-18 22:09:06 -0600408\t.name\t\t= "sandbox_spl_test",
Simon Glasse2119082021-02-03 06:01:19 -0700409\t.plat\t\t= &dtv_spl_test3,
Simon Glass39edb952020-12-03 16:55:19 -0700410\t.plat_size\t= sizeof(dtv_spl_test3),
Simon Glass36b15e22020-10-03 11:31:35 -0600411\t.parent_idx\t= -1,
Simon Glass9d2eb922017-06-18 22:09:06 -0600412};
413
Simon Glass2500de22020-12-28 20:35:05 -0700414'''
Simon Glassc7b4b832021-02-03 06:01:20 -0700415 uclass_text = UCLASS_HEADER
416 uclass_text_inst = '''
417
418#include <common.h>
419#include <dm.h>
420#include <dt-structs.h>
421
422/*
423 * uclass declarations
424 *
425 * Sequence numbers:
426 * i2c: UCLASS_I2C
427 * 4: /i2c
428 * misc: UCLASS_MISC
429 * 0: /spl-test
430 * 1: /spl-test3
431 * root: UCLASS_ROOT
432 * 0: /
433 * testbus: UCLASS_TEST_BUS
434 * 2: /some-bus
435 * testfdt: UCLASS_TEST_FDT
436 * 1: /some-bus/test
437 * 2: /some-bus/test0
438 */
439
440struct list_head uclass_head = {
441 .prev = &DM_UCLASS_REF(testfdt)->sibling_node,
442 .next = &DM_UCLASS_REF(i2c)->sibling_node,
443};
444
445DM_UCLASS_INST(i2c) = {
446 .uc_drv = DM_UCLASS_DRIVER_REF(i2c),
447 .sibling_node = {
448 .prev = &uclass_head,
449 .next = &DM_UCLASS_REF(misc)->sibling_node,
450 },
451 .dev_head = {
452 .prev = &DM_DEVICE_REF(i2c)->uclass_node,
453 .next = &DM_DEVICE_REF(i2c)->uclass_node,
454 },
455};
456
457DM_UCLASS_INST(misc) = {
458 .uc_drv = DM_UCLASS_DRIVER_REF(misc),
459 .sibling_node = {
460 .prev = &DM_UCLASS_REF(i2c)->sibling_node,
461 .next = &DM_UCLASS_REF(root)->sibling_node,
462 },
463 .dev_head = {
464 .prev = &DM_DEVICE_REF(spl_test3)->uclass_node,
465 .next = &DM_DEVICE_REF(spl_test)->uclass_node,
466 },
467};
468
469DM_UCLASS_INST(root) = {
470 .uc_drv = DM_UCLASS_DRIVER_REF(root),
471 .sibling_node = {
472 .prev = &DM_UCLASS_REF(misc)->sibling_node,
473 .next = &DM_UCLASS_REF(testbus)->sibling_node,
474 },
475 .dev_head = {
476 .prev = &DM_DEVICE_REF(root)->uclass_node,
477 .next = &DM_DEVICE_REF(root)->uclass_node,
478 },
479};
480
481DM_UCLASS_INST(testbus) = {
482 .uc_drv = DM_UCLASS_DRIVER_REF(testbus),
483 .sibling_node = {
484 .prev = &DM_UCLASS_REF(root)->sibling_node,
485 .next = &DM_UCLASS_REF(testfdt)->sibling_node,
486 },
487 .dev_head = {
488 .prev = &DM_DEVICE_REF(some_bus)->uclass_node,
489 .next = &DM_DEVICE_REF(some_bus)->uclass_node,
490 },
491};
492
493#include <dm/test.h>
494u8 _testfdt_priv_[sizeof(struct dm_test_uc_priv)]
495 __attribute__ ((section (".priv_data")));
496DM_UCLASS_INST(testfdt) = {
497 .priv_ = _testfdt_priv_,
498 .uc_drv = DM_UCLASS_DRIVER_REF(testfdt),
499 .sibling_node = {
500 .prev = &DM_UCLASS_REF(testbus)->sibling_node,
501 .next = &uclass_head,
502 },
503 .dev_head = {
504 .prev = &DM_DEVICE_REF(test0)->uclass_node,
505 .next = &DM_DEVICE_REF(test)->uclass_node,
506 },
507};
508
509'''
Simon Glass07ee48e2020-12-28 20:34:49 -0700510
511 def test_simple(self):
512 """Test output from some simple nodes with various types of data"""
513 dtb_file = get_dtb_file('dtoc_test_simple.dts')
514 output = tools.GetOutputFilename('output')
515 self.run_test(['struct'], dtb_file, output)
516 with open(output) as infile:
517 data = infile.read()
518
519 self._check_strings(self.struct_text, data)
520
521 self.run_test(['platdata'], dtb_file, output)
522 with open(output) as infile:
523 data = infile.read()
524
525 self._check_strings(self.platdata_text, data)
Simon Glass9d2eb922017-06-18 22:09:06 -0600526
Simon Glass3fa3bbb2021-02-03 06:01:14 -0700527 self.run_test(['decl'], dtb_file, output)
528 with open(output) as infile:
529 data = infile.read()
530
531 self._check_strings(self.decl_text, data)
532
Simon Glass4e8e8462020-12-28 20:34:52 -0700533 # Try the 'all' command
534 self.run_test(['all'], dtb_file, output)
535 data = tools.ReadFile(output, binary=False)
Simon Glass3fa3bbb2021-02-03 06:01:14 -0700536 self._check_strings(self.decl_text + self.platdata_text +
Simon Glassc7b4b832021-02-03 06:01:20 -0700537 self.struct_text + self.uclass_text, data)
Simon Glass4e8e8462020-12-28 20:34:52 -0700538
Walter Lozanoe675d962020-07-03 08:07:17 -0300539 def test_driver_alias(self):
540 """Test output from a device tree file with a driver alias"""
541 dtb_file = get_dtb_file('dtoc_test_driver_alias.dts')
542 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300543 self.run_test(['struct'], dtb_file, output)
Walter Lozanoe675d962020-07-03 08:07:17 -0300544 with open(output) as infile:
545 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700546 self._check_strings(HEADER + '''
Walter Lozanoe675d962020-07-03 08:07:17 -0300547struct dtd_sandbox_gpio {
548\tconst char *\tgpio_bank_name;
549\tbool\t\tgpio_controller;
550\tfdt32_t\t\tsandbox_gpio_count;
551};
Walter Lozanoe675d962020-07-03 08:07:17 -0300552''', data)
553
Walter Lozanoa324e412020-06-25 01:10:08 -0300554 self.run_test(['platdata'], dtb_file, output)
Walter Lozanoe675d962020-07-03 08:07:17 -0300555 with open(output) as infile:
556 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700557 self._check_strings(C_HEADER + '''
Simon Glassbe749002021-02-03 06:01:15 -0700558/*
Simon Glasse2119082021-02-03 06:01:19 -0700559 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
560 *
561 * idx driver_info driver
562 * --- -------------------- --------------------
563 * 0: gpios_at_0 sandbox_gpio
564 * --- -------------------- --------------------
565 */
566
567/*
Simon Glassbe749002021-02-03 06:01:15 -0700568 * Node /gpios@0 index 0
569 * driver sandbox_gpio parent None
570 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300571static struct dtd_sandbox_gpio dtv_gpios_at_0 = {
Walter Lozanoe675d962020-07-03 08:07:17 -0300572\t.gpio_bank_name\t\t= "a",
573\t.gpio_controller\t= true,
574\t.sandbox_gpio_count\t= 0x14,
575};
Simon Glass1d8364a2020-12-28 20:34:54 -0700576U_BOOT_DRVINFO(gpios_at_0) = {
Walter Lozanoe675d962020-07-03 08:07:17 -0300577\t.name\t\t= "sandbox_gpio",
Simon Glasse2119082021-02-03 06:01:19 -0700578\t.plat\t\t= &dtv_gpios_at_0,
Simon Glass39edb952020-12-03 16:55:19 -0700579\t.plat_size\t= sizeof(dtv_gpios_at_0),
Simon Glass36b15e22020-10-03 11:31:35 -0600580\t.parent_idx\t= -1,
Walter Lozanoe675d962020-07-03 08:07:17 -0300581};
582
583''', data)
584
Walter Lozanoa324e412020-06-25 01:10:08 -0300585 def test_invalid_driver(self):
586 """Test output from a device tree file with an invalid driver"""
587 dtb_file = get_dtb_file('dtoc_test_invalid_driver.dts')
588 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -0700589 with test_util.capture_sys_output() as _:
Simon Glass3809ad92021-02-03 06:01:12 -0700590 dtb_platdata.run_steps(
591 ['struct'], dtb_file, False, output, [], None, False,
592 scan=copy_scan())
Walter Lozanoa324e412020-06-25 01:10:08 -0300593 with open(output) as infile:
594 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700595 self._check_strings(HEADER + '''
Walter Lozanoa324e412020-06-25 01:10:08 -0300596struct dtd_invalid {
597};
598''', data)
599
Simon Glassa60cabd2020-12-28 20:34:47 -0700600 with test_util.capture_sys_output() as _:
Simon Glass3809ad92021-02-03 06:01:12 -0700601 dtb_platdata.run_steps(
602 ['platdata'], dtb_file, False, output, [], None, False,
603 scan=copy_scan())
Walter Lozanoa324e412020-06-25 01:10:08 -0300604 with open(output) as infile:
605 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700606 self._check_strings(C_HEADER + '''
Simon Glasse2119082021-02-03 06:01:19 -0700607/*
608 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
609 *
610 * idx driver_info driver
611 * --- -------------------- --------------------
612 * 0: spl_test invalid
613 * --- -------------------- --------------------
614 */
615
Simon Glass192f8132020-10-03 11:31:25 -0600616/* Node /spl-test index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300617static struct dtd_invalid dtv_spl_test = {
Walter Lozanoa324e412020-06-25 01:10:08 -0300618};
Simon Glass1d8364a2020-12-28 20:34:54 -0700619U_BOOT_DRVINFO(spl_test) = {
Walter Lozanoa324e412020-06-25 01:10:08 -0300620\t.name\t\t= "invalid",
Simon Glasse2119082021-02-03 06:01:19 -0700621\t.plat\t\t= &dtv_spl_test,
Simon Glass39edb952020-12-03 16:55:19 -0700622\t.plat_size\t= sizeof(dtv_spl_test),
Simon Glass36b15e22020-10-03 11:31:35 -0600623\t.parent_idx\t= -1,
Walter Lozanoa324e412020-06-25 01:10:08 -0300624};
625
626''', data)
627
Simon Glass9d2eb922017-06-18 22:09:06 -0600628 def test_phandle(self):
629 """Test output from a node containing a phandle reference"""
630 dtb_file = get_dtb_file('dtoc_test_phandle.dts')
631 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300632 self.run_test(['struct'], dtb_file, output)
Simon Glass9d2eb922017-06-18 22:09:06 -0600633 with open(output) as infile:
634 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700635 self._check_strings(HEADER + '''
Simon Glass9d2eb922017-06-18 22:09:06 -0600636struct dtd_source {
Simon Glass3deeb472017-08-29 14:15:59 -0600637\tstruct phandle_2_arg clocks[4];
Simon Glass9d2eb922017-06-18 22:09:06 -0600638};
639struct dtd_target {
640\tfdt32_t\t\tintval;
641};
642''', data)
643
Walter Lozanoa324e412020-06-25 01:10:08 -0300644 self.run_test(['platdata'], dtb_file, output)
Simon Glass9d2eb922017-06-18 22:09:06 -0600645 with open(output) as infile:
646 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700647 self._check_strings(C_HEADER + '''
Simon Glasse2119082021-02-03 06:01:19 -0700648/*
649 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
650 *
651 * idx driver_info driver
652 * --- -------------------- --------------------
653 * 0: phandle2_target target
654 * 1: phandle3_target target
655 * 2: phandle_source source
656 * 3: phandle_source2 source
657 * 4: phandle_target target
658 * --- -------------------- --------------------
659 */
660
Simon Glass192f8132020-10-03 11:31:25 -0600661/* Node /phandle2-target index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300662static struct dtd_target dtv_phandle2_target = {
Simon Glass3deeb472017-08-29 14:15:59 -0600663\t.intval\t\t\t= 0x1,
664};
Simon Glass1d8364a2020-12-28 20:34:54 -0700665U_BOOT_DRVINFO(phandle2_target) = {
Simon Glass3deeb472017-08-29 14:15:59 -0600666\t.name\t\t= "target",
Simon Glasse2119082021-02-03 06:01:19 -0700667\t.plat\t\t= &dtv_phandle2_target,
Simon Glass39edb952020-12-03 16:55:19 -0700668\t.plat_size\t= sizeof(dtv_phandle2_target),
Simon Glass36b15e22020-10-03 11:31:35 -0600669\t.parent_idx\t= -1,
Simon Glass3deeb472017-08-29 14:15:59 -0600670};
671
Simon Glass192f8132020-10-03 11:31:25 -0600672/* Node /phandle3-target index 1 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300673static struct dtd_target dtv_phandle3_target = {
Simon Glass3deeb472017-08-29 14:15:59 -0600674\t.intval\t\t\t= 0x2,
675};
Simon Glass1d8364a2020-12-28 20:34:54 -0700676U_BOOT_DRVINFO(phandle3_target) = {
Simon Glass3deeb472017-08-29 14:15:59 -0600677\t.name\t\t= "target",
Simon Glasse2119082021-02-03 06:01:19 -0700678\t.plat\t\t= &dtv_phandle3_target,
Simon Glass39edb952020-12-03 16:55:19 -0700679\t.plat_size\t= sizeof(dtv_phandle3_target),
Simon Glass36b15e22020-10-03 11:31:35 -0600680\t.parent_idx\t= -1,
Simon Glass3deeb472017-08-29 14:15:59 -0600681};
682
Simon Glass192f8132020-10-03 11:31:25 -0600683/* Node /phandle-source index 2 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300684static struct dtd_source dtv_phandle_source = {
Simon Glassd0cd0752017-08-29 14:15:57 -0600685\t.clocks\t\t\t= {
Simon Glass5792f4b2020-10-03 11:31:40 -0600686\t\t\t{4, {}},
687\t\t\t{0, {11}},
688\t\t\t{1, {12, 13}},
689\t\t\t{4, {}},},
Simon Glass9d2eb922017-06-18 22:09:06 -0600690};
Simon Glass1d8364a2020-12-28 20:34:54 -0700691U_BOOT_DRVINFO(phandle_source) = {
Simon Glass9d2eb922017-06-18 22:09:06 -0600692\t.name\t\t= "source",
Simon Glasse2119082021-02-03 06:01:19 -0700693\t.plat\t\t= &dtv_phandle_source,
Simon Glass39edb952020-12-03 16:55:19 -0700694\t.plat_size\t= sizeof(dtv_phandle_source),
Simon Glass36b15e22020-10-03 11:31:35 -0600695\t.parent_idx\t= -1,
Simon Glass9d2eb922017-06-18 22:09:06 -0600696};
697
Simon Glass192f8132020-10-03 11:31:25 -0600698/* Node /phandle-source2 index 3 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300699static struct dtd_source dtv_phandle_source2 = {
Simon Glass609e2b12018-07-06 10:27:31 -0600700\t.clocks\t\t\t= {
Simon Glass5792f4b2020-10-03 11:31:40 -0600701\t\t\t{4, {}},},
Simon Glass609e2b12018-07-06 10:27:31 -0600702};
Simon Glass1d8364a2020-12-28 20:34:54 -0700703U_BOOT_DRVINFO(phandle_source2) = {
Simon Glass609e2b12018-07-06 10:27:31 -0600704\t.name\t\t= "source",
Simon Glasse2119082021-02-03 06:01:19 -0700705\t.plat\t\t= &dtv_phandle_source2,
Simon Glass39edb952020-12-03 16:55:19 -0700706\t.plat_size\t= sizeof(dtv_phandle_source2),
Simon Glass36b15e22020-10-03 11:31:35 -0600707\t.parent_idx\t= -1,
Simon Glass609e2b12018-07-06 10:27:31 -0600708};
709
Simon Glass16382ce2020-12-28 20:35:04 -0700710/* Node /phandle-target index 4 */
711static struct dtd_target dtv_phandle_target = {
712\t.intval\t\t\t= 0x0,
713};
714U_BOOT_DRVINFO(phandle_target) = {
715\t.name\t\t= "target",
Simon Glasse2119082021-02-03 06:01:19 -0700716\t.plat\t\t= &dtv_phandle_target,
Simon Glass16382ce2020-12-28 20:35:04 -0700717\t.plat_size\t= sizeof(dtv_phandle_target),
718\t.parent_idx\t= -1,
719};
720
Simon Glass9d2eb922017-06-18 22:09:06 -0600721''', data)
722
Simon Glass961c1ce2018-07-06 10:27:35 -0600723 def test_phandle_single(self):
724 """Test output from a node containing a phandle reference"""
725 dtb_file = get_dtb_file('dtoc_test_phandle_single.dts')
726 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300727 self.run_test(['struct'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -0600728 with open(output) as infile:
729 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700730 self._check_strings(HEADER + '''
Simon Glass961c1ce2018-07-06 10:27:35 -0600731struct dtd_source {
732\tstruct phandle_0_arg clocks[1];
733};
734struct dtd_target {
735\tfdt32_t\t\tintval;
736};
737''', data)
738
739 def test_phandle_reorder(self):
740 """Test that phandle targets are generated before their references"""
741 dtb_file = get_dtb_file('dtoc_test_phandle_reorder.dts')
742 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300743 self.run_test(['platdata'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -0600744 with open(output) as infile:
745 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700746 self._check_strings(C_HEADER + '''
Simon Glasse2119082021-02-03 06:01:19 -0700747/*
748 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
749 *
750 * idx driver_info driver
751 * --- -------------------- --------------------
752 * 0: phandle_source2 source
753 * 1: phandle_target target
754 * --- -------------------- --------------------
755 */
756
Simon Glass192f8132020-10-03 11:31:25 -0600757/* Node /phandle-source2 index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300758static struct dtd_source dtv_phandle_source2 = {
Simon Glass961c1ce2018-07-06 10:27:35 -0600759\t.clocks\t\t\t= {
Simon Glass5792f4b2020-10-03 11:31:40 -0600760\t\t\t{1, {}},},
Simon Glass961c1ce2018-07-06 10:27:35 -0600761};
Simon Glass1d8364a2020-12-28 20:34:54 -0700762U_BOOT_DRVINFO(phandle_source2) = {
Simon Glass961c1ce2018-07-06 10:27:35 -0600763\t.name\t\t= "source",
Simon Glasse2119082021-02-03 06:01:19 -0700764\t.plat\t\t= &dtv_phandle_source2,
Simon Glass39edb952020-12-03 16:55:19 -0700765\t.plat_size\t= sizeof(dtv_phandle_source2),
Simon Glass36b15e22020-10-03 11:31:35 -0600766\t.parent_idx\t= -1,
Simon Glass961c1ce2018-07-06 10:27:35 -0600767};
768
Simon Glass16382ce2020-12-28 20:35:04 -0700769/* Node /phandle-target index 1 */
770static struct dtd_target dtv_phandle_target = {
771};
772U_BOOT_DRVINFO(phandle_target) = {
773\t.name\t\t= "target",
Simon Glasse2119082021-02-03 06:01:19 -0700774\t.plat\t\t= &dtv_phandle_target,
Simon Glass16382ce2020-12-28 20:35:04 -0700775\t.plat_size\t= sizeof(dtv_phandle_target),
776\t.parent_idx\t= -1,
777};
778
Simon Glass961c1ce2018-07-06 10:27:35 -0600779''', data)
780
Walter Lozano5541fc02020-06-25 01:10:17 -0300781 def test_phandle_cd_gpio(self):
782 """Test that phandle targets are generated when unsing cd-gpios"""
783 dtb_file = get_dtb_file('dtoc_test_phandle_cd_gpios.dts')
784 output = tools.GetOutputFilename('output')
Simon Glass3809ad92021-02-03 06:01:12 -0700785 dtb_platdata.run_steps(
786 ['platdata'], dtb_file, False, output, [], None, False,
787 warning_disabled=True, scan=copy_scan())
Walter Lozano5541fc02020-06-25 01:10:17 -0300788 with open(output) as infile:
789 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700790 self._check_strings(C_HEADER + '''
Simon Glasse2119082021-02-03 06:01:19 -0700791/*
792 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
793 *
794 * idx driver_info driver
795 * --- -------------------- --------------------
796 * 0: phandle2_target target
797 * 1: phandle3_target target
798 * 2: phandle_source source
799 * 3: phandle_source2 source
800 * 4: phandle_target target
801 * --- -------------------- --------------------
802 */
803
Simon Glass192f8132020-10-03 11:31:25 -0600804/* Node /phandle2-target index 0 */
Walter Lozano5541fc02020-06-25 01:10:17 -0300805static struct dtd_target dtv_phandle2_target = {
806\t.intval\t\t\t= 0x1,
807};
Simon Glass1d8364a2020-12-28 20:34:54 -0700808U_BOOT_DRVINFO(phandle2_target) = {
Walter Lozano5541fc02020-06-25 01:10:17 -0300809\t.name\t\t= "target",
Simon Glasse2119082021-02-03 06:01:19 -0700810\t.plat\t\t= &dtv_phandle2_target,
Simon Glass39edb952020-12-03 16:55:19 -0700811\t.plat_size\t= sizeof(dtv_phandle2_target),
Simon Glass36b15e22020-10-03 11:31:35 -0600812\t.parent_idx\t= -1,
Walter Lozano5541fc02020-06-25 01:10:17 -0300813};
814
Simon Glass192f8132020-10-03 11:31:25 -0600815/* Node /phandle3-target index 1 */
Walter Lozano5541fc02020-06-25 01:10:17 -0300816static struct dtd_target dtv_phandle3_target = {
817\t.intval\t\t\t= 0x2,
818};
Simon Glass1d8364a2020-12-28 20:34:54 -0700819U_BOOT_DRVINFO(phandle3_target) = {
Walter Lozano5541fc02020-06-25 01:10:17 -0300820\t.name\t\t= "target",
Simon Glasse2119082021-02-03 06:01:19 -0700821\t.plat\t\t= &dtv_phandle3_target,
Simon Glass39edb952020-12-03 16:55:19 -0700822\t.plat_size\t= sizeof(dtv_phandle3_target),
Simon Glass36b15e22020-10-03 11:31:35 -0600823\t.parent_idx\t= -1,
Walter Lozano5541fc02020-06-25 01:10:17 -0300824};
825
Simon Glass192f8132020-10-03 11:31:25 -0600826/* Node /phandle-source index 2 */
Walter Lozano5541fc02020-06-25 01:10:17 -0300827static struct dtd_source dtv_phandle_source = {
828\t.cd_gpios\t\t= {
Simon Glass5792f4b2020-10-03 11:31:40 -0600829\t\t\t{4, {}},
830\t\t\t{0, {11}},
831\t\t\t{1, {12, 13}},
832\t\t\t{4, {}},},
Walter Lozano5541fc02020-06-25 01:10:17 -0300833};
Simon Glass1d8364a2020-12-28 20:34:54 -0700834U_BOOT_DRVINFO(phandle_source) = {
Walter Lozano5541fc02020-06-25 01:10:17 -0300835\t.name\t\t= "source",
Simon Glasse2119082021-02-03 06:01:19 -0700836\t.plat\t\t= &dtv_phandle_source,
Simon Glass39edb952020-12-03 16:55:19 -0700837\t.plat_size\t= sizeof(dtv_phandle_source),
Simon Glass36b15e22020-10-03 11:31:35 -0600838\t.parent_idx\t= -1,
Walter Lozano5541fc02020-06-25 01:10:17 -0300839};
840
Simon Glass192f8132020-10-03 11:31:25 -0600841/* Node /phandle-source2 index 3 */
Walter Lozano5541fc02020-06-25 01:10:17 -0300842static struct dtd_source dtv_phandle_source2 = {
843\t.cd_gpios\t\t= {
Simon Glass5792f4b2020-10-03 11:31:40 -0600844\t\t\t{4, {}},},
Walter Lozano5541fc02020-06-25 01:10:17 -0300845};
Simon Glass1d8364a2020-12-28 20:34:54 -0700846U_BOOT_DRVINFO(phandle_source2) = {
Walter Lozano5541fc02020-06-25 01:10:17 -0300847\t.name\t\t= "source",
Simon Glasse2119082021-02-03 06:01:19 -0700848\t.plat\t\t= &dtv_phandle_source2,
Simon Glass39edb952020-12-03 16:55:19 -0700849\t.plat_size\t= sizeof(dtv_phandle_source2),
Simon Glass36b15e22020-10-03 11:31:35 -0600850\t.parent_idx\t= -1,
Walter Lozano5541fc02020-06-25 01:10:17 -0300851};
852
Simon Glass16382ce2020-12-28 20:35:04 -0700853/* Node /phandle-target index 4 */
854static struct dtd_target dtv_phandle_target = {
855\t.intval\t\t\t= 0x0,
856};
857U_BOOT_DRVINFO(phandle_target) = {
858\t.name\t\t= "target",
Simon Glasse2119082021-02-03 06:01:19 -0700859\t.plat\t\t= &dtv_phandle_target,
Simon Glass16382ce2020-12-28 20:35:04 -0700860\t.plat_size\t= sizeof(dtv_phandle_target),
861\t.parent_idx\t= -1,
862};
863
Walter Lozano5541fc02020-06-25 01:10:17 -0300864''', data)
865
Simon Glass961c1ce2018-07-06 10:27:35 -0600866 def test_phandle_bad(self):
867 """Test a node containing an invalid phandle fails"""
Simon Glass04150022018-10-01 21:12:43 -0600868 dtb_file = get_dtb_file('dtoc_test_phandle_bad.dts',
869 capture_stderr=True)
Simon Glass961c1ce2018-07-06 10:27:35 -0600870 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -0700871 with self.assertRaises(ValueError) as exc:
Walter Lozanoa324e412020-06-25 01:10:08 -0300872 self.run_test(['struct'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -0600873 self.assertIn("Cannot parse 'clocks' in node 'phandle-source'",
Simon Glassa60cabd2020-12-28 20:34:47 -0700874 str(exc.exception))
Simon Glass961c1ce2018-07-06 10:27:35 -0600875
876 def test_phandle_bad2(self):
877 """Test a phandle target missing its #*-cells property"""
Simon Glass04150022018-10-01 21:12:43 -0600878 dtb_file = get_dtb_file('dtoc_test_phandle_bad2.dts',
879 capture_stderr=True)
Simon Glass961c1ce2018-07-06 10:27:35 -0600880 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -0700881 with self.assertRaises(ValueError) as exc:
Walter Lozanoa324e412020-06-25 01:10:08 -0300882 self.run_test(['struct'], dtb_file, output)
Walter Lozano179f0b62020-06-25 01:10:16 -0300883 self.assertIn("Node 'phandle-target' has no cells property",
Simon Glassa60cabd2020-12-28 20:34:47 -0700884 str(exc.exception))
Simon Glass961c1ce2018-07-06 10:27:35 -0600885
Simon Glass1b1fe412017-08-29 14:15:50 -0600886 def test_addresses64(self):
887 """Test output from a node with a 'reg' property with na=2, ns=2"""
888 dtb_file = get_dtb_file('dtoc_test_addr64.dts')
889 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300890 self.run_test(['struct'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -0600891 with open(output) as infile:
892 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700893 self._check_strings(HEADER + '''
Simon Glass1b1fe412017-08-29 14:15:50 -0600894struct dtd_test1 {
895\tfdt64_t\t\treg[2];
896};
897struct dtd_test2 {
898\tfdt64_t\t\treg[2];
899};
900struct dtd_test3 {
901\tfdt64_t\t\treg[4];
902};
903''', data)
904
Walter Lozanoa324e412020-06-25 01:10:08 -0300905 self.run_test(['platdata'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -0600906 with open(output) as infile:
907 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700908 self._check_strings(C_HEADER + '''
Simon Glasse2119082021-02-03 06:01:19 -0700909/*
910 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
911 *
912 * idx driver_info driver
913 * --- -------------------- --------------------
914 * 0: test1 test1
915 * 1: test2 test2
916 * 2: test3 test3
917 * --- -------------------- --------------------
918 */
919
Simon Glass192f8132020-10-03 11:31:25 -0600920/* Node /test1 index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300921static struct dtd_test1 dtv_test1 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600922\t.reg\t\t\t= {0x1234, 0x5678},
923};
Simon Glass1d8364a2020-12-28 20:34:54 -0700924U_BOOT_DRVINFO(test1) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600925\t.name\t\t= "test1",
Simon Glasse2119082021-02-03 06:01:19 -0700926\t.plat\t\t= &dtv_test1,
Simon Glass39edb952020-12-03 16:55:19 -0700927\t.plat_size\t= sizeof(dtv_test1),
Simon Glass36b15e22020-10-03 11:31:35 -0600928\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600929};
930
Simon Glass192f8132020-10-03 11:31:25 -0600931/* Node /test2 index 1 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300932static struct dtd_test2 dtv_test2 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600933\t.reg\t\t\t= {0x1234567890123456, 0x9876543210987654},
934};
Simon Glass1d8364a2020-12-28 20:34:54 -0700935U_BOOT_DRVINFO(test2) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600936\t.name\t\t= "test2",
Simon Glasse2119082021-02-03 06:01:19 -0700937\t.plat\t\t= &dtv_test2,
Simon Glass39edb952020-12-03 16:55:19 -0700938\t.plat_size\t= sizeof(dtv_test2),
Simon Glass36b15e22020-10-03 11:31:35 -0600939\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600940};
941
Simon Glass192f8132020-10-03 11:31:25 -0600942/* Node /test3 index 2 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300943static struct dtd_test3 dtv_test3 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600944\t.reg\t\t\t= {0x1234567890123456, 0x9876543210987654, 0x2, 0x3},
945};
Simon Glass1d8364a2020-12-28 20:34:54 -0700946U_BOOT_DRVINFO(test3) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600947\t.name\t\t= "test3",
Simon Glasse2119082021-02-03 06:01:19 -0700948\t.plat\t\t= &dtv_test3,
Simon Glass39edb952020-12-03 16:55:19 -0700949\t.plat_size\t= sizeof(dtv_test3),
Simon Glass36b15e22020-10-03 11:31:35 -0600950\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600951};
952
Simon Glass2500de22020-12-28 20:35:05 -0700953''', data)
Simon Glass1b1fe412017-08-29 14:15:50 -0600954
955 def test_addresses32(self):
956 """Test output from a node with a 'reg' property with na=1, ns=1"""
957 dtb_file = get_dtb_file('dtoc_test_addr32.dts')
958 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -0300959 self.run_test(['struct'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -0600960 with open(output) as infile:
961 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700962 self._check_strings(HEADER + '''
Simon Glass1b1fe412017-08-29 14:15:50 -0600963struct dtd_test1 {
964\tfdt32_t\t\treg[2];
965};
966struct dtd_test2 {
967\tfdt32_t\t\treg[4];
968};
969''', data)
970
Walter Lozanoa324e412020-06-25 01:10:08 -0300971 self.run_test(['platdata'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -0600972 with open(output) as infile:
973 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -0700974 self._check_strings(C_HEADER + '''
Simon Glasse2119082021-02-03 06:01:19 -0700975/*
976 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
977 *
978 * idx driver_info driver
979 * --- -------------------- --------------------
980 * 0: test1 test1
981 * 1: test2 test2
982 * --- -------------------- --------------------
983 */
984
Simon Glass192f8132020-10-03 11:31:25 -0600985/* Node /test1 index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300986static struct dtd_test1 dtv_test1 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600987\t.reg\t\t\t= {0x1234, 0x5678},
988};
Simon Glass1d8364a2020-12-28 20:34:54 -0700989U_BOOT_DRVINFO(test1) = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600990\t.name\t\t= "test1",
Simon Glasse2119082021-02-03 06:01:19 -0700991\t.plat\t\t= &dtv_test1,
Simon Glass39edb952020-12-03 16:55:19 -0700992\t.plat_size\t= sizeof(dtv_test1),
Simon Glass36b15e22020-10-03 11:31:35 -0600993\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -0600994};
995
Simon Glass192f8132020-10-03 11:31:25 -0600996/* Node /test2 index 1 */
Walter Lozanodc5b4372020-06-25 01:10:13 -0300997static struct dtd_test2 dtv_test2 = {
Simon Glass1b1fe412017-08-29 14:15:50 -0600998\t.reg\t\t\t= {0x12345678, 0x98765432, 0x2, 0x3},
999};
Simon Glass1d8364a2020-12-28 20:34:54 -07001000U_BOOT_DRVINFO(test2) = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001001\t.name\t\t= "test2",
Simon Glasse2119082021-02-03 06:01:19 -07001002\t.plat\t\t= &dtv_test2,
Simon Glass39edb952020-12-03 16:55:19 -07001003\t.plat_size\t= sizeof(dtv_test2),
Simon Glass36b15e22020-10-03 11:31:35 -06001004\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -06001005};
1006
Simon Glass2500de22020-12-28 20:35:05 -07001007''', data)
Simon Glass1b1fe412017-08-29 14:15:50 -06001008
1009 def test_addresses64_32(self):
1010 """Test output from a node with a 'reg' property with na=2, ns=1"""
1011 dtb_file = get_dtb_file('dtoc_test_addr64_32.dts')
1012 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -03001013 self.run_test(['struct'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -06001014 with open(output) as infile:
1015 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -07001016 self._check_strings(HEADER + '''
Simon Glass1b1fe412017-08-29 14:15:50 -06001017struct dtd_test1 {
1018\tfdt64_t\t\treg[2];
1019};
1020struct dtd_test2 {
1021\tfdt64_t\t\treg[2];
1022};
1023struct dtd_test3 {
1024\tfdt64_t\t\treg[4];
1025};
1026''', data)
1027
Walter Lozanoa324e412020-06-25 01:10:08 -03001028 self.run_test(['platdata'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -06001029 with open(output) as infile:
1030 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -07001031 self._check_strings(C_HEADER + '''
Simon Glasse2119082021-02-03 06:01:19 -07001032/*
1033 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
1034 *
1035 * idx driver_info driver
1036 * --- -------------------- --------------------
1037 * 0: test1 test1
1038 * 1: test2 test2
1039 * 2: test3 test3
1040 * --- -------------------- --------------------
1041 */
1042
Simon Glass192f8132020-10-03 11:31:25 -06001043/* Node /test1 index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -03001044static struct dtd_test1 dtv_test1 = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001045\t.reg\t\t\t= {0x123400000000, 0x5678},
1046};
Simon Glass1d8364a2020-12-28 20:34:54 -07001047U_BOOT_DRVINFO(test1) = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001048\t.name\t\t= "test1",
Simon Glasse2119082021-02-03 06:01:19 -07001049\t.plat\t\t= &dtv_test1,
Simon Glass39edb952020-12-03 16:55:19 -07001050\t.plat_size\t= sizeof(dtv_test1),
Simon Glass36b15e22020-10-03 11:31:35 -06001051\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -06001052};
1053
Simon Glass192f8132020-10-03 11:31:25 -06001054/* Node /test2 index 1 */
Walter Lozanodc5b4372020-06-25 01:10:13 -03001055static struct dtd_test2 dtv_test2 = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001056\t.reg\t\t\t= {0x1234567890123456, 0x98765432},
1057};
Simon Glass1d8364a2020-12-28 20:34:54 -07001058U_BOOT_DRVINFO(test2) = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001059\t.name\t\t= "test2",
Simon Glasse2119082021-02-03 06:01:19 -07001060\t.plat\t\t= &dtv_test2,
Simon Glass39edb952020-12-03 16:55:19 -07001061\t.plat_size\t= sizeof(dtv_test2),
Simon Glass36b15e22020-10-03 11:31:35 -06001062\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -06001063};
1064
Simon Glass192f8132020-10-03 11:31:25 -06001065/* Node /test3 index 2 */
Walter Lozanodc5b4372020-06-25 01:10:13 -03001066static struct dtd_test3 dtv_test3 = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001067\t.reg\t\t\t= {0x1234567890123456, 0x98765432, 0x2, 0x3},
1068};
Simon Glass1d8364a2020-12-28 20:34:54 -07001069U_BOOT_DRVINFO(test3) = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001070\t.name\t\t= "test3",
Simon Glasse2119082021-02-03 06:01:19 -07001071\t.plat\t\t= &dtv_test3,
Simon Glass39edb952020-12-03 16:55:19 -07001072\t.plat_size\t= sizeof(dtv_test3),
Simon Glass36b15e22020-10-03 11:31:35 -06001073\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -06001074};
1075
Simon Glass2500de22020-12-28 20:35:05 -07001076''', data)
Simon Glass1b1fe412017-08-29 14:15:50 -06001077
1078 def test_addresses32_64(self):
1079 """Test output from a node with a 'reg' property with na=1, ns=2"""
1080 dtb_file = get_dtb_file('dtoc_test_addr32_64.dts')
1081 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -03001082 self.run_test(['struct'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -06001083 with open(output) as infile:
1084 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -07001085 self._check_strings(HEADER + '''
Simon Glass1b1fe412017-08-29 14:15:50 -06001086struct dtd_test1 {
1087\tfdt64_t\t\treg[2];
1088};
1089struct dtd_test2 {
1090\tfdt64_t\t\treg[2];
1091};
1092struct dtd_test3 {
1093\tfdt64_t\t\treg[4];
1094};
1095''', data)
1096
Walter Lozanoa324e412020-06-25 01:10:08 -03001097 self.run_test(['platdata'], dtb_file, output)
Simon Glass1b1fe412017-08-29 14:15:50 -06001098 with open(output) as infile:
1099 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -07001100 self._check_strings(C_HEADER + '''
Simon Glasse2119082021-02-03 06:01:19 -07001101/*
1102 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
1103 *
1104 * idx driver_info driver
1105 * --- -------------------- --------------------
1106 * 0: test1 test1
1107 * 1: test2 test2
1108 * 2: test3 test3
1109 * --- -------------------- --------------------
1110 */
1111
Simon Glass192f8132020-10-03 11:31:25 -06001112/* Node /test1 index 0 */
Walter Lozanodc5b4372020-06-25 01:10:13 -03001113static struct dtd_test1 dtv_test1 = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001114\t.reg\t\t\t= {0x1234, 0x567800000000},
1115};
Simon Glass1d8364a2020-12-28 20:34:54 -07001116U_BOOT_DRVINFO(test1) = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001117\t.name\t\t= "test1",
Simon Glasse2119082021-02-03 06:01:19 -07001118\t.plat\t\t= &dtv_test1,
Simon Glass39edb952020-12-03 16:55:19 -07001119\t.plat_size\t= sizeof(dtv_test1),
Simon Glass36b15e22020-10-03 11:31:35 -06001120\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -06001121};
1122
Simon Glass192f8132020-10-03 11:31:25 -06001123/* Node /test2 index 1 */
Walter Lozanodc5b4372020-06-25 01:10:13 -03001124static struct dtd_test2 dtv_test2 = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001125\t.reg\t\t\t= {0x12345678, 0x9876543210987654},
1126};
Simon Glass1d8364a2020-12-28 20:34:54 -07001127U_BOOT_DRVINFO(test2) = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001128\t.name\t\t= "test2",
Simon Glasse2119082021-02-03 06:01:19 -07001129\t.plat\t\t= &dtv_test2,
Simon Glass39edb952020-12-03 16:55:19 -07001130\t.plat_size\t= sizeof(dtv_test2),
Simon Glass36b15e22020-10-03 11:31:35 -06001131\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -06001132};
1133
Simon Glass192f8132020-10-03 11:31:25 -06001134/* Node /test3 index 2 */
Walter Lozanodc5b4372020-06-25 01:10:13 -03001135static struct dtd_test3 dtv_test3 = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001136\t.reg\t\t\t= {0x12345678, 0x9876543210987654, 0x2, 0x3},
1137};
Simon Glass1d8364a2020-12-28 20:34:54 -07001138U_BOOT_DRVINFO(test3) = {
Simon Glass1b1fe412017-08-29 14:15:50 -06001139\t.name\t\t= "test3",
Simon Glasse2119082021-02-03 06:01:19 -07001140\t.plat\t\t= &dtv_test3,
Simon Glass39edb952020-12-03 16:55:19 -07001141\t.plat_size\t= sizeof(dtv_test3),
Simon Glass36b15e22020-10-03 11:31:35 -06001142\t.parent_idx\t= -1,
Simon Glass1b1fe412017-08-29 14:15:50 -06001143};
1144
Simon Glass2500de22020-12-28 20:35:05 -07001145''', data)
Simon Glass961c1ce2018-07-06 10:27:35 -06001146
1147 def test_bad_reg(self):
1148 """Test that a reg property with an invalid type generates an error"""
Simon Glass3bce93d2018-07-06 10:27:37 -06001149 # Capture stderr since dtc will emit warnings for this file
1150 dtb_file = get_dtb_file('dtoc_test_bad_reg.dts', capture_stderr=True)
Simon Glass961c1ce2018-07-06 10:27:35 -06001151 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -07001152 with self.assertRaises(ValueError) as exc:
Walter Lozanoa324e412020-06-25 01:10:08 -03001153 self.run_test(['struct'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -06001154 self.assertIn("Node 'spl-test' reg property is not an int",
Simon Glassa60cabd2020-12-28 20:34:47 -07001155 str(exc.exception))
Simon Glass961c1ce2018-07-06 10:27:35 -06001156
1157 def test_bad_reg2(self):
1158 """Test that a reg property with an invalid cell count is detected"""
Simon Glass3bce93d2018-07-06 10:27:37 -06001159 # Capture stderr since dtc will emit warnings for this file
1160 dtb_file = get_dtb_file('dtoc_test_bad_reg2.dts', capture_stderr=True)
Simon Glass961c1ce2018-07-06 10:27:35 -06001161 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -07001162 with self.assertRaises(ValueError) as exc:
Walter Lozanoa324e412020-06-25 01:10:08 -03001163 self.run_test(['struct'], dtb_file, output)
Simon Glassa60cabd2020-12-28 20:34:47 -07001164 self.assertIn(
1165 "Node 'spl-test' reg property has 3 cells which is not a multiple of na + ns = 1 + 1)",
1166 str(exc.exception))
Simon Glass961c1ce2018-07-06 10:27:35 -06001167
1168 def test_add_prop(self):
1169 """Test that a subequent node can add a new property to a struct"""
1170 dtb_file = get_dtb_file('dtoc_test_add_prop.dts')
1171 output = tools.GetOutputFilename('output')
Walter Lozanoa324e412020-06-25 01:10:08 -03001172 self.run_test(['struct'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -06001173 with open(output) as infile:
1174 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -07001175 self._check_strings(HEADER + '''
Simon Glass961c1ce2018-07-06 10:27:35 -06001176struct dtd_sandbox_spl_test {
1177\tfdt32_t\t\tintarray;
1178\tfdt32_t\t\tintval;
1179};
1180''', data)
1181
Walter Lozanoa324e412020-06-25 01:10:08 -03001182 self.run_test(['platdata'], dtb_file, output)
Simon Glass961c1ce2018-07-06 10:27:35 -06001183 with open(output) as infile:
1184 data = infile.read()
Simon Glassa60cabd2020-12-28 20:34:47 -07001185 self._check_strings(C_HEADER + '''
Simon Glassbe749002021-02-03 06:01:15 -07001186/*
Simon Glasse2119082021-02-03 06:01:19 -07001187 * driver_info declarations, ordered by 'struct driver_info' linker_list idx:
1188 *
1189 * idx driver_info driver
1190 * --- -------------------- --------------------
1191 * 0: spl_test sandbox_spl_test
1192 * 1: spl_test2 sandbox_spl_test
1193 * --- -------------------- --------------------
1194 */
1195
1196/*
Simon Glassbe749002021-02-03 06:01:15 -07001197 * Node /spl-test index 0
1198 * driver sandbox_spl_test parent None
1199 */
Walter Lozanodc5b4372020-06-25 01:10:13 -03001200static struct dtd_sandbox_spl_test dtv_spl_test = {
Simon Glass961c1ce2018-07-06 10:27:35 -06001201\t.intval\t\t\t= 0x1,
1202};
Simon Glass1d8364a2020-12-28 20:34:54 -07001203U_BOOT_DRVINFO(spl_test) = {
Simon Glass961c1ce2018-07-06 10:27:35 -06001204\t.name\t\t= "sandbox_spl_test",
Simon Glasse2119082021-02-03 06:01:19 -07001205\t.plat\t\t= &dtv_spl_test,
Simon Glass39edb952020-12-03 16:55:19 -07001206\t.plat_size\t= sizeof(dtv_spl_test),
Simon Glass36b15e22020-10-03 11:31:35 -06001207\t.parent_idx\t= -1,
Simon Glass961c1ce2018-07-06 10:27:35 -06001208};
1209
Simon Glassbe749002021-02-03 06:01:15 -07001210/*
1211 * Node /spl-test2 index 1
1212 * driver sandbox_spl_test parent None
1213 */
Walter Lozanodc5b4372020-06-25 01:10:13 -03001214static struct dtd_sandbox_spl_test dtv_spl_test2 = {
Simon Glass961c1ce2018-07-06 10:27:35 -06001215\t.intarray\t\t= 0x5,
1216};
Simon Glass1d8364a2020-12-28 20:34:54 -07001217U_BOOT_DRVINFO(spl_test2) = {
Simon Glass961c1ce2018-07-06 10:27:35 -06001218\t.name\t\t= "sandbox_spl_test",
Simon Glasse2119082021-02-03 06:01:19 -07001219\t.plat\t\t= &dtv_spl_test2,
Simon Glass39edb952020-12-03 16:55:19 -07001220\t.plat_size\t= sizeof(dtv_spl_test2),
Simon Glass36b15e22020-10-03 11:31:35 -06001221\t.parent_idx\t= -1,
Simon Glass961c1ce2018-07-06 10:27:35 -06001222};
1223
Simon Glass2500de22020-12-28 20:35:05 -07001224''', data)
Simon Glass961c1ce2018-07-06 10:27:35 -06001225
Simon Glassa60cabd2020-12-28 20:34:47 -07001226 def test_stdout(self):
Simon Glass961c1ce2018-07-06 10:27:35 -06001227 """Test output to stdout"""
1228 dtb_file = get_dtb_file('dtoc_test_simple.dts')
Simon Glass07ee48e2020-12-28 20:34:49 -07001229 with test_util.capture_sys_output() as (stdout, _):
Simon Glass6ca0c7a2020-12-28 20:34:48 -07001230 self.run_test(['struct'], dtb_file, None)
Simon Glass07ee48e2020-12-28 20:34:49 -07001231 self._check_strings(self.struct_text, stdout.getvalue())
Simon Glass961c1ce2018-07-06 10:27:35 -06001232
Simon Glassc3a310a82020-12-28 20:34:51 -07001233 def test_multi_to_file(self):
1234 """Test output of multiple pieces to a single file"""
1235 dtb_file = get_dtb_file('dtoc_test_simple.dts')
1236 output = tools.GetOutputFilename('output')
Simon Glass4e8e8462020-12-28 20:34:52 -07001237 self.run_test(['all'], dtb_file, output)
Simon Glassc3a310a82020-12-28 20:34:51 -07001238 data = tools.ReadFile(output, binary=False)
Simon Glass3fa3bbb2021-02-03 06:01:14 -07001239 self._check_strings(self.decl_text + self.platdata_text +
Simon Glassc7b4b832021-02-03 06:01:20 -07001240 self.struct_text + self.uclass_text, data)
Simon Glassc3a310a82020-12-28 20:34:51 -07001241
Simon Glassa60cabd2020-12-28 20:34:47 -07001242 def test_no_command(self):
Simon Glass961c1ce2018-07-06 10:27:35 -06001243 """Test running dtoc without a command"""
Simon Glassa60cabd2020-12-28 20:34:47 -07001244 with self.assertRaises(ValueError) as exc:
Walter Lozanoa324e412020-06-25 01:10:08 -03001245 self.run_test([], '', '')
Simon Glass961c1ce2018-07-06 10:27:35 -06001246 self.assertIn("Please specify a command: struct, platdata",
Simon Glassa60cabd2020-12-28 20:34:47 -07001247 str(exc.exception))
Simon Glass961c1ce2018-07-06 10:27:35 -06001248
Simon Glassa60cabd2020-12-28 20:34:47 -07001249 def test_bad_command(self):
Simon Glass961c1ce2018-07-06 10:27:35 -06001250 """Test running dtoc with an invalid command"""
1251 dtb_file = get_dtb_file('dtoc_test_simple.dts')
1252 output = tools.GetOutputFilename('output')
Simon Glassa60cabd2020-12-28 20:34:47 -07001253 with self.assertRaises(ValueError) as exc:
Simon Glass3fa3bbb2021-02-03 06:01:14 -07001254 self.run_test(['invalid-cmd'], dtb_file, output)
1255 self.assertIn(
Simon Glassc7b4b832021-02-03 06:01:20 -07001256 "Unknown command 'invalid-cmd': (use: decl, platdata, struct, uclass)",
Simon Glass3fa3bbb2021-02-03 06:01:14 -07001257 str(exc.exception))
Walter Lozanod82062b2020-07-28 19:06:23 -03001258
Simon Glass4e8e8462020-12-28 20:34:52 -07001259 def test_output_conflict(self):
1260 """Test a conflict between and output dirs and output file"""
1261 with self.assertRaises(ValueError) as exc:
Simon Glass3809ad92021-02-03 06:01:12 -07001262 dtb_platdata.run_steps(
1263 ['all'], None, False, 'out', ['cdir'], None, False,
1264 warning_disabled=True, scan=copy_scan())
Simon Glass4e8e8462020-12-28 20:34:52 -07001265 self.assertIn("Must specify either output or output_dirs, not both",
1266 str(exc.exception))
1267
1268 def test_output_dirs(self):
1269 """Test outputting files to a directory"""
1270 # Remove the directory so that files from other tests are not there
1271 tools._RemoveOutputDir()
1272 tools.PrepareOutputDir(None)
1273
1274 # This should create the .dts and .dtb in the output directory
1275 dtb_file = get_dtb_file('dtoc_test_simple.dts')
1276 outdir = tools.GetOutputDir()
1277 fnames = glob.glob(outdir + '/*')
1278 self.assertEqual(2, len(fnames))
1279
Simon Glass3809ad92021-02-03 06:01:12 -07001280 dtb_platdata.run_steps(
1281 ['all'], dtb_file, False, None, [outdir], None, False,
1282 warning_disabled=True, scan=copy_scan())
Simon Glass4e8e8462020-12-28 20:34:52 -07001283 fnames = glob.glob(outdir + '/*')
Simon Glassc7b4b832021-02-03 06:01:20 -07001284 self.assertEqual(6, len(fnames))
Simon Glass4e8e8462020-12-28 20:34:52 -07001285
1286 leafs = set(os.path.basename(fname) for fname in fnames)
1287 self.assertEqual(
Simon Glass3fa3bbb2021-02-03 06:01:14 -07001288 {'dt-structs-gen.h', 'source.dts', 'dt-plat.c', 'source.dtb',
Simon Glassc7b4b832021-02-03 06:01:20 -07001289 'dt-uclass.c', 'dt-decl.h'},
Simon Glass4e8e8462020-12-28 20:34:52 -07001290 leafs)
Simon Glass047a4802021-02-03 06:01:00 -07001291
1292 def setup_process_test(self):
1293 """Set up a test of process_nodes()
1294
1295 This uses saved_scan but returns a deep copy of it, so it is safe to
1296 modify it in these tests
1297
1298 Returns:
1299 tuple:
1300 DtbPlatdata: object to test
1301 Scanner: scanner to use
1302 """
1303 dtb_file = get_dtb_file('dtoc_test_simple.dts')
1304 output = tools.GetOutputFilename('output')
1305
1306 # Take a copy before messing with it
Simon Glassc14fd0c2021-02-03 06:01:11 -07001307 scan = copy_scan()
Simon Glass047a4802021-02-03 06:01:00 -07001308 plat = dtb_platdata.DtbPlatdata(scan, dtb_file, False)
1309 plat.scan_dtb()
Simon Glassc14fd0c2021-02-03 06:01:11 -07001310 plat.scan_tree(False)
Simon Glass047a4802021-02-03 06:01:00 -07001311 plat.prepare_nodes()
1312 return plat, scan
1313
1314 def test_process_nodes(self):
1315 """Test processing nodes to add various info"""
1316 plat, scan = self.setup_process_test()
1317 plat.process_nodes(True)
1318
1319 i2c_node = plat._fdt.GetNode('/i2c@0')
1320 pmic_node = plat._fdt.GetNode('/i2c@0/pmic@9')
1321 pmic = scan._drivers['sandbox_pmic']
1322 i2c = scan._drivers['sandbox_i2c']
1323 self.assertEqual('DM_DEVICE_REF(pmic_at_9)', pmic_node.dev_ref)
1324 self.assertEqual(pmic, pmic_node.driver)
1325 self.assertEqual(i2c_node, pmic_node.parent)
1326 self.assertEqual(i2c, pmic_node.parent_driver)
1327
1328 # The pmic is the only child
1329 self.assertEqual(pmic_node.parent_seq, 0)
1330 self.assertEqual([pmic_node], i2c_node.child_devs)
1331
1332 # Start and end of the list should be the child_head
1333 ref = '&DM_DEVICE_REF(i2c_at_0)->child_head'
1334 self.assertEqual(
1335 {-1: ref, 0: '&DM_DEVICE_REF(pmic_at_9)->sibling_node', 1: ref},
1336 i2c_node.child_refs)
1337
1338 def test_process_nodes_bad_parent(self):
1339 # Pretend that i2c has a parent (the pmic) and delete that driver
1340 plat, scan = self.setup_process_test()
1341
1342 i2c_node = plat._fdt.GetNode('/i2c@0')
1343 pmic_node = plat._fdt.GetNode('/i2c@0/pmic@9')
1344 del scan._drivers['sandbox_pmic']
1345 i2c_node.parent = pmic_node
1346
1347 # Process twice, the second time to generate an exception
1348 plat.process_nodes(False)
1349 with self.assertRaises(ValueError) as exc:
1350 plat.process_nodes(True)
1351 self.assertIn(
1352 "Cannot parse/find parent driver 'sandbox_pmic' for 'sandbox_i2c",
1353 str(exc.exception))
1354
1355 def test_process_nodes_bad_node(self):
1356 plat, scan = self.setup_process_test()
1357
1358 # Now remove the pmic driver
1359 del scan._drivers['sandbox_pmic']
1360
1361 # Process twice, the second time to generate an exception
1362 plat.process_nodes(False)
1363 with self.assertRaises(ValueError) as exc:
1364 plat.process_nodes(True)
1365 self.assertIn("Cannot parse/find driver for 'sandbox_pmic",
1366 str(exc.exception))
Simon Glasseb3c2492021-02-03 06:01:01 -07001367
Simon Glass80d782c42021-02-03 06:01:10 -07001368 def test_process_nodes_bad_uclass(self):
1369 plat, scan = self.setup_process_test()
1370
1371 self.assertIn('UCLASS_I2C', scan._uclass)
1372 del scan._uclass['UCLASS_I2C']
1373 with self.assertRaises(ValueError) as exc:
1374 plat.process_nodes(True)
1375 self.assertIn("Cannot parse/find uclass 'UCLASS_I2C' for driver 'sandbox_i2c'",
1376 str(exc.exception))
1377
Simon Glasseb3c2492021-02-03 06:01:01 -07001378 def test_process_nodes_used(self):
1379 """Test processing nodes to add various info"""
1380 plat, scan = self.setup_process_test()
1381 plat.process_nodes(True)
1382
1383 pmic = scan._drivers['sandbox_pmic']
1384 self.assertTrue(pmic.used)
1385
1386 gpio = scan._drivers['sandbox_gpio']
1387 self.assertFalse(gpio.used)
Simon Glassbe88d2f2021-02-03 06:01:07 -07001388
1389 def test_alias_read(self):
1390 """Test obtaining aliases"""
1391 dtb_file = get_dtb_file('dtoc_test_inst.dts')
1392 output = tools.GetOutputFilename('output')
1393 plat = self.run_test(['struct'], dtb_file, output)
1394
1395 scan = plat._scan
1396 testfdt_node = plat._fdt.GetNode('/some-bus/test')
Simon Glass80d782c42021-02-03 06:01:10 -07001397 test0_node = plat._fdt.GetNode('/some-bus/test0')
Simon Glassbe88d2f2021-02-03 06:01:07 -07001398 self.assertIn('UCLASS_TEST_FDT', scan._uclass)
1399 uc = scan._uclass['UCLASS_TEST_FDT']
Simon Glass80d782c42021-02-03 06:01:10 -07001400 self.assertEqual({1: testfdt_node, 2: test0_node},
1401 uc.alias_num_to_node)
1402 self.assertEqual({'/some-bus/test': 1, '/some-bus/test0': 2},
1403 uc.alias_path_to_num)
Simon Glassbe88d2f2021-02-03 06:01:07 -07001404
1405 # Try adding an alias that doesn't exist
1406 self.assertFalse(scan.add_uclass_alias('fred', 3, None))
1407
1408 # Try adding an alias for a missing node
1409 self.assertIsNone(scan.add_uclass_alias('testfdt', 3, None))
1410
1411 def test_alias_read_bad(self):
1412 """Test invalid alias property name"""
1413 dtb_file = get_dtb_file('dtoc_test_alias_bad.dts')
1414 output = tools.GetOutputFilename('output')
1415 with self.assertRaises(ValueError) as exc:
1416 plat = self.run_test(['struct'], dtb_file, output)
1417 self.assertIn("Cannot decode alias 'i2c4-'", str(exc.exception))
1418
1419 def test_alias_read_bad_path(self):
1420 """Test alias pointing to a non-existent node"""
1421 # This line may produce a warning, so capture it:
1422 # Warning (alias_paths): /aliases:i2c4: aliases property is not a valid
1423 # node (/does/not/exist)
1424 dtb_file = get_dtb_file('dtoc_test_alias_bad_path.dts', True)
1425
1426 output = tools.GetOutputFilename('output')
1427 with self.assertRaises(ValueError) as exc:
1428 plat = self.run_test(['struct'], dtb_file, output)
1429 self.assertIn("Alias 'i2c4' path '/does/not/exist' not found",
1430 str(exc.exception))
1431
1432 def test_alias_read_bad_uclass(self):
1433 """Test alias for a uclass that doesn't exist"""
1434 dtb_file = get_dtb_file('dtoc_test_alias_bad_uc.dts')
1435 output = tools.GetOutputFilename('output')
1436 with test_util.capture_sys_output() as (stdout, _):
1437 plat = self.run_test(['struct'], dtb_file, output)
1438 self.assertEqual("Could not find uclass for alias 'other1'",
1439 stdout.getvalue().strip())
Simon Glassdf56e0b2021-02-03 06:01:09 -07001440
1441 def test_sequence(self):
1442 """Test assignment of sequence numnbers"""
1443 dtb_file = get_dtb_file('dtoc_test_inst.dts')
1444 output = tools.GetOutputFilename('output')
1445 plat = self.run_test(['struct'], dtb_file, output)
Simon Glass80d782c42021-02-03 06:01:10 -07001446
1447 scan = plat._scan
1448 testfdt = plat._fdt.GetNode('/some-bus/test')
1449 self.assertEqual(1, testfdt.seq)
1450 i2c = plat._fdt.GetNode('/i2c')
1451
1452 # For now this uclass is not compiled in, so no sequence is assigned
1453 self.assertEqual(4, i2c.seq)
1454 spl = plat._fdt.GetNode('/spl-test')
1455 self.assertEqual(0, spl.seq)
Simon Glassc14fd0c2021-02-03 06:01:11 -07001456
1457 def test_process_root(self):
1458 """Test assignment of sequence numnbers"""
1459 dtb_file = get_dtb_file('dtoc_test_simple.dts')
1460 output = tools.GetOutputFilename('output')
1461
1462 # Take a copy before messing with it
1463 scan = copy_scan()
1464 plat = dtb_platdata.DtbPlatdata(scan, dtb_file, False)
1465 plat.scan_dtb()
1466 root = plat._fdt.GetRoot()
1467
1468 plat.scan_tree(False)
1469 self.assertNotIn(root, plat._valid_nodes)
1470
1471 plat.scan_tree(True)
1472 self.assertIn(root, plat._valid_nodes)
1473 self.assertEqual('root_driver',
1474 scan.get_normalized_compat_name(root)[0])
Simon Glass3fa3bbb2021-02-03 06:01:14 -07001475
1476 def test_simple_inst(self):
1477 """Test output from some simple nodes with instantiate enabled"""
Simon Glassc7b4b832021-02-03 06:01:20 -07001478 dtb_file = get_dtb_file('dtoc_test_inst.dts')
Simon Glass3fa3bbb2021-02-03 06:01:14 -07001479 output = tools.GetOutputFilename('output')
1480
1481 self.run_test(['decl'], dtb_file, output, True)
1482 with open(output) as infile:
1483 data = infile.read()
1484
1485 self._check_strings(self.decl_text_inst, data)
Simon Glassbe749002021-02-03 06:01:15 -07001486
1487 self.run_test(['platdata'], dtb_file, output, True)
1488 with open(output) as infile:
1489 data = infile.read()
1490
1491 self._check_strings(C_HEADER_PRE + '''
1492/* This file is not used: --instantiate was enabled */
1493''', data)
Simon Glassc7b4b832021-02-03 06:01:20 -07001494
1495 self.run_test(['uclass'], dtb_file, output, True)
1496 with open(output) as infile:
1497 data = infile.read()
1498
1499 self._check_strings(UCLASS_HEADER_COMMON + self.uclass_text_inst, data)
1500
1501 def test_inst_no_hdr(self):
1502 """Test dealing with a struct that has no header"""
1503 dtb_file = get_dtb_file('dtoc_test_inst.dts')
1504 output = tools.GetOutputFilename('output')
1505
1506 # Run it once to set everything up
1507 plat = self.run_test(['decl'], dtb_file, output, True)
1508 scan = plat._scan
1509
1510 # Restart the output file and delete any record of the uclass' struct
1511 plat.setup_output(Ftype.SOURCE, output)
1512 del scan._structs['dm_test_uc_priv']
1513
1514 # Now generate the uclasses, which should provide a warning
1515 with test_util.capture_sys_output() as (stdout, _):
1516 plat.generate_uclasses()
1517 self.assertEqual(
1518 'Warning: Cannot find header file for struct dm_test_uc_priv',
1519 stdout.getvalue().strip())