Makefile 3.3 KB
Newer Older
1
# SPDX-License-Identifier: GPL-2.0
2 3 4 5
#
# Makefile for the linux kernel signature checking certificates.
#

6 7
obj-$(CONFIG_SYSTEM_TRUSTED_KEYRING) += system_keyring.o system_certificates.o
obj-$(CONFIG_SYSTEM_BLACKLIST_KEYRING) += blacklist.o
8
obj-$(CONFIG_SYSTEM_REVOCATION_LIST) += revocation_certificates.o
9
ifneq ($(CONFIG_SYSTEM_BLACKLIST_HASH_LIST),)
10

11 12
$(obj)/blacklist_hashes.o: $(obj)/blacklist_hash_list
CFLAGS_blacklist_hashes.o := -I $(obj)
13

14 15
quiet_cmd_check_and_copy_blacklist_hash_list = GEN     $@
      cmd_check_and_copy_blacklist_hash_list = \
16
	$(AWK) -f $(srctree)/$(src)/check-blacklist-hashes.awk $(CONFIG_SYSTEM_BLACKLIST_HASH_LIST) >&2; \
17
	cat $(CONFIG_SYSTEM_BLACKLIST_HASH_LIST) > $@
18

19 20
$(obj)/blacklist_hash_list: $(CONFIG_SYSTEM_BLACKLIST_HASH_LIST) FORCE
	$(call if_changed,check_and_copy_blacklist_hash_list)
21 22 23 24
obj-$(CONFIG_SYSTEM_BLACKLIST_KEYRING) += blacklist_hashes.o
else
obj-$(CONFIG_SYSTEM_BLACKLIST_KEYRING) += blacklist_nohashes.o
endif
25
targets += blacklist_hash_list
26

27
quiet_cmd_extract_certs  = CERT    $@
28 29
      cmd_extract_certs  = $(obj)/extract-cert $(extract-cert-in) $@
extract-cert-in = $(or $(filter-out $(obj)/extract-cert, $(real-prereqs)),"")
30

31 32
$(obj)/system_certificates.o: $(obj)/x509_certificate_list

33
$(obj)/x509_certificate_list: $(CONFIG_SYSTEM_TRUSTED_KEYS) $(obj)/extract-cert FORCE
34
	$(call if_changed,extract_certs)
35

36
targets += x509_certificate_list
37 38 39 40 41 42 43 44

# If module signing is requested, say by allyesconfig, but a key has not been
# supplied, then one will need to be generated to make sure the build does not
# fail and that the kernel may be used afterwards.
#
# We do it this way rather than having a boolean option for enabling an
# external private key, because 'make randconfig' might enable such a
# boolean option and we unfortunately can't make it depend on !RANDCONFIG.
45
ifeq ($(CONFIG_MODULE_SIG_KEY),certs/signing_key.pem)
46

47
keytype-$(CONFIG_MODULE_SIG_KEY_TYPE_ECDSA) := -newkey ec -pkeyopt ec_paramgen_curve:secp384r1
48

49 50
quiet_cmd_gen_key = GENKEY  $@
      cmd_gen_key = openssl req -new -nodes -utf8 -$(CONFIG_MODULE_SIG_HASH) -days 36500 \
51 52
		-batch -x509 -config $< \
		-outform PEM -out $@ -keyout $@ $(keytype-y) 2>&1
53 54 55

$(obj)/signing_key.pem: $(obj)/x509.genkey FORCE
	$(call if_changed,gen_key)
56

57
targets += signing_key.pem
58

59 60 61 62
quiet_cmd_copy_x509_config = COPY    $@
      cmd_copy_x509_config = cat $(srctree)/$(src)/default_x509.genkey > $@

# You can provide your own config file. If not present, copy the default one.
63
$(obj)/x509.genkey:
64 65
	$(call cmd,copy_x509_config)

66
endif # CONFIG_MODULE_SIG_KEY
67 68 69

$(obj)/system_certificates.o: $(obj)/signing_key.x509

70 71 72 73 74 75 76
PKCS11_URI := $(filter pkcs11:%, $(CONFIG_MODULE_SIG_KEY))
ifdef PKCS11_URI
$(obj)/signing_key.x509: extract-cert-in := $(PKCS11_URI)
endif

$(obj)/signing_key.x509: $(filter-out $(PKCS11_URI),$(CONFIG_MODULE_SIG_KEY)) $(obj)/extract-cert FORCE
	$(call if_changed,extract_certs)
77

M
Masahiro Yamada 已提交
78 79
targets += signing_key.x509

80 81
$(obj)/revocation_certificates.o: $(obj)/x509_revocation_list

82
$(obj)/x509_revocation_list: $(CONFIG_SYSTEM_REVOCATION_KEYS) $(obj)/extract-cert FORCE
83
	$(call if_changed,extract_certs)
M
Masahiro Yamada 已提交
84 85

targets += x509_revocation_list
86 87 88

hostprogs := extract-cert

89 90
HOSTCFLAGS_extract-cert.o = $(shell $(HOSTPKG_CONFIG) --cflags libcrypto 2> /dev/null)
HOSTLDLIBS_extract-cert = $(shell $(HOSTPKG_CONFIG) --libs libcrypto 2> /dev/null || echo -lcrypto)