1# SPDX-License-Identifier: GPL-2.0
2#
3# Makefile for asymmetric cryptographic keys
4#
5
6obj-$(CONFIG_ASYMMETRIC_KEY_TYPE) += asymmetric_keys.o
7
8asymmetric_keys-y := \
9	asymmetric_type.o \
10	restrict.o \
11	signature.o
12
13obj-$(CONFIG_ASYMMETRIC_PUBLIC_KEY_SUBTYPE) += public_key.o
14
15#
16# X.509 Certificate handling
17#
18obj-$(CONFIG_X509_CERTIFICATE_PARSER) += x509_key_parser.o
19x509_key_parser-y := \
20	x509.asn1.o \
21	x509_akid.asn1.o \
22	x509_cert_parser.o \
23	x509_public_key.o
24
25$(obj)/x509_cert_parser.o: \
26	$(obj)/x509.asn1.h \
27	$(obj)/x509_akid.asn1.h
28
29$(obj)/x509.asn1.o: $(obj)/x509.asn1.c $(obj)/x509.asn1.h
30$(obj)/x509_akid.asn1.o: $(obj)/x509_akid.asn1.c $(obj)/x509_akid.asn1.h
31
32#
33# PKCS#8 private key handling
34#
35obj-$(CONFIG_PKCS8_PRIVATE_KEY_PARSER) += pkcs8_key_parser.o
36pkcs8_key_parser-y := \
37	pkcs8.asn1.o \
38	pkcs8_parser.o
39
40$(obj)/pkcs8_parser.o: $(obj)/pkcs8.asn1.h
41$(obj)/pkcs8-asn1.o: $(obj)/pkcs8.asn1.c $(obj)/pkcs8.asn1.h
42
43clean-files	+= pkcs8.asn1.c pkcs8.asn1.h
44
45#
46# PKCS#7 message handling
47#
48obj-$(CONFIG_PKCS7_MESSAGE_PARSER) += pkcs7_message.o
49pkcs7_message-y := \
50	pkcs7.asn1.o \
51	pkcs7_parser.o \
52	pkcs7_trust.o \
53	pkcs7_verify.o
54
55$(obj)/pkcs7_parser.o: $(obj)/pkcs7.asn1.h
56$(obj)/pkcs7.asn1.o: $(obj)/pkcs7.asn1.c $(obj)/pkcs7.asn1.h
57
58#
59# PKCS#7 parser testing key
60#
61obj-$(CONFIG_PKCS7_TEST_KEY) += pkcs7_test_key.o
62pkcs7_test_key-y := \
63	pkcs7_key_type.o
64
65#
66# Signed PE binary-wrapped key handling
67#
68obj-$(CONFIG_SIGNED_PE_FILE_VERIFICATION) += verify_signed_pefile.o
69
70verify_signed_pefile-y := \
71	verify_pefile.o \
72	mscode_parser.o \
73	mscode.asn1.o
74
75$(obj)/mscode_parser.o: $(obj)/mscode.asn1.h $(obj)/mscode.asn1.h
76$(obj)/mscode.asn1.o: $(obj)/mscode.asn1.c $(obj)/mscode.asn1.h
77