2025-04-14 13:40:31 +01:00
|
|
|
/*
|
|
|
|
|
* Copyright (C) 2025 Michael Brown <mbrown@fensystems.co.uk>.
|
|
|
|
|
*
|
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
|
* modify it under the terms of the GNU General Public License as
|
|
|
|
|
* published by the Free Software Foundation; either version 2 of the
|
|
|
|
|
* License, or any later version.
|
|
|
|
|
*
|
|
|
|
|
* This program is distributed in the hope that it will be useful, but
|
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
|
* General Public License for more details.
|
|
|
|
|
*
|
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
|
|
|
|
* 02110-1301, USA.
|
|
|
|
|
*
|
|
|
|
|
* You can also choose to distribute this program under the terms of
|
|
|
|
|
* the Unmodified Binary Distribution Licence (as given in the file
|
|
|
|
|
* COPYING.UBDL), provided that you have satisfied its requirements.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL );
|
|
|
|
|
|
|
|
|
|
/** @file
|
|
|
|
|
*
|
|
|
|
|
* Flattened device tree self-tests
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
/* Forcibly enable assertions */
|
|
|
|
|
#undef NDEBUG
|
|
|
|
|
|
|
|
|
|
#include <string.h>
|
|
|
|
|
#include <ipxe/fdt.h>
|
2025-05-30 14:15:43 +01:00
|
|
|
#include <ipxe/image.h>
|
2025-04-14 13:40:31 +01:00
|
|
|
#include <ipxe/test.h>
|
|
|
|
|
|
|
|
|
|
/** Simplified QEMU sifive_u device tree blob */
|
|
|
|
|
static const uint8_t sifive_u[] = {
|
2025-07-22 13:37:05 +01:00
|
|
|
0xd0, 0x0d, 0xfe, 0xed, 0x00, 0x00, 0x05, 0x8f, 0x00, 0x00, 0x00, 0x38,
|
|
|
|
|
0x00, 0x00, 0x04, 0x9c, 0x00, 0x00, 0x00, 0x28, 0x00, 0x00, 0x00, 0x11,
|
|
|
|
|
0x00, 0x00, 0x00, 0x10, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xf3,
|
|
|
|
|
0x00, 0x00, 0x04, 0x64, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
2025-04-14 13:40:31 +01:00
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01,
|
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x04,
|
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x03,
|
|
|
|
|
0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x0f, 0x00, 0x00, 0x00, 0x02,
|
|
|
|
|
0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x34, 0x00, 0x00, 0x00, 0x1b,
|
|
|
|
|
0x73, 0x69, 0x66, 0x69, 0x76, 0x65, 0x2c, 0x68, 0x69, 0x66, 0x69, 0x76,
|
|
|
|
|
0x65, 0x2d, 0x75, 0x6e, 0x6c, 0x65, 0x61, 0x73, 0x68, 0x65, 0x64, 0x2d,
|
|
|
|
|
0x61, 0x30, 0x30, 0x00, 0x73, 0x69, 0x66, 0x69, 0x76, 0x65, 0x2c, 0x68,
|
|
|
|
|
0x69, 0x66, 0x69, 0x76, 0x65, 0x2d, 0x75, 0x6e, 0x6c, 0x65, 0x61, 0x73,
|
|
|
|
|
0x68, 0x65, 0x64, 0x00, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x1c,
|
|
|
|
|
0x00, 0x00, 0x00, 0x26, 0x53, 0x69, 0x46, 0x69, 0x76, 0x65, 0x20, 0x48,
|
|
|
|
|
0x69, 0x46, 0x69, 0x76, 0x65, 0x20, 0x55, 0x6e, 0x6c, 0x65, 0x61, 0x73,
|
|
|
|
|
0x68, 0x65, 0x64, 0x20, 0x41, 0x30, 0x30, 0x00, 0x00, 0x00, 0x00, 0x01,
|
|
|
|
|
0x63, 0x68, 0x6f, 0x73, 0x65, 0x6e, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03,
|
|
|
|
|
0x00, 0x00, 0x00, 0x15, 0x00, 0x00, 0x00, 0x2c, 0x2f, 0x73, 0x6f, 0x63,
|
|
|
|
|
0x2f, 0x73, 0x65, 0x72, 0x69, 0x61, 0x6c, 0x40, 0x31, 0x30, 0x30, 0x31,
|
|
|
|
|
0x30, 0x30, 0x30, 0x30, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02,
|
|
|
|
|
0x00, 0x00, 0x00, 0x01, 0x61, 0x6c, 0x69, 0x61, 0x73, 0x65, 0x73, 0x00,
|
|
|
|
|
0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x15, 0x00, 0x00, 0x00, 0x38,
|
|
|
|
|
0x2f, 0x73, 0x6f, 0x63, 0x2f, 0x73, 0x65, 0x72, 0x69, 0x61, 0x6c, 0x40,
|
|
|
|
|
0x31, 0x30, 0x30, 0x31, 0x30, 0x30, 0x30, 0x30, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
|
0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x17, 0x00, 0x00, 0x00, 0x40,
|
|
|
|
|
0x2f, 0x73, 0x6f, 0x63, 0x2f, 0x65, 0x74, 0x68, 0x65, 0x72, 0x6e, 0x65,
|
|
|
|
|
0x74, 0x40, 0x31, 0x30, 0x30, 0x39, 0x30, 0x30, 0x30, 0x30, 0x00, 0x00,
|
|
|
|
|
0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x01, 0x63, 0x70, 0x75, 0x73,
|
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x04,
|
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x03,
|
|
|
|
|
0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x0f, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
|
0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x4a,
|
|
|
|
|
0x00, 0x0f, 0x42, 0x40, 0x00, 0x00, 0x00, 0x01, 0x63, 0x70, 0x75, 0x40,
|
|
|
|
|
0x30, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x04,
|
|
|
|
|
0x00, 0x00, 0x00, 0x5d, 0x63, 0x70, 0x75, 0x00, 0x00, 0x00, 0x00, 0x03,
|
|
|
|
|
0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x69, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
|
0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x05, 0x00, 0x00, 0x00, 0x6d,
|
|
|
|
|
0x6f, 0x6b, 0x61, 0x79, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03,
|
|
|
|
|
0x00, 0x00, 0x00, 0x06, 0x00, 0x00, 0x00, 0x1b, 0x72, 0x69, 0x73, 0x63,
|
|
|
|
|
0x76, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x25,
|
|
|
|
|
0x00, 0x00, 0x00, 0x74, 0x72, 0x76, 0x36, 0x34, 0x69, 0x6d, 0x61, 0x63,
|
|
|
|
|
0x5f, 0x7a, 0x69, 0x63, 0x6e, 0x74, 0x72, 0x5f, 0x7a, 0x69, 0x63, 0x73,
|
|
|
|
|
0x72, 0x5f, 0x7a, 0x69, 0x66, 0x65, 0x6e, 0x63, 0x65, 0x69, 0x5f, 0x7a,
|
|
|
|
|
0x69, 0x68, 0x70, 0x6d, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01,
|
|
|
|
|
0x69, 0x6e, 0x74, 0x65, 0x72, 0x72, 0x75, 0x70, 0x74, 0x2d, 0x63, 0x6f,
|
|
|
|
|
0x6e, 0x74, 0x72, 0x6f, 0x6c, 0x6c, 0x65, 0x72, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
|
0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x7e,
|
|
|
|
|
0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
|
0x00, 0x00, 0x00, 0x8f, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x0f,
|
|
|
|
|
0x00, 0x00, 0x00, 0x1b, 0x72, 0x69, 0x73, 0x63, 0x76, 0x2c, 0x63, 0x70,
|
2025-07-22 13:37:05 +01:00
|
|
|
0x75, 0x2d, 0x69, 0x6e, 0x74, 0x63, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03,
|
|
|
|
|
0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0xa4, 0x00, 0x00, 0x00, 0x03,
|
|
|
|
|
0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x02,
|
|
|
|
|
0x00, 0x00, 0x00, 0x01, 0x6d, 0x65, 0x6d, 0x6f, 0x72, 0x79, 0x40, 0x38,
|
|
|
|
|
0x30, 0x30, 0x30, 0x30, 0x30, 0x30, 0x30, 0x00, 0x00, 0x00, 0x00, 0x03,
|
|
|
|
|
0x00, 0x00, 0x00, 0x07, 0x00, 0x00, 0x00, 0x5d, 0x6d, 0x65, 0x6d, 0x6f,
|
|
|
|
|
0x72, 0x79, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x10,
|
|
|
|
|
0x00, 0x00, 0x00, 0x69, 0x00, 0x00, 0x00, 0x00, 0x80, 0x00, 0x00, 0x00,
|
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02,
|
|
|
|
|
0x00, 0x00, 0x00, 0x01, 0x73, 0x6f, 0x63, 0x00, 0x00, 0x00, 0x00, 0x03,
|
|
|
|
|
0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02,
|
|
|
|
|
0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x0f,
|
|
|
|
|
0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x0b,
|
|
|
|
|
0x00, 0x00, 0x00, 0x1b, 0x73, 0x69, 0x6d, 0x70, 0x6c, 0x65, 0x2d, 0x62,
|
|
|
|
|
0x75, 0x73, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
|
0x00, 0x00, 0x00, 0xb2, 0x00, 0x00, 0x00, 0x01, 0x73, 0x65, 0x72, 0x69,
|
|
|
|
|
0x61, 0x6c, 0x40, 0x31, 0x30, 0x30, 0x31, 0x30, 0x30, 0x30, 0x30, 0x00,
|
2025-04-14 13:40:31 +01:00
|
|
|
0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x10, 0x00, 0x00, 0x00, 0x69,
|
2025-07-22 13:37:05 +01:00
|
|
|
0x00, 0x00, 0x00, 0x00, 0x10, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
|
0x00, 0x00, 0x10, 0x00, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x0d,
|
|
|
|
|
0x00, 0x00, 0x00, 0x1b, 0x73, 0x69, 0x66, 0x69, 0x76, 0x65, 0x2c, 0x75,
|
|
|
|
|
0x61, 0x72, 0x74, 0x30, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02,
|
2025-04-15 20:14:03 +01:00
|
|
|
0x00, 0x00, 0x00, 0x01, 0x65, 0x74, 0x68, 0x65, 0x72, 0x6e, 0x65, 0x74,
|
2025-07-22 13:37:05 +01:00
|
|
|
0x40, 0x31, 0x30, 0x30, 0x39, 0x30, 0x30, 0x30, 0x30, 0x00, 0x00, 0x00,
|
|
|
|
|
0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x0f,
|
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x04,
|
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x03,
|
|
|
|
|
0x00, 0x00, 0x00, 0x06, 0x00, 0x00, 0x00, 0xb9, 0x52, 0x54, 0x00, 0x12,
|
|
|
|
|
0x34, 0x56, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x04,
|
|
|
|
|
0x00, 0x00, 0x00, 0xcb, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x03,
|
|
|
|
|
0x00, 0x00, 0x00, 0x05, 0x00, 0x00, 0x00, 0xd6, 0x67, 0x6d, 0x69, 0x69,
|
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x08,
|
|
|
|
|
0x00, 0x00, 0x00, 0xdf, 0x63, 0x6f, 0x6e, 0x74, 0x72, 0x6f, 0x6c, 0x00,
|
|
|
|
|
0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00, 0x00, 0x69,
|
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x10, 0x09, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
|
|
|
0x00, 0x00, 0x20, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x0a, 0x00, 0x00,
|
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x00, 0x00, 0x00, 0x00, 0x03,
|
|
|
|
|
0x00, 0x00, 0x00, 0x16, 0x00, 0x00, 0x00, 0x1b, 0x73, 0x69, 0x66, 0x69,
|
|
|
|
|
0x76, 0x65, 0x2c, 0x66, 0x75, 0x35, 0x34, 0x30, 0x2d, 0x63, 0x30, 0x30,
|
|
|
|
|
0x30, 0x2d, 0x67, 0x65, 0x6d, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03,
|
|
|
|
|
0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0xe9, 0x00, 0x00, 0x00, 0x02,
|
|
|
|
|
0x54, 0x0b, 0xe4, 0x00, 0x00, 0x00, 0x00, 0x01, 0x65, 0x74, 0x68, 0x65,
|
|
|
|
|
0x72, 0x6e, 0x65, 0x74, 0x2d, 0x70, 0x68, 0x79, 0x40, 0x30, 0x00, 0x00,
|
|
|
|
|
0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x69,
|
|
|
|
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0x00, 0x00, 0x00, 0x04,
|
|
|
|
|
0x00, 0x00, 0x00, 0xaa, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x02,
|
2025-04-15 20:14:03 +01:00
|
|
|
0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x02,
|
2025-07-22 13:37:05 +01:00
|
|
|
0x00, 0x00, 0x00, 0x09, 0x23, 0x61, 0x64, 0x64, 0x72, 0x65, 0x73, 0x73,
|
|
|
|
|
0x2d, 0x63, 0x65, 0x6c, 0x6c, 0x73, 0x00, 0x23, 0x73, 0x69, 0x7a, 0x65,
|
|
|
|
|
0x2d, 0x63, 0x65, 0x6c, 0x6c, 0x73, 0x00, 0x63, 0x6f, 0x6d, 0x70, 0x61,
|
|
|
|
|
0x74, 0x69, 0x62, 0x6c, 0x65, 0x00, 0x6d, 0x6f, 0x64, 0x65, 0x6c, 0x00,
|
|
|
|
|
0x73, 0x74, 0x64, 0x6f, 0x75, 0x74, 0x2d, 0x70, 0x61, 0x74, 0x68, 0x00,
|
|
|
|
|
0x73, 0x65, 0x72, 0x69, 0x61, 0x6c, 0x30, 0x00, 0x65, 0x74, 0x68, 0x65,
|
|
|
|
|
0x72, 0x6e, 0x65, 0x74, 0x30, 0x00, 0x74, 0x69, 0x6d, 0x65, 0x62, 0x61,
|
|
|
|
|
0x73, 0x65, 0x2d, 0x66, 0x72, 0x65, 0x71, 0x75, 0x65, 0x6e, 0x63, 0x79,
|
|
|
|
|
0x00, 0x64, 0x65, 0x76, 0x69, 0x63, 0x65, 0x5f, 0x74, 0x79, 0x70, 0x65,
|
|
|
|
|
0x00, 0x72, 0x65, 0x67, 0x00, 0x73, 0x74, 0x61, 0x74, 0x75, 0x73, 0x00,
|
|
|
|
|
0x72, 0x69, 0x73, 0x63, 0x76, 0x2c, 0x69, 0x73, 0x61, 0x00, 0x23, 0x69,
|
|
|
|
|
0x6e, 0x74, 0x65, 0x72, 0x72, 0x75, 0x70, 0x74, 0x2d, 0x63, 0x65, 0x6c,
|
|
|
|
|
0x6c, 0x73, 0x00, 0x69, 0x6e, 0x74, 0x65, 0x72, 0x72, 0x75, 0x70, 0x74,
|
|
|
|
|
0x2d, 0x63, 0x6f, 0x6e, 0x74, 0x72, 0x6f, 0x6c, 0x6c, 0x65, 0x72, 0x00,
|
|
|
|
|
0x6c, 0x69, 0x6e, 0x75, 0x78, 0x2c, 0x70, 0x68, 0x61, 0x6e, 0x64, 0x6c,
|
|
|
|
|
0x65, 0x00, 0x72, 0x61, 0x6e, 0x67, 0x65, 0x73, 0x00, 0x6c, 0x6f, 0x63,
|
|
|
|
|
0x61, 0x6c, 0x2d, 0x6d, 0x61, 0x63, 0x2d, 0x61, 0x64, 0x64, 0x72, 0x65,
|
|
|
|
|
0x73, 0x73, 0x00, 0x70, 0x68, 0x79, 0x2d, 0x68, 0x61, 0x6e, 0x64, 0x6c,
|
|
|
|
|
0x65, 0x00, 0x70, 0x68, 0x79, 0x2d, 0x6d, 0x6f, 0x64, 0x65, 0x00, 0x72,
|
|
|
|
|
0x65, 0x67, 0x2d, 0x6e, 0x61, 0x6d, 0x65, 0x73, 0x00, 0x6d, 0x61, 0x78,
|
|
|
|
|
0x2d, 0x73, 0x70, 0x65, 0x65, 0x64, 0x00
|
2025-04-14 13:40:31 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Perform FDT self-test
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
static void fdt_test_exec ( void ) {
|
2025-04-14 11:33:27 +01:00
|
|
|
struct fdt_descriptor desc;
|
2025-04-14 13:40:31 +01:00
|
|
|
struct fdt_header *hdr;
|
|
|
|
|
struct fdt fdt;
|
|
|
|
|
const char *string;
|
2025-05-30 14:15:43 +01:00
|
|
|
struct image *image;
|
2025-04-15 20:14:03 +01:00
|
|
|
uint32_t u32;
|
2025-04-14 13:40:31 +01:00
|
|
|
uint64_t u64;
|
|
|
|
|
unsigned int count;
|
|
|
|
|
unsigned int offset;
|
|
|
|
|
|
|
|
|
|
/* Verify parsing */
|
|
|
|
|
hdr = ( ( struct fdt_header * ) sifive_u );
|
|
|
|
|
ok ( fdt_parse ( &fdt, hdr, 0 ) != 0 );
|
|
|
|
|
ok ( fdt_parse ( &fdt, hdr, 1 ) != 0 );
|
|
|
|
|
ok ( fdt_parse ( &fdt, hdr, ( sizeof ( sifive_u ) - 1 ) ) != 0 );
|
|
|
|
|
ok ( fdt_parse ( &fdt, hdr, -1UL ) == 0 );
|
|
|
|
|
ok ( fdt.len == sizeof ( sifive_u ) );
|
|
|
|
|
ok ( fdt_parse ( &fdt, hdr, sizeof ( sifive_u ) ) == 0 );
|
|
|
|
|
ok ( fdt.len == sizeof ( sifive_u ) );
|
|
|
|
|
|
|
|
|
|
/* Verify string properties */
|
|
|
|
|
ok ( ( string = fdt_string ( &fdt, 0, "model" ) ) != NULL );
|
|
|
|
|
ok ( strcmp ( string, "SiFive HiFive Unleashed A00" ) == 0 );
|
|
|
|
|
ok ( ( string = fdt_string ( &fdt, 0, "nonexistent" ) ) == NULL );
|
|
|
|
|
|
|
|
|
|
/* Verify string list properties */
|
|
|
|
|
ok ( ( string = fdt_strings ( &fdt, 0, "model", &count ) ) != NULL );
|
|
|
|
|
ok ( count == 1 );
|
|
|
|
|
ok ( memcmp ( string, "SiFive HiFive Unleashed A00", 28 ) == 0 );
|
|
|
|
|
ok ( ( string = fdt_strings ( &fdt, 0, "compatible",
|
|
|
|
|
&count ) ) != NULL );
|
|
|
|
|
ok ( count == 2 );
|
|
|
|
|
ok ( memcmp ( string, "sifive,hifive-unleashed-a00\0"
|
|
|
|
|
"sifive,hifive-unleashed", 52 ) == 0 );
|
|
|
|
|
ok ( ( string = fdt_strings ( &fdt, 0, "nonexistent",
|
|
|
|
|
&count ) ) == NULL );
|
|
|
|
|
ok ( count == 0 );
|
|
|
|
|
|
|
|
|
|
/* Verify path lookup */
|
|
|
|
|
ok ( fdt_path ( &fdt, "", &offset ) == 0 );
|
|
|
|
|
ok ( offset == 0 );
|
|
|
|
|
ok ( fdt_path ( &fdt, "/", &offset ) == 0 );
|
|
|
|
|
ok ( offset == 0 );
|
|
|
|
|
ok ( fdt_path ( &fdt, "/cpus/cpu@0/interrupt-controller",
|
|
|
|
|
&offset ) == 0 );
|
|
|
|
|
ok ( ( string = fdt_string ( &fdt, offset, "compatible" ) ) != NULL );
|
|
|
|
|
ok ( strcmp ( string, "riscv,cpu-intc" ) == 0 );
|
|
|
|
|
ok ( fdt_path ( &fdt, "//soc/serial@10010000//", &offset ) == 0 );
|
|
|
|
|
ok ( ( string = fdt_string ( &fdt, offset, "compatible" ) ) != NULL );
|
|
|
|
|
ok ( strcmp ( string, "sifive,uart0" ) == 0 );
|
|
|
|
|
ok ( fdt_path ( &fdt, "/nonexistent", &offset ) != 0 );
|
|
|
|
|
ok ( fdt_path ( &fdt, "/cpus/nonexistent", &offset ) != 0 );
|
2025-06-11 16:08:42 +01:00
|
|
|
ok ( fdt_path ( &fdt, "/soc/serial@10010000:115200n8",
|
|
|
|
|
&offset ) == 0 );
|
|
|
|
|
ok ( ( string = fdt_string ( &fdt, offset, "compatible" ) ) != NULL );
|
|
|
|
|
ok ( strcmp ( string, "sifive,uart0" ) == 0 );
|
2025-04-14 13:40:31 +01:00
|
|
|
|
2025-04-15 20:14:03 +01:00
|
|
|
/* Verify 64-bit integer properties */
|
|
|
|
|
ok ( fdt_u64 ( &fdt, 0, "#address-cells", &u64 ) == 0 );
|
|
|
|
|
ok ( u64 == 2 );
|
|
|
|
|
ok ( fdt_path ( &fdt, "/soc/ethernet@10090000", &offset ) == 0 );
|
|
|
|
|
ok ( fdt_u64 ( &fdt, offset, "max-speed", &u64 ) == 0 );
|
|
|
|
|
ok ( u64 == 10000000000ULL );
|
|
|
|
|
ok ( fdt_u64 ( &fdt, offset, "#nonexistent", &u64 ) != 0 );
|
|
|
|
|
|
|
|
|
|
/* Verify 32-bit integer properties */
|
|
|
|
|
ok ( fdt_u32 ( &fdt, 0, "#address-cells", &u32 ) == 0 );
|
|
|
|
|
ok ( u32 == 2 );
|
|
|
|
|
ok ( fdt_u32 ( &fdt, 0, "#nonexistent", &u32 ) != 0 );
|
|
|
|
|
ok ( fdt_path ( &fdt, "/soc/ethernet@10090000", &offset ) == 0 );
|
|
|
|
|
ok ( fdt_u32 ( &fdt, offset, "max-speed", &u32 ) != 0 );
|
|
|
|
|
|
2025-08-04 14:52:00 +01:00
|
|
|
/* Verify phandle properties */
|
|
|
|
|
ok ( fdt_path ( &fdt, "/cpus/cpu@0/interrupt-controller",
|
|
|
|
|
&offset ) == 0 );
|
|
|
|
|
ok ( fdt_phandle ( &fdt, offset ) == 0x03 );
|
|
|
|
|
ok ( fdt_path ( &fdt, "/soc/ethernet@10090000/ethernet-phy@0",
|
|
|
|
|
&offset ) == 0 );
|
|
|
|
|
ok ( fdt_phandle ( &fdt, offset ) == 0x08 );
|
|
|
|
|
ok ( fdt_path ( &fdt, "/soc/serial@10010000", &offset ) == 0 );
|
|
|
|
|
ok ( fdt_phandle ( &fdt, offset ) == 0 );
|
|
|
|
|
|
2025-04-15 20:14:03 +01:00
|
|
|
/* Verify cell properties */
|
|
|
|
|
ok ( fdt_path ( &fdt, "/soc/ethernet@10090000", &offset ) == 0 );
|
|
|
|
|
ok ( fdt_cells ( &fdt, offset, "reg", 4, 2, &u64 ) == 0 );
|
|
|
|
|
ok ( u64 == 0x100a0000 );
|
|
|
|
|
ok ( fdt_cells ( &fdt, offset, "reg", 6, 2, &u64 ) == 0 );
|
|
|
|
|
ok ( u64 == 0x1000 );
|
|
|
|
|
ok ( fdt_cells ( &fdt, offset, "reg", 0, 2, &u64 ) == 0 );
|
|
|
|
|
ok ( u64 == 0x10090000 );
|
|
|
|
|
ok ( fdt_cells ( &fdt, offset, "reg", 6, 0, &u64 ) == 0 );
|
|
|
|
|
ok ( u64 == 0x1000 );
|
|
|
|
|
ok ( fdt_cells ( &fdt, offset, "reg", 8, 0, &u64 ) == 0 );
|
|
|
|
|
ok ( u64 == 0 );
|
|
|
|
|
ok ( fdt_cells ( &fdt, offset, "reg", 7, 2, &u64 ) != 0 );
|
|
|
|
|
ok ( fdt_cells ( &fdt, offset, "notareg", 0, 1, &u64 ) != 0 );
|
|
|
|
|
|
2025-04-14 13:40:31 +01:00
|
|
|
/* Verify alias lookup */
|
|
|
|
|
ok ( fdt_alias ( &fdt, "serial0", &offset ) == 0 );
|
|
|
|
|
ok ( ( string = fdt_string ( &fdt, offset, "compatible" ) ) != NULL );
|
|
|
|
|
ok ( strcmp ( string, "sifive,uart0" ) == 0 );
|
|
|
|
|
ok ( fdt_alias ( &fdt, "nonexistent0", &offset ) != 0 );
|
2025-06-11 16:08:42 +01:00
|
|
|
ok ( fdt_alias ( &fdt, "ethernet0:params", &offset ) == 0 );
|
|
|
|
|
ok ( ( string = fdt_string ( &fdt, offset, "phy-mode" ) ) != NULL );
|
|
|
|
|
ok ( strcmp ( string, "gmii" ) == 0 );
|
2025-04-14 11:33:27 +01:00
|
|
|
|
|
|
|
|
/* Verify node description */
|
|
|
|
|
ok ( fdt_path ( &fdt, "/memory@80000000", &offset ) == 0 );
|
|
|
|
|
ok ( fdt_describe ( &fdt, offset, &desc ) == 0 );
|
|
|
|
|
ok ( desc.offset == offset );
|
|
|
|
|
ok ( strcmp ( desc.name, "memory@80000000" ) == 0 );
|
|
|
|
|
ok ( desc.data == NULL );
|
|
|
|
|
ok ( desc.len == 0 );
|
|
|
|
|
ok ( desc.depth == +1 );
|
|
|
|
|
ok ( fdt_describe ( &fdt, desc.next, &desc ) == 0 );
|
|
|
|
|
ok ( strcmp ( desc.name, "device_type" ) == 0 );
|
|
|
|
|
ok ( strcmp ( desc.data, "memory" ) == 0 );
|
|
|
|
|
ok ( desc.depth == 0 );
|
2025-05-30 14:15:43 +01:00
|
|
|
|
2025-05-30 16:37:28 +01:00
|
|
|
/* Verify parent lookup */
|
|
|
|
|
ok ( fdt_path ( &fdt, "/soc/ethernet@10090000/ethernet-phy@0",
|
|
|
|
|
&offset ) == 0 );
|
|
|
|
|
ok ( fdt_parent ( &fdt, offset, &offset ) == 0 );
|
|
|
|
|
ok ( fdt_describe ( &fdt, offset, &desc ) == 0 );
|
|
|
|
|
ok ( strcmp ( desc.name, "ethernet@10090000" ) == 0 );
|
|
|
|
|
ok ( fdt_parent ( &fdt, offset, &offset ) == 0 );
|
|
|
|
|
ok ( fdt_describe ( &fdt, offset, &desc ) == 0 );
|
|
|
|
|
ok ( strcmp ( desc.name, "soc" ) == 0 );
|
|
|
|
|
ok ( fdt_parent ( &fdt, offset, &offset ) == 0 );
|
|
|
|
|
ok ( offset == 0 );
|
|
|
|
|
|
2025-05-30 14:15:43 +01:00
|
|
|
/* Verify device tree creation */
|
|
|
|
|
image = image_memory ( "test.dtb", sifive_u, sizeof ( sifive_u ) );
|
|
|
|
|
ok ( image != NULL );
|
|
|
|
|
image_tag ( image, &fdt_image );
|
|
|
|
|
ok ( fdt_create ( &hdr, "hello world", 0xabcd0000, 0x00001234 ) == 0 );
|
|
|
|
|
ok ( fdt_parse ( &fdt, hdr, -1UL ) == 0 );
|
|
|
|
|
ok ( fdt_path ( &fdt, "/chosen", &offset ) == 0 );
|
|
|
|
|
ok ( ( string = fdt_string ( &fdt, offset, "bootargs" ) ) != NULL );
|
|
|
|
|
ok ( strcmp ( string, "hello world" ) == 0 );
|
|
|
|
|
ok ( fdt_u64 ( &fdt, offset, "linux,initrd-start", &u64 ) == 0 );
|
|
|
|
|
ok ( u64 == 0xabcd0000 );
|
|
|
|
|
ok ( fdt_u64 ( &fdt, offset, "linux,initrd-end", &u64 ) == 0 );
|
|
|
|
|
ok ( u64 == 0xabcd1234 );
|
|
|
|
|
fdt_remove ( hdr );
|
|
|
|
|
unregister_image ( image );
|
2025-04-14 13:40:31 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/** FDT self-test */
|
|
|
|
|
struct self_test fdt_test __self_test = {
|
|
|
|
|
.name = "fdt",
|
|
|
|
|
.exec = fdt_test_exec,
|
|
|
|
|
};
|