From nobody Tue Feb 10 00:22:31 2026 Delivered-To: importer@patchew.org Received-SPF: pass (zohomail.com: domain of groups.io designates 66.175.222.108 as permitted sender) client-ip=66.175.222.108; envelope-from=bounce+27952+95116+1787277+3901457@groups.io; helo=mail02.groups.io; Authentication-Results: mx.zohomail.com; dkim=pass; spf=pass (zohomail.com: domain of groups.io designates 66.175.222.108 as permitted sender) smtp.mailfrom=bounce+27952+95116+1787277+3901457@groups.io ARC-Seal: i=1; a=rsa-sha256; t=1665655135; cv=none; d=zohomail.com; s=zohoarc; b=RfvJeLTjp7lj03A8fLV+yupGIEfNMLexk9JrKRz9IJL1wD67AQtdxO+FDHA7WSwZanjN+TK2t1ynVam6ICAUVrAmz8kPO/n50QQgEk37slXhzVIJwvtn8q1acdtUkOOD3nTMeZfLunY/OdKW0oOIJ6d8gA9D3/HGgAbWL3Qu8MQ= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1665655135; h=Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Id:List-Help:List-Unsubscribe:MIME-Version:Message-ID:Reply-To:References:Sender:Subject:To; bh=ApCJsqH+DkotQ8LjnuA00tsTCj272pPY5vT+3+4KiqM=; b=ODa8Yw+UrfVeQy5mWKawL8r68C6OShX3sfUB1V+0yFhtuYw8WuLRUWdUJebU9kDPv66F145zXl6ucEwuBFaiQgqiXPfPy+kMKKT3Dt0dqUx199OF18DikX15d+lS4Gi+WmMXtjKLa81wEZRumgMXH0q1ud3ERs5T1h2TTiipmkE= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; spf=pass (zohomail.com: domain of groups.io designates 66.175.222.108 as permitted sender) smtp.mailfrom=bounce+27952+95116+1787277+3901457@groups.io Received: from mail02.groups.io (mail02.groups.io [66.175.222.108]) by mx.zohomail.com with SMTPS id 1665655135647442.487187986412; Thu, 13 Oct 2022 02:58:55 -0700 (PDT) Return-Path: X-Received: by 127.0.0.2 with SMTP id FIUgYY1788612xZjkHarADSk; Thu, 13 Oct 2022 02:58:55 -0700 X-Received: from mail-pg1-f169.google.com (mail-pg1-f169.google.com [209.85.215.169]) by mx.groups.io with SMTP id smtpd.web12.5667.1665655134797578039 for ; Thu, 13 Oct 2022 02:58:54 -0700 X-Received: by mail-pg1-f169.google.com with SMTP id 129so1139328pgc.5 for ; Thu, 13 Oct 2022 02:58:54 -0700 (PDT) X-Gm-Message-State: 5Xpnf9DYKUnvuHi05lnJ8atOx1787277AA= X-Google-Smtp-Source: AMsMyM4HkScdFSX9LmW5zESjqcJC3EnlW+vV16PQfIOX/l3ULgGuV9SWJzldlxo7xRWvJ8HzBQKIDg== X-Received: by 2002:a05:6a00:408c:b0:565:fc2c:8c71 with SMTP id bw12-20020a056a00408c00b00565fc2c8c71mr980730pfb.82.1665655134095; Thu, 13 Oct 2022 02:58:54 -0700 (PDT) X-Received: from localhost.localdomain ([49.206.13.138]) by smtp.gmail.com with ESMTPSA id w8-20020a17090abc0800b0020d43c5c9a0sm2931845pjr.18.2022.10.13.02.58.51 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 13 Oct 2022 02:58:53 -0700 (PDT) From: "Sunil V L" To: devel@edk2.groups.io Cc: Ard Biesheuvel , Jiewen Yao , Jordan Justen , Gerd Hoffmann , Daniel Schaefer Subject: [edk2-devel] [edk2-staging/RiscV64QemuVirt PATCH V3 06/34] OvmfPkg/PlatformInitLib: Add support for RISC-V Date: Thu, 13 Oct 2022 15:28:01 +0530 Message-Id: <20221013095829.1454581-7-sunilvl@ventanamicro.com> In-Reply-To: <20221013095829.1454581-1-sunilvl@ventanamicro.com> References: <20221013095829.1454581-1-sunilvl@ventanamicro.com> MIME-Version: 1.0 Precedence: Bulk List-Unsubscribe: List-Subscribe: List-Help: Sender: devel@edk2.groups.io List-Id: Mailing-List: list devel@edk2.groups.io; contact devel+owner@edk2.groups.io Reply-To: devel@edk2.groups.io,sunilvl@ventanamicro.com Content-Transfer-Encoding: quoted-printable DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=groups.io; q=dns/txt; s=20140610; t=1665655135; bh=euRTbFoOZl9Ff+LyHKIQk/1bmxz9qjPtASziMMVAG2k=; h=Cc:Date:From:Reply-To:Subject:To; b=U4ghDiEuGXeamCxnx5XgD8JeSayE1e8Q4KzEprm5lgiuLKaMXb4iqjs3dqBiICgbHgs 3+h7TmBO/F05iqn5+Fz79mp6Jt8UOPqo6jDGNt587GBaghvddEATMHDocoK5TCyVhUbSI VmT6XMLhx2nn2oV6E91dPL2aGv49JqIj2LE= X-ZohoMail-DKIM: pass (identity @groups.io) X-ZM-MESSAGEID: 1665655137752100006 Content-Type: text/plain; charset="utf-8" REF: https://bugzilla.tianocore.org/show_bug.cgi?id=3D4076 This is copied from edk2-platforms/Platform/RISC-V/PlatformPkg/Universal/FdtPeim but added as part of library instead of a separate module. Cc: Ard Biesheuvel Cc: Jiewen Yao Cc: Jordan Justen Cc: Gerd Hoffmann Cc: Daniel Schaefer Signed-off-by: Sunil V L --- .../PlatformInitLib/PlatformInitLib.inf | 9 ++- OvmfPkg/Include/Library/PlatformInitLib.h | 6 ++ .../PlatformInitLib/RiscV64/PlatformPeiLib.c | 73 +++++++++++++++++++ 3 files changed, 87 insertions(+), 1 deletion(-) create mode 100644 OvmfPkg/Library/PlatformInitLib/RiscV64/PlatformPeiLib.c diff --git a/OvmfPkg/Library/PlatformInitLib/PlatformInitLib.inf b/OvmfPkg/= Library/PlatformInitLib/PlatformInitLib.inf index d4449e40af61..ef8675999583 100644 --- a/OvmfPkg/Library/PlatformInitLib/PlatformInitLib.inf +++ b/OvmfPkg/Library/PlatformInitLib/PlatformInitLib.inf @@ -19,7 +19,7 @@ [Defines] # # The following information is for reference only and not required by the = build tools. # -# VALID_ARCHITECTURES =3D IA32 X64 EBC +# VALID_ARCHITECTURES =3D IA32 X64 EBC RISCV64 # =20 [Sources.IA32, Sources.X64] @@ -33,6 +33,9 @@ [Sources.IA32] [Sources.X64] Ia32_X64/IntelTdx.c =20 +[Sources.RISCV64] + RiscV64/PlatformPeiLib.c + [Packages] EmbeddedPkg/EmbeddedPkg.dec MdeModulePkg/MdeModulePkg.dec @@ -58,6 +61,10 @@ [LibraryClasses.IA32, LibraryClasses.X64] [LibraryClasses.X64] TdxLib =20 +[LibraryClasses.RISCV64] + RiscVSbiLib + FdtLib + [Pcd] gEfiMdePkgTokenSpaceGuid.PcdPciExpressBaseAddress =20 diff --git a/OvmfPkg/Include/Library/PlatformInitLib.h b/OvmfPkg/Include/Li= brary/PlatformInitLib.h index c5234bf26d45..1b8d1fad3b49 100644 --- a/OvmfPkg/Include/Library/PlatformInitLib.h +++ b/OvmfPkg/Include/Library/PlatformInitLib.h @@ -285,4 +285,10 @@ PlatformInitEmuVariableNvStore ( IN VOID *EmuVariableNvStore ); =20 +EFI_STATUS +EFIAPI +PlatformPeim ( + VOID + ); + #endif // PLATFORM_INIT_LIB_H_ diff --git a/OvmfPkg/Library/PlatformInitLib/RiscV64/PlatformPeiLib.c b/Ovm= fPkg/Library/PlatformInitLib/RiscV64/PlatformPeiLib.c new file mode 100644 index 000000000000..c5db7777c849 --- /dev/null +++ b/OvmfPkg/Library/PlatformInitLib/RiscV64/PlatformPeiLib.c @@ -0,0 +1,73 @@ +/** @file +The library call to pass the device tree to DXE via HOB. + +Copyright (c) 2021, Hewlett Packard Enterprise Development LP. All rights = reserved.
+Copyright (c) 2022, Ventana Micro Systems Inc. All rights reserved.
+ +SPDX-License-Identifier: BSD-2-Clause-Patent + +**/ + +// +//// The package level header files this module uses +//// +#include + +#include +#include +#include +#include + +#include + +#include + +/** + @retval EFI_SUCCESS The address of FDT is passed in HOB. + EFI_UNSUPPORTED Can't locate FDT. +**/ +EFI_STATUS +EFIAPI +PlatformPeim ( + VOID + ) +{ + EFI_RISCV_FIRMWARE_CONTEXT *FirmwareContext; + VOID *FdtPointer; + VOID *Base; + VOID *NewBase; + UINTN FdtSize; + UINTN FdtPages; + UINT64 *FdtHobData; + + FirmwareContext =3D NULL; + GetFirmwareContextPointer (&FirmwareContext); + + if (FirmwareContext =3D=3D NULL) { + DEBUG ((DEBUG_ERROR, "%a: Firmware Context is NULL\n", __FUNCTION__)); + return EFI_UNSUPPORTED; + } + + FdtPointer =3D (VOID *)FirmwareContext->FlattenedDeviceTree; + if (FdtPointer =3D=3D NULL) { + DEBUG ((DEBUG_ERROR, "%a: Invalid FDT pointer\n", __FUNCTION__)); + return EFI_UNSUPPORTED; + } + + DEBUG ((DEBUG_INFO, "%a: Build FDT HOB - FDT at address: 0x%x \n", __FUN= CTION__, FdtPointer)); + Base =3D FdtPointer; + ASSERT (Base !=3D NULL); + ASSERT (fdt_check_header (Base) =3D=3D 0); + + FdtSize =3D fdt_totalsize (Base); + FdtPages =3D EFI_SIZE_TO_PAGES (FdtSize); + NewBase =3D AllocatePages (FdtPages); + ASSERT (NewBase !=3D NULL); + fdt_open_into (Base, NewBase, EFI_PAGES_TO_SIZE (FdtPages)); + + FdtHobData =3D BuildGuidHob (&gFdtHobGuid, sizeof *FdtHobData); + ASSERT (FdtHobData !=3D NULL); + *FdtHobData =3D (UINTN)NewBase; + + return EFI_SUCCESS; +} --=20 2.25.1 -=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D- Groups.io Links: You receive all messages sent to this group. View/Reply Online (#95116): https://edk2.groups.io/g/devel/message/95116 Mute This Topic: https://groups.io/mt/94300386/1787277 Group Owner: devel+owner@edk2.groups.io Unsubscribe: https://edk2.groups.io/g/devel/unsub [importer@patchew.org] -=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-