!48 Fix build on riscv64
From: @misaka00251 Reviewed-by: @Charlie_li Signed-off-by: @Charlie_li
This commit is contained in:
commit
5c2134e857
136
crt0-efi-riscv64.S
Normal file
136
crt0-efi-riscv64.S
Normal file
@ -0,0 +1,136 @@
|
|||||||
|
/* SPDX-License-Identifier: GPL-2.0+ */
|
||||||
|
/*
|
||||||
|
* Copright (C) 2014 Linaro Ltd. <ard.biesheuvel@linaro.org>
|
||||||
|
* Copright (C) 2018 Alexander Graf <agraf@suse.de>
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice and this list of conditions, without modification.
|
||||||
|
* 2. The name of the author may not be used to endorse or promote products
|
||||||
|
* derived from this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* Alternatively, this software may be distributed under the terms of the
|
||||||
|
* GNU General Public License as published by the Free Software Foundation;
|
||||||
|
* either version 2 of the License, or (at your option) any later version.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef EFI_SUBSYSTEM
|
||||||
|
#define EFI_SUBSYSTEM 10
|
||||||
|
#endif
|
||||||
|
|
||||||
|
.section .text.head
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Magic "MZ" signature for PE/COFF
|
||||||
|
*/
|
||||||
|
.globl ImageBase
|
||||||
|
ImageBase:
|
||||||
|
.ascii "MZ"
|
||||||
|
.skip 58 // 'MZ' + pad + offset == 64
|
||||||
|
.long pe_header - ImageBase // Offset to the PE header.
|
||||||
|
pe_header:
|
||||||
|
.ascii "PE"
|
||||||
|
.short 0
|
||||||
|
coff_header:
|
||||||
|
.short 0x5064 // riscv64
|
||||||
|
.short 2 // nr_sections
|
||||||
|
.long 0 // TimeDateStamp
|
||||||
|
.long 0 // PointerToSymbolTable
|
||||||
|
.long 0 // NumberOfSymbols
|
||||||
|
.short section_table - optional_header // SizeOfOptionalHeader
|
||||||
|
.short 0x206 // Characteristics.
|
||||||
|
// IMAGE_FILE_DEBUG_STRIPPED |
|
||||||
|
// IMAGE_FILE_EXECUTABLE_IMAGE |
|
||||||
|
// IMAGE_FILE_LINE_NUMS_STRIPPED
|
||||||
|
optional_header:
|
||||||
|
.short 0x20b // PE32+ format
|
||||||
|
.byte 0x02 // MajorLinkerVersion
|
||||||
|
.byte 0x14 // MinorLinkerVersion
|
||||||
|
.long _data - _start // SizeOfCode
|
||||||
|
.long _data_size // SizeOfInitializedData
|
||||||
|
.long 0 // SizeOfUninitializedData
|
||||||
|
.long _start - ImageBase // AddressOfEntryPoint
|
||||||
|
.long _start - ImageBase // BaseOfCode
|
||||||
|
|
||||||
|
extra_header_fields:
|
||||||
|
.quad 0 // ImageBase
|
||||||
|
.long 0x1000 // SectionAlignment
|
||||||
|
.long 0x200 // FileAlignment
|
||||||
|
.short 0 // MajorOperatingSystemVersion
|
||||||
|
.short 0 // MinorOperatingSystemVersion
|
||||||
|
.short 0 // MajorImageVersion
|
||||||
|
.short 0 // MinorImageVersion
|
||||||
|
.short 0 // MajorSubsystemVersion
|
||||||
|
.short 0 // MinorSubsystemVersion
|
||||||
|
.long 0 // Win32VersionValue
|
||||||
|
|
||||||
|
.long _edata - ImageBase // SizeOfImage
|
||||||
|
|
||||||
|
// Everything before the kernel image is considered part of the header
|
||||||
|
.long _start - ImageBase // SizeOfHeaders
|
||||||
|
.long 0 // CheckSum
|
||||||
|
.short EFI_SUBSYSTEM // Subsystem
|
||||||
|
.short 0 // DllCharacteristics
|
||||||
|
.quad 0 // SizeOfStackReserve
|
||||||
|
.quad 0 // SizeOfStackCommit
|
||||||
|
.quad 0 // SizeOfHeapReserve
|
||||||
|
.quad 0 // SizeOfHeapCommit
|
||||||
|
.long 0 // LoaderFlags
|
||||||
|
.long 0x6 // NumberOfRvaAndSizes
|
||||||
|
|
||||||
|
.quad 0 // ExportTable
|
||||||
|
.quad 0 // ImportTable
|
||||||
|
.quad 0 // ResourceTable
|
||||||
|
.quad 0 // ExceptionTable
|
||||||
|
.quad 0 // CertificationTable
|
||||||
|
.quad 0 // BaseRelocationTable
|
||||||
|
|
||||||
|
// Section table
|
||||||
|
section_table:
|
||||||
|
/*
|
||||||
|
* The EFI application loader requires a relocation section
|
||||||
|
* because EFI applications must be relocatable. This is a
|
||||||
|
* dummy section as far as we are concerned.
|
||||||
|
*/
|
||||||
|
.ascii ".reloc\0\0"
|
||||||
|
.long 0
|
||||||
|
.long 0
|
||||||
|
.long 0 // SizeOfRawData
|
||||||
|
.long 0 // PointerToRawData
|
||||||
|
.long 0 // PointerToRelocations
|
||||||
|
.long 0 // PointerToLineNumbers
|
||||||
|
.short 0 // NumberOfRelocations
|
||||||
|
.short 0 // NumberOfLineNumbers
|
||||||
|
.long 0x42100040 // Characteristics (section flags)
|
||||||
|
|
||||||
|
.ascii ".text\0\0\0"
|
||||||
|
.long _edata - _start // VirtualSize
|
||||||
|
.long _start - ImageBase // VirtualAddress
|
||||||
|
.long _edata - _start // SizeOfRawData
|
||||||
|
.long _start - ImageBase // PointerToRawData
|
||||||
|
|
||||||
|
.long 0 // PointerToRelocations (0 for executables)
|
||||||
|
.long 0 // PointerToLineNumbers (0 for executables)
|
||||||
|
.short 0 // NumberOfRelocations (0 for executables)
|
||||||
|
.short 0 // NumberOfLineNumbers (0 for executables)
|
||||||
|
.long 0xe0500020 // Characteristics (section flags)
|
||||||
|
|
||||||
|
.align 12
|
||||||
|
.globl _start
|
||||||
|
_start:
|
||||||
|
addi sp, sp, -24
|
||||||
|
sd a0, 0(sp)
|
||||||
|
sd a1, 8(sp)
|
||||||
|
sd ra, 16(sp)
|
||||||
|
lla a0, ImageBase
|
||||||
|
lla a1, _DYNAMIC
|
||||||
|
call _relocate
|
||||||
|
bne a0, zero, 0f
|
||||||
|
ld a1, 8(sp)
|
||||||
|
ld a0, 0(sp)
|
||||||
|
call efi_main
|
||||||
|
ld ra, 16(sp)
|
||||||
|
0: addi sp, sp, 24
|
||||||
|
ret
|
||||||
77
elf_riscv64_efi.lds
Normal file
77
elf_riscv64_efi.lds
Normal file
@ -0,0 +1,77 @@
|
|||||||
|
/* SPDX-License-Identifier: GPL-2.0+ */
|
||||||
|
|
||||||
|
OUTPUT_FORMAT("elf64-littleriscv", "elf64-littleriscv", "elf64-littleriscv")
|
||||||
|
OUTPUT_ARCH(riscv)
|
||||||
|
ENTRY(_start)
|
||||||
|
SECTIONS {
|
||||||
|
.text 0x0 :
|
||||||
|
{
|
||||||
|
_text = .;
|
||||||
|
*(.text.head)
|
||||||
|
*(.text)
|
||||||
|
*(.text.*)
|
||||||
|
*(.gnu.linkonce.t.*)
|
||||||
|
*(.srodata)
|
||||||
|
*(.rodata*)
|
||||||
|
. = ALIGN(16);
|
||||||
|
}
|
||||||
|
_etext = .;
|
||||||
|
_text_size = . - _text;
|
||||||
|
.dynamic :
|
||||||
|
{ *(.dynamic) }
|
||||||
|
.data :
|
||||||
|
ALIGN(4096)
|
||||||
|
{
|
||||||
|
_data = .;
|
||||||
|
*(.sdata)
|
||||||
|
*(.data)
|
||||||
|
*(.data1)
|
||||||
|
*(.data.*)
|
||||||
|
*(.got.plt)
|
||||||
|
*(.got)
|
||||||
|
|
||||||
|
/* the EFI loader doesn't seem to like a .bss section, so we stick
|
||||||
|
it all into .data: */
|
||||||
|
. = ALIGN(16);
|
||||||
|
_bss = .;
|
||||||
|
*(.sbss)
|
||||||
|
*(.scommon)
|
||||||
|
*(.dynbss)
|
||||||
|
*(.bss)
|
||||||
|
*(COMMON)
|
||||||
|
. = ALIGN(16);
|
||||||
|
_bss_end = .;
|
||||||
|
}
|
||||||
|
|
||||||
|
.rela.text :
|
||||||
|
{ *(.rela.text) *(.rela.text*) }
|
||||||
|
.rela.dyn :
|
||||||
|
{ *(.rela.dyn) }
|
||||||
|
.rela.plt :
|
||||||
|
{ *(.rela.plt) }
|
||||||
|
.rela.got :
|
||||||
|
{ *(.rela.got) }
|
||||||
|
.rela.data :
|
||||||
|
{ *(.rela.data) *(.rela.data*) }
|
||||||
|
. = ALIGN(512);
|
||||||
|
_edata = .;
|
||||||
|
_data_size = . - _data;
|
||||||
|
|
||||||
|
. = ALIGN(4096);
|
||||||
|
.dynsym :
|
||||||
|
{ *(.dynsym) }
|
||||||
|
. = ALIGN(4096);
|
||||||
|
.dynstr :
|
||||||
|
{ *(.dynstr) }
|
||||||
|
. = ALIGN(4096);
|
||||||
|
.note.gnu.build-id :
|
||||||
|
{ *(.note.gnu.build-id) }
|
||||||
|
/DISCARD/ :
|
||||||
|
{
|
||||||
|
*(.rel.reloc)
|
||||||
|
*(.eh_frame)
|
||||||
|
*(.note.GNU-stack)
|
||||||
|
}
|
||||||
|
.comment 0 :
|
||||||
|
{ *(.comment) }
|
||||||
|
}
|
||||||
32
fwupd.spec
32
fwupd.spec
@ -12,17 +12,17 @@
|
|||||||
%global enable_dummy 1
|
%global enable_dummy 1
|
||||||
|
|
||||||
# fwupd.efi is only available on these arches
|
# fwupd.efi is only available on these arches
|
||||||
%ifarch x86_64 aarch64
|
%ifarch x86_64 aarch64 riscv64
|
||||||
%global have_uefi 1
|
%global have_uefi 1
|
||||||
%endif
|
%endif
|
||||||
|
|
||||||
# gpio.h is only available on these arches
|
# gpio.h is only available on these arches
|
||||||
%ifarch x86_64 aarch64
|
%ifarch x86_64 aarch64 riscv64
|
||||||
%global have_gpio 1
|
%global have_gpio 1
|
||||||
%endif
|
%endif
|
||||||
|
|
||||||
# flashrom is only available on these arches
|
# flashrom is only available on these arches
|
||||||
%ifarch i686 x86_64 armv7hl aarch64 ppc64le
|
%ifarch i686 x86_64 armv7hl aarch64 ppc64le riscv64
|
||||||
%global have_flashrom 0
|
%global have_flashrom 0
|
||||||
%endif
|
%endif
|
||||||
|
|
||||||
@ -43,7 +43,7 @@
|
|||||||
|
|
||||||
Name: fwupd
|
Name: fwupd
|
||||||
Version: 1.8.6
|
Version: 1.8.6
|
||||||
Release: 5
|
Release: 6
|
||||||
License: LGPLv2+
|
License: LGPLv2+
|
||||||
Summary: Make updating firmware on Linux automatic, safe and reliable
|
Summary: Make updating firmware on Linux automatic, safe and reliable
|
||||||
URL: https://github.com/fwupd/fwupd
|
URL: https://github.com/fwupd/fwupd
|
||||||
@ -59,9 +59,13 @@ Source9: http://people.redhat.com/rhughes/dbx/DBXUpdate-20160809-x64.cab
|
|||||||
Source10: http://people.redhat.com/rhughes/dbx/DBXUpdate-20200729-aa64.cab
|
Source10: http://people.redhat.com/rhughes/dbx/DBXUpdate-20200729-aa64.cab
|
||||||
Source11: http://people.redhat.com/rhughes/dbx/DBXUpdate-20200729-ia32.cab
|
Source11: http://people.redhat.com/rhughes/dbx/DBXUpdate-20200729-ia32.cab
|
||||||
Source12: http://people.redhat.com/rhughes/dbx/DBXUpdate-20200729-x64.cab
|
Source12: http://people.redhat.com/rhughes/dbx/DBXUpdate-20200729-x64.cab
|
||||||
|
Source13: https://sourceforge.net/p/gnu-efi/code/ci/3.0.14/tree/gnuefi/crt0-efi-riscv64.S?format=raw#/crt0-efi-riscv64.S
|
||||||
|
Source14: https://sourceforge.net/p/gnu-efi/code/ci/3.0.14/tree/gnuefi/elf_riscv64_efi.lds?format=raw#/elf_riscv64_efi.lds
|
||||||
|
|
||||||
Patch0: fwupd-efi.patch
|
Patch0: fwupd-efi.patch
|
||||||
|
%ifarch riscv64
|
||||||
|
Patch1: https://raw.githubusercontent.com/GNOME/gnome-build-meta/37bc8931517261e359e02b2b14bffab0501e79d9/files/fwupd/riscv64.patch
|
||||||
|
%endif
|
||||||
|
|
||||||
BuildRequires: libcbor libcbor-devel
|
BuildRequires: libcbor libcbor-devel
|
||||||
BuildRequires: efi-srpm-macros
|
BuildRequires: efi-srpm-macros
|
||||||
@ -163,11 +167,18 @@ Provides: dbxtool-help
|
|||||||
Man pages and other related documents for fwupd.
|
Man pages and other related documents for fwupd.
|
||||||
|
|
||||||
%prep
|
%prep
|
||||||
%autosetup -p1
|
%setup -q -n %{name}-%{version}
|
||||||
|
%patch0 -p1
|
||||||
|
|
||||||
mkdir -p subprojects/fwupd-efi
|
mkdir -p subprojects/fwupd-efi
|
||||||
tar xfs %{SOURCE2} -C subprojects/fwupd-efi --strip-components=1
|
tar xfs %{SOURCE2} -C subprojects/fwupd-efi --strip-components=1
|
||||||
|
|
||||||
|
%ifarch riscv64
|
||||||
|
%patch1 -p1
|
||||||
|
cp %{SOURCE13} subprojects/fwupd-efi/efi/crt0
|
||||||
|
cp %{SOURCE14} subprojects/fwupd-efi/efi/lds
|
||||||
|
%endif
|
||||||
|
|
||||||
sed -ri '1s=^#!/usr/bin/(env )?python3=#!%{__python3}=' \
|
sed -ri '1s=^#!/usr/bin/(env )?python3=#!%{__python3}=' \
|
||||||
contrib/ci/*.py \
|
contrib/ci/*.py \
|
||||||
contrib/firmware_packager/*.py \
|
contrib/firmware_packager/*.py \
|
||||||
@ -330,9 +341,14 @@ done
|
|||||||
%endif
|
%endif
|
||||||
%dir %{_libexecdir}/fwupd
|
%dir %{_libexecdir}/fwupd
|
||||||
%{_libexecdir}/fwupd/fwupd
|
%{_libexecdir}/fwupd/fwupd
|
||||||
|
# depending on compiler behavior
|
||||||
|
# currently skipped from building if compiled by llvm
|
||||||
|
%if "%toolchain" == "llvm"
|
||||||
|
%else
|
||||||
%ifarch i686 x86_64
|
%ifarch i686 x86_64
|
||||||
%{_libexecdir}/fwupd/fwupd-detect-cet
|
%{_libexecdir}/fwupd/fwupd-detect-cet
|
||||||
%endif
|
%endif
|
||||||
|
%endif
|
||||||
%{_libexecdir}/fwupd/fwupdoffline
|
%{_libexecdir}/fwupd/fwupdoffline
|
||||||
%if 0%{?have_uefi}
|
%if 0%{?have_uefi}
|
||||||
%{_bindir}/fwupdate
|
%{_bindir}/fwupdate
|
||||||
@ -458,6 +474,10 @@ done
|
|||||||
%{_datadir}/man/man1/*
|
%{_datadir}/man/man1/*
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Mon Jul 10 2023 misaka00251 <liuxin@iscas.ac.cn> - 1.8.6-6
|
||||||
|
- Fix build on riscv64
|
||||||
|
- from @jchzhou: skip packaging fwupd-detect-cet if compiled with llvm
|
||||||
|
|
||||||
* Fri Mar 10 2023 zhouwenpei <zhouwenpei1@h-partners.com> - 1.8.6-5
|
* Fri Mar 10 2023 zhouwenpei <zhouwenpei1@h-partners.com> - 1.8.6-5
|
||||||
- remove bluez require
|
- remove bluez require
|
||||||
|
|
||||||
|
|||||||
49
riscv64.patch
Normal file
49
riscv64.patch
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
diff --git a/subprojects/fwupd-efi/efi/generate_binary.py b/subprojects/fwupd-efi/efi/generate_binary.py
|
||||||
|
index a8a4437..9af5853 100755
|
||||||
|
--- a/subprojects/fwupd-efi/efi/generate_binary.py
|
||||||
|
+++ b/subprojects/fwupd-efib/efi/generate_binary.py
|
||||||
|
@@ -36,7 +36,7 @@ def _run_objcopy(args):
|
||||||
|
|
||||||
|
# aarch64 and arm32 don't have an EFI capable objcopy
|
||||||
|
# Use 'binary' instead, and add required symbols manually
|
||||||
|
- if args.arch in ["aarch64", "arm"]:
|
||||||
|
+ if args.arch in ["aarch64", "arm", "riscv64"]:
|
||||||
|
argv.extend(["-O", "binary"])
|
||||||
|
elif args.os == "freebsd":
|
||||||
|
# `--target` option is missing and --input-target doesn't recognize
|
||||||
|
diff --git a/subprojects/fwupd-efi/efi/meson.build b/subprojects/fwupd-efi/efi/meson.build
|
||||||
|
index 68ea4aa..26ba42c 100644
|
||||||
|
--- a/subprojects/fwupd-efi/efi/meson.build
|
||||||
|
+++ b/subprojects/fwupd-efi/efi/meson.build
|
||||||
|
@@ -18,7 +18,7 @@ endif
|
||||||
|
|
||||||
|
efi_libdir = get_option('efi-libdir')
|
||||||
|
if efi_libdir == ''
|
||||||
|
- cmd = 'cd /usr/lib/$(@0@ -print-multi-os-directory) && pwd'.format(efi_cc)
|
||||||
|
+ cmd = 'cd /usr/lib64/$(@0@ -print-multi-os-directory) && pwd'.format(efi_cc)
|
||||||
|
ret = run_command('sh', '-c', cmd)
|
||||||
|
if ret.returncode() == 0
|
||||||
|
efi_libdir = ret.stdout().strip()
|
||||||
|
@@ -79,7 +79,7 @@ if get_option('efi_sbat_distro_id') != ''
|
||||||
|
endif
|
||||||
|
|
||||||
|
# is the system crt0 for arm and aarch64 new enough to know about SBAT?
|
||||||
|
-if host_cpu == 'aarch64' or host_cpu == 'arm'
|
||||||
|
+if host_cpu == 'aarch64' or host_cpu == 'arm' or host_cpu == 'riscv64'
|
||||||
|
if get_option('efi_sbat_distro_id') != ''
|
||||||
|
arch_crt_source = 'crt0-efi-@0@.S'.format(gnu_efi_path_arch)
|
||||||
|
cmd = run_command('grep', '-q', 'sbat', join_paths(efi_crtdir, arch_crt_source))
|
||||||
|
diff --git a/subprojects/fwupd-efi/meson.build b/subprojects/fwupd-efi/meson.build
|
||||||
|
index 1753411..8d23a50 100644
|
||||||
|
--- a/subprojects/fwupd-efi/meson.build
|
||||||
|
+++ b/subprojects/fwupd-efi/meson.build
|
||||||
|
@@ -27,6 +27,9 @@ elif host_cpu == 'arm'
|
||||||
|
elif host_cpu == 'aarch64'
|
||||||
|
EFI_MACHINE_TYPE_NAME = 'aa64'
|
||||||
|
gnu_efi_arch = 'aarch64'
|
||||||
|
+elif host_cpu == 'riscv64'
|
||||||
|
+ EFI_MACHINE_TYPE_NAME = 'riscv64'
|
||||||
|
+ gnu_efi_arch = 'riscv64'
|
||||||
|
else
|
||||||
|
error('Unknown host_cpu ' + host_cpu)
|
||||||
|
endif
|
||||||
Loading…
x
Reference in New Issue
Block a user