blob: 739c6867f412d308f8c8d6d4bebc83e76f7d70af [file] [log] [blame]
Heinrich Schuchardt79d72022018-09-20 21:58:23 +02001// SPDX-License-Identifier: GPL-2.0+
2/*
3 * Root node for system services
4 *
5 * Copyright (c) 2018 Heinrich Schuchardt
6 */
7
8#include <common.h>
9#include <malloc.h>
Heinrich Schuchardt2c1e2242020-12-13 10:30:24 +010010#include <efi_dt_fixup.h>
Heinrich Schuchardt79d72022018-09-20 21:58:23 +020011#include <efi_loader.h>
12
13const efi_guid_t efi_u_boot_guid = U_BOOT_GUID;
14
AKASHI Takahiro0b275752019-04-16 13:24:20 +090015efi_handle_t efi_root = NULL;
16
Heinrich Schuchardt79d72022018-09-20 21:58:23 +020017struct efi_root_dp {
18 struct efi_device_path_vendor vendor;
19 struct efi_device_path end;
20} __packed;
21
22/**
23 * efi_root_node_register() - create root node
24 *
25 * Create the root node on which we install all protocols that are
26 * not related to a loaded image or a driver.
27 *
28 * Return: status code
29 */
30efi_status_t efi_root_node_register(void)
31{
Heinrich Schuchardt2e0a7902019-05-05 16:55:06 +020032 efi_status_t ret;
Heinrich Schuchardt79d72022018-09-20 21:58:23 +020033 struct efi_root_dp *dp;
34
Heinrich Schuchardt22b9fb92019-04-12 07:14:43 +020035 /* Create device path protocol */
Heinrich Schuchardt79d72022018-09-20 21:58:23 +020036 dp = calloc(1, sizeof(*dp));
37 if (!dp)
38 return EFI_OUT_OF_RESOURCES;
39
40 /* Fill vendor node */
41 dp->vendor.dp.type = DEVICE_PATH_TYPE_HARDWARE_DEVICE;
42 dp->vendor.dp.sub_type = DEVICE_PATH_SUB_TYPE_VENDOR;
43 dp->vendor.dp.length = sizeof(struct efi_device_path_vendor);
44 dp->vendor.guid = efi_u_boot_guid;
45
46 /* Fill end node */
47 dp->end.type = DEVICE_PATH_TYPE_END;
48 dp->end.sub_type = DEVICE_PATH_SUB_TYPE_END;
49 dp->end.length = sizeof(struct efi_device_path);
50
Heinrich Schuchardt22b9fb92019-04-12 07:14:43 +020051 /* Create root node and install protocols */
Heinrich Schuchardt2e0a7902019-05-05 16:55:06 +020052 ret = EFI_CALL(efi_install_multiple_protocol_interfaces
53 (&efi_root,
54 /* Device path protocol */
55 &efi_guid_device_path, dp,
Heinrich Schuchardt3db35912019-05-11 09:53:33 +020056#if CONFIG_IS_ENABLED(EFI_DEVICE_PATH_TO_TEXT)
Heinrich Schuchardt2e0a7902019-05-05 16:55:06 +020057 /* Device path to text protocol */
58 &efi_guid_device_path_to_text_protocol,
59 (void *)&efi_device_path_to_text,
Heinrich Schuchardt3db35912019-05-11 09:53:33 +020060#endif
Heinrich Schuchardt1cb1a9d2021-01-16 09:44:25 +010061#ifdef CONFIG_EFI_DEVICE_PATH_UTIL
Heinrich Schuchardt2e0a7902019-05-05 16:55:06 +020062 /* Device path utilities protocol */
63 &efi_guid_device_path_utilities_protocol,
64 (void *)&efi_device_path_utilities,
Heinrich Schuchardt1cb1a9d2021-01-16 09:44:25 +010065#endif
Heinrich Schuchardt0404b282021-01-16 09:33:24 +010066#ifdef CONFIG_EFI_DT_FIXUP
Heinrich Schuchardt2c1e2242020-12-13 10:30:24 +010067 /* Device-tree fix-up protocol */
68 &efi_guid_dt_fixup_protocol,
69 (void *)&efi_dt_fixup_prot,
70#endif
Heinrich Schuchardtb3258842019-05-16 07:52:58 +020071#if CONFIG_IS_ENABLED(EFI_UNICODE_COLLATION_PROTOCOL2)
Heinrich Schuchardtb3258842019-05-16 07:52:58 +020072 &efi_guid_unicode_collation_protocol2,
73 (void *)&efi_unicode_collation_protocol2,
Heinrich Schuchardt532fec72019-05-08 23:24:26 +020074#endif
Heinrich Schuchardt926e6962019-04-07 23:53:53 +020075#if CONFIG_IS_ENABLED(EFI_LOADER_HII)
Heinrich Schuchardt2e0a7902019-05-05 16:55:06 +020076 /* HII string protocol */
77 &efi_guid_hii_string_protocol,
78 (void *)&efi_hii_string,
79 /* HII database protocol */
80 &efi_guid_hii_database_protocol,
81 (void *)&efi_hii_database,
Heinrich Schuchardt926e6962019-04-07 23:53:53 +020082#endif
Heinrich Schuchardt2e0a7902019-05-05 16:55:06 +020083 NULL));
84 efi_root->type = EFI_OBJECT_TYPE_U_BOOT_FIRMWARE;
85 return ret;
Heinrich Schuchardt79d72022018-09-20 21:58:23 +020086}