efitools for target. Might be used for reading efivariables or signing/resigning images on the target. efitools might also be used for signing EFI images on host. This is the target package.
Signed-off-by: Christian Melki <[email protected]> --- rules/efitools.in | 11 ++++++ rules/efitools.make | 84 +++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 95 insertions(+) create mode 100644 rules/efitools.in create mode 100644 rules/efitools.make diff --git a/rules/efitools.in b/rules/efitools.in new file mode 100644 index 000000000..1b1b1d0ba --- /dev/null +++ b/rules/efitools.in @@ -0,0 +1,11 @@ +## SECTION=shell_and_console + +config EFITOOLS + tristate + select LIBC_DL + select GNU_EFI + select OPENSSL + select HOST_EFITOOLS + prompt "efitools" + help + Useful tools for manipulating UEFI secure boot platforms diff --git a/rules/efitools.make b/rules/efitools.make new file mode 100644 index 000000000..4e43dc3fd --- /dev/null +++ b/rules/efitools.make @@ -0,0 +1,84 @@ +# -*-makefile-*- +# +# Copyright (C) 2021 by Christian Melki <[email protected]> +# +# For further information about the PTXdist project and license conditions +# see the README file. +# + +# +# We provide this package +# +PACKAGES-$(PTXCONF_EFITOOLS) += efitools + +# +# Paths and names +# +EFITOOLS_VERSION := 1.9.2 +EFITOOLS_MD5 := a3a3f04ed6aa5486c97dd206edeebe0a +EFITOOLS := efitools-$(EFITOOLS_VERSION) +EFITOOLS_SUFFIX := tar.gz +EFITOOLS_URL := https://git.kernel.org/pub/scm/linux/kernel/git/jejb/efitools.git/snapshot/$(EFITOOLS).$(EFITOOLS_SUFFIX) +EFITOOLS_SOURCE := $(SRCDIR)/$(EFITOOLS).$(EFITOOLS_SUFFIX) +EFITOOLS_DIR := $(BUILDDIR)/$(EFITOOLS) +EFITOOLS_LICENSE := GPL-2.0-or-later +EFITOOLS_LICENSE_FILES := \ + file://COPYING;md5=97d554a32881fee0aa283d96e47cb24a + +# ---------------------------------------------------------------------------- +# Prepare +# ---------------------------------------------------------------------------- + +ifdef PTXCONF_ARCH_X86 +EFITOOLS_ARCH := ia32 +ifdef PTXCONF_ARCH_X86_64 +EFITOOLS_ARCH := x86_64 +endif +endif +ifdef PTXCONF_ARCH_ARM +EFITOOLS_ARCH := arm +endif +ifdef PTXCONF_ARCH_ARM64 +EFITOOLS_ARCH := aarch64 +endif + +EFITOOLS_CONF_TOOL := NO + +EFITOOLS_MAKE_ENV := \ + $(CROSS_ENV) \ + ARCH=$(EFITOOLS_ARCH) \ + INCDIR_PREFIX=$(SYSROOT) \ + CRTPATH_PREFIX=$(SYSROOT) \ + OPENSSL_LIB=$(PTXDIST_SYSROOT_HOST) \ + SIGN_EFI_SIG_LIST=$(PTXDIST_SYSROOT_HOST)/usr/bin/sign-efi-sig-list \ + CERT_TO_EFI_SIG_LIST=$(PTXDIST_SYSROOT_HOST)/usr/bin/cert-to-efi-sig-list \ + CERT_TO_EFI_HASH_LIST=$(PTXDIST_SYSROOT_HOST)/usr/bin/cert-to-efi-hash-list \ + HASH_TO_EFI_SIG_LIST=$(PTXDIST_SYSROOT_HOST)/usr/bin/hash-to-efi-sig-list \ + prefix=/usr + +# ---------------------------------------------------------------------------- +# Target-Install +# ---------------------------------------------------------------------------- + +$(STATEDIR)/efitools.targetinstall: + @$(call targetinfo) + + @$(call install_init, efitools) + @$(call install_fixup, efitools,PRIORITY,optional) + @$(call install_fixup, efitools,SECTION,base) + @$(call install_fixup, efitools,AUTHOR,"Christian Melki <[email protected]>") + @$(call install_fixup, efitools,DESCRIPTION,missing) + @$(call install_copy, efitools, 0, 0, 0755, -, /usr/bin/cert-to-efi-hash-list) + @$(call install_copy, efitools, 0, 0, 0755, -, /usr/bin/cert-to-efi-sig-list) + @$(call install_copy, efitools, 0, 0, 0755, -, /usr/bin/efi-readvar) + @$(call install_copy, efitools, 0, 0, 0755, -, /usr/bin/efi-updatevar) + @$(call install_copy, efitools, 0, 0, 0755, -, /usr/bin/efitool-mkusb) + @$(call install_copy, efitools, 0, 0, 0755, -, /usr/bin/flash-var) + @$(call install_copy, efitools, 0, 0, 0755, -, /usr/bin/hash-to-efi-sig-list) + @$(call install_copy, efitools, 0, 0, 0755, -, /usr/bin/sig-list-to-certs) + @$(call install_copy, efitools, 0, 0, 0755, -, /usr/bin/sign-efi-sig-list) + @$(call install_finish, efitools) + + @$(call touch) + +# vim: syntax=make -- 2.32.0 _______________________________________________ ptxdist mailing list [email protected] To unsubscribe, send a mail with subject "unsubscribe" to [email protected]
