4 # For the license, see the LICENSE file in the root directory.
7 lib_LTLIBRARIES=libtpms.la
9 common_CFLAGS = -include tpm_library_conf.h \
10 -I$(top_srcdir)/include/libtpms \
17 noinst_LTLIBRARIES = libtpms_tpm12.la
19 libtpms_la_LIBADD = libtpms_tpm12.la
21 libtpms_tpm12_la_LIBADD =
23 libtpms_tpm12_la_CFLAGS = $(common_CFLAGS)
26 libtpms_tpm12_la_CFLAGS += -DTPM_V12
27 # build a PC Client TPM
28 libtpms_tpm12_la_CFLAGS += -DTPM_PCCLIENT
29 # upon initialization have the TPM load the volatile state
30 libtpms_tpm12_la_CFLAGS += -DTPM_VOLATILE_LOAD
31 # build the TPM enabled and activated
32 libtpms_tpm12_la_CFLAGS += -DTPM_ENABLE_ACTIVATE
33 # build with AES support for symmetric crypto
34 libtpms_tpm12_la_CFLAGS += -DTPM_AES
35 # build with libtpms callback support
36 libtpms_tpm12_la_CFLAGS += -DTPM_LIBTPMS_CALLBACKS
37 # let the default NVRAM write to disk
38 libtpms_tpm12_la_CFLAGS += -DTPM_NV_DISK
39 # build a POSIX type of TPM
40 libtpms_tpm12_la_CFLAGS += -DTPM_POSIX
42 libtpms_tpm12_la_CFLAGS += @DEBUG_DEFINES@
46 libtpms_tpm12_la_SOURCES = \
54 tpm12/tpm_delegate.c \
58 tpm12/tpm_identity.c \
60 tpm12/tpm_libtpms_io.c \
65 tpm12/tpm_migration.c \
71 tpm12/tpm_permanent.c \
72 tpm12/tpm_platform.c \
76 tpm12/tpm_sizedbuffer.c \
82 tpm12/tpm_transport.c \
84 tpm12/tpm_svnrevision.c \
85 tpm_tpm12_interface.c \
92 tpm12/tpm_commands.h \
93 tpm12/tpm_constants.h \
99 tpm12/tpm_delegate.h \
102 tpm12/tpm_identity.h \
107 tpm_library_intern.h \
110 tpm12/tpm_migration.h \
113 tpm12/tpm_nvram_const.h \
117 tpm12/tpm_permanent.h \
118 tpm12/tpm_platform.h \
119 tpm12/tpm_process.h \
121 tpm12/tpm_session.h \
122 tpm12/tpm_sizedbuffer.h \
123 tpm12/tpm_startup.h \
124 tpm12/tpm_storage.h \
126 tpm12/tpm_structures.h \
127 tpm12/tpm_svnrevision.h \
130 tpm12/tpm_transport.h \
134 if LIBTPMS_USE_FREEBL
136 libtpms_tpm12_la_SOURCES += tpm12/tpm_crypto_freebl.c
137 libtpms_tpm12_la_LIBADD += -lfreebl -lgmp -lnspr4 -lnssutil3 -lnss3
139 #work-around broken freebl includes
140 libtpms_tpm12_la_CFLAGS += $(shell [ ! -r /usr/include/nss3/alghmac.h ] && \
143 # tpm12/tpm_crypto_freebl.c: work around #include "blapi.h" : should be <nss3/blapi.h>
144 libtpms_tpm12_la_CFLAGS += $(shell nss-config --cflags)
145 #including nss3/blapi.h requires a look into nspr4 dir
146 libtpms_tpm12_la_CFLAGS += $(shell nspr-config --cflags)
150 if LIBTPMS_USE_OPENSSL
152 libtpms_tpm12_la_SOURCES += tpm12/tpm_crypto.c
153 libtpms_tpm12_la_LIBADD += -lcrypto
155 endif # LIBTPMS_USE_OPENSSL
157 endif # LIBTPMS_USE_FREEBL
164 noinst_LTLIBRARIES += libtpms_tpm2.la
166 libtpms_la_LIBADD += libtpms_tpm2.la
168 libtpms_tpm2_la_LIBADD =
170 libtpms_tpm2_la_LDFLAGS = -Wl,--version-script=./libtpms.syms \
171 -version-info $(LIBTPMS_VERSION_INFO) \
174 libtpms_tpm2_la_CFLAGS = $(common_CFLAGS) \
177 libtpms_tpm2_la_CFLAGS += -D_POSIX_
178 libtpms_tpm2_la_CFLAGS += -DTPM_POSIX
179 # build with libtpms callback support
180 libtpms_tpm2_la_CFLAGS += -DTPM_LIBTPMS_CALLBACKS
182 libtpms_tpm2_la_SOURCES = \
183 tpm2/AlgorithmCap.c \
184 tpm2/AlgorithmTests.c \
185 tpm2/AsymmetricCommands.c \
186 tpm2/AttestationCommands.c \
188 tpm2/AuditCommands.c \
195 tpm2/CapabilityCommands.c \
197 tpm2/ClockCommands.c \
198 tpm2/CommandAudit.c \
199 tpm2/CommandCodeAttributes.c \
200 tpm2/CommandDispatcher.c \
201 tpm2/ContextCommands.c \
203 tpm2/CryptSelfTest.c \
206 tpm2/DictionaryCommands.c \
207 tpm2/DuplicationCommands.c \
209 tpm2/EncryptDecrypt_spt.c \
212 tpm2/EphemeralCommands.c \
216 tpm2/HashCommands.c \
218 tpm2/HierarchyCommands.c \
219 tpm2/IntegrityCommands.c \
222 tpm2/LocalityPlat.c \
223 tpm2/ManagementCommands.c \
226 tpm2/MathOnByteBuffers.c \
234 tpm2/ObjectCommands.c \
237 tpm2/PlatformData.c \
245 tpm2/RandomCommands.c \
247 tpm2/ResponseCodeProcessing.c \
250 tpm2/SessionCommands.c \
251 tpm2/SessionProcess.c \
252 tpm2/SigningCommands.c \
253 tpm2/StartupCommands.c \
254 tpm2/SymmetricCommands.c \
255 tpm2/TestingCommands.c \
258 tpm2/TpmSizeChecks.c \
263 tpm2/Vendor_TCG_Test.c \
264 tpm_tpm2_interface.c \
268 tpm2/StateMarshal.c \
272 tpm2/crypto/CryptDes_fp.h \
273 tpm2/crypto/CryptEcc.h \
274 tpm2/crypto/CryptEccKeyExchange_fp.h \
275 tpm2/crypto/CryptEccMain_fp.h \
276 tpm2/crypto/CryptEccSignature_fp.h \
277 tpm2/crypto/CryptHashData.h \
278 tpm2/crypto/CryptHash_fp.h \
279 tpm2/crypto/CryptHash.h \
280 tpm2/crypto/CryptPrime_fp.h \
281 tpm2/crypto/CryptPrimeSieve_fp.h \
282 tpm2/crypto/CryptRand_fp.h \
283 tpm2/crypto/CryptRand.h \
284 tpm2/crypto/CryptRsa_fp.h \
285 tpm2/crypto/CryptRsa.h \
286 tpm2/crypto/CryptSelfTest_fp.h \
287 tpm2/crypto/CryptSym_fp.h \
288 tpm2/crypto/CryptTest.h \
289 tpm2/crypto/CryptUtil_fp.h \
290 tpm2/ActivateCredential_fp.h \
291 tpm2/AlgorithmCap_fp.h \
292 tpm2/AlgorithmTests_fp.h \
293 tpm2/Attest_spt_fp.h \
296 tpm2/Capabilities.h \
297 tpm2/CertifyCreation_fp.h \
299 tpm2/ChangeEPS_fp.h \
300 tpm2/ChangePPS_fp.h \
301 tpm2/ClearControl_fp.h \
303 tpm2/ClockRateAdjust_fp.h \
305 tpm2/CommandAttributeData.h \
306 tpm2/CommandAttributes.h \
307 tpm2/CommandAudit_fp.h \
308 tpm2/CommandCodeAttributes_fp.h \
309 tpm2/CommandDispatchData.h \
310 tpm2/CommandDispatcher_fp.h \
312 tpm2/CompilerDependencies.h \
313 tpm2/ContextLoad_fp.h \
314 tpm2/ContextSave_fp.h \
315 tpm2/Context_spt_fp.h \
317 tpm2/CreateLoaded_fp.h \
318 tpm2/CreatePrimary_fp.h \
319 tpm2/CryptSelfTest_fp.h \
320 tpm2/CryptUtil_fp.h \
322 tpm2/DictionaryAttackLockReset_fp.h \
323 tpm2/DictionaryAttackParameters_fp.h \
324 tpm2/Duplicate_fp.h \
326 tpm2/ECC_Parameters_fp.h \
327 tpm2/ECDH_KeyGen_fp.h \
328 tpm2/ECDH_ZGen_fp.h \
329 tpm2/EC_Ephemeral_fp.h \
330 tpm2/EncryptDecrypt2_fp.h \
331 tpm2/EncryptDecrypt_fp.h \
332 tpm2/EncryptDecrypt_spt.h \
333 tpm2/EncryptDecrypt_spt_fp.h \
335 tpm2/EventSequenceComplete_fp.h \
336 tpm2/EvictControl_fp.h \
337 tpm2/ExecCommand_fp.h \
338 tpm2/FlushContext_fp.h \
339 tpm2/GetCapability_fp.h \
340 tpm2/GetCommandAuditDigest_fp.h \
341 tpm2/GetRandom_fp.h \
342 tpm2/GetSessionAuditDigest_fp.h \
343 tpm2/GetTestResult_fp.h \
349 tpm2/HashSequenceStart_fp.h \
350 tpm2/HashTestData.h \
351 tpm2/HierarchyChangeAuth_fp.h \
352 tpm2/HierarchyControl_fp.h \
353 tpm2/Hierarchy_fp.h \
355 tpm2/HMAC_Start_fp.h \
356 tpm2/Implementation.h \
358 tpm2/IncrementalSelfTest_fp.h \
359 tpm2/InternalRoutines.h \
360 tpm2/IoBuffers_fp.h \
361 tpm2/LoadExternal_fp.h \
364 tpm2/MakeCredential_fp.h \
365 tpm2/Manufacture_fp.h \
367 tpm2/MathOnByteBuffers_fp.h \
369 tpm2/NV_Certify_fp.h \
370 tpm2/NV_ChangeAuth_fp.h \
371 tpm2/NV_DefineSpace_fp.h \
372 tpm2/NVDynamic_fp.h \
373 tpm2/NV_Extend_fp.h \
374 tpm2/NV_GlobalWriteLock_fp.h \
376 tpm2/NV_Increment_fp.h \
378 tpm2/NV_ReadLock_fp.h \
379 tpm2/NV_ReadPublic_fp.h \
380 tpm2/NVReserved_fp.h \
381 tpm2/NV_SetBits_fp.h \
383 tpm2/NV_UndefineSpace_fp.h \
384 tpm2/NV_UndefineSpaceSpecial_fp.h \
386 tpm2/NV_WriteLock_fp.h \
387 tpm2/ObjectChangeAuth_fp.h \
389 tpm2/Object_spt_fp.h \
390 tpm2/PCR_Allocate_fp.h \
391 tpm2/PCR_Event_fp.h \
392 tpm2/PCR_Extend_fp.h \
395 tpm2/PCR_Reset_fp.h \
396 tpm2/PCR_SetAuthPolicy_fp.h \
397 tpm2/PCR_SetAuthValue_fp.h \
398 tpm2/PlatformData.h \
400 tpm2/PolicyAuthorize_fp.h \
401 tpm2/PolicyAuthorizeNV_fp.h \
402 tpm2/PolicyAuthValue_fp.h \
403 tpm2/PolicyCommandCode_fp.h \
404 tpm2/PolicyCounterTimer_fp.h \
405 tpm2/PolicyCpHash_fp.h \
406 tpm2/PolicyDuplicationSelect_fp.h \
407 tpm2/PolicyGetDigest_fp.h \
408 tpm2/PolicyLocality_fp.h \
409 tpm2/PolicyNameHash_fp.h \
411 tpm2/PolicyNvWritten_fp.h \
413 tpm2/PolicyPassword_fp.h \
414 tpm2/PolicyPCR_fp.h \
415 tpm2/PolicyPhysicalPresence_fp.h \
416 tpm2/PolicyRestart_fp.h \
417 tpm2/PolicySecret_fp.h \
418 tpm2/PolicySigned_fp.h \
419 tpm2/Policy_spt_fp.h \
420 tpm2/PolicyTemplate_fp.h \
421 tpm2/PolicyTicket_fp.h \
423 tpm2/PP_Commands_fp.h \
425 tpm2/PRNG_TestVectors.h \
426 tpm2/PropertyCap_fp.h \
428 tpm2/ReadClock_fp.h \
429 tpm2/ReadPublic_fp.h \
430 tpm2/ResponseCodeProcessing_fp.h \
434 tpm2/RSA_Decrypt_fp.h \
435 tpm2/RSA_Encrypt_fp.h \
438 tpm2/SequenceComplete_fp.h \
439 tpm2/SequenceUpdate_fp.h \
441 tpm2/SessionProcess_fp.h \
442 tpm2/SetAlgorithmSet_fp.h \
443 tpm2/SetCommandCodeAuditStatus_fp.h \
444 tpm2/SetPrimaryPolicy_fp.h \
447 tpm2/Simulator_fp.h \
448 tpm2/StartAuthSession_fp.h \
450 tpm2/StirRandom_fp.h \
451 tpm2/SupportLibraryFunctionPrototypes_fp.h \
452 tpm2/SymmetricTest.h \
453 tpm2/SymmetricTestData.h \
455 tpm2/TcpServerPosix_fp.h \
456 tpm2/TestParms_fp.h \
460 tpm2/TpmBuildSwitches.h \
464 tpm2/_TPM_Hash_Data_fp.h \
465 tpm2/_TPM_Hash_End_fp.h \
466 tpm2/_TPM_Hash_Start_fp.h \
467 tpm2/_TPM_Init_fp.h \
468 tpm2/TpmSizeChecks_fp.h \
469 tpm2/TpmTcpProtocol.h \
471 tpm2/Unmarshal_fp.h \
473 tpm2/VendorString.h \
474 tpm2/Vendor_TCG_Test_fp.h \
475 tpm2/VerifySignature_fp.h \
476 tpm2/ZGen_2Phase_fp.h \
479 tpm2/StateMarshal.h \
482 if LIBTPMS_USE_OPENSSL
484 libtpms_tpm2_la_SOURCES += \
485 tpm2/crypto/openssl/CryptDes.c \
486 tpm2/crypto/openssl/CryptEccKeyExchange.c \
487 tpm2/crypto/openssl/CryptEccMain.c \
488 tpm2/crypto/openssl/CryptEccSignature.c \
489 tpm2/crypto/openssl/CryptHash.c \
490 tpm2/crypto/openssl/CryptHashData.c \
491 tpm2/crypto/openssl/CryptPrime.c \
492 tpm2/crypto/openssl/CryptPrimeSieve.c \
493 tpm2/crypto/openssl/CryptRand.c \
494 tpm2/crypto/openssl/CryptRsa.c \
495 tpm2/crypto/openssl/CryptSym.c \
496 tpm2/crypto/openssl/TpmToOsslDesSupport.c \
497 tpm2/crypto/openssl/TpmToOsslMath.c \
498 tpm2/crypto/openssl/TpmToOsslSupport.c
501 tpm2/crypto/openssl/BnConvert_fp.h \
502 tpm2/crypto/openssl/BnMath_fp.h \
503 tpm2/crypto/openssl/BnMemory_fp.h \
504 tpm2/crypto/openssl/BnValues.h \
505 tpm2/crypto/openssl/LibSupport.h \
506 tpm2/crypto/openssl/TpmToOsslDesSupport_fp.h \
507 tpm2/crypto/openssl/TpmToOsslHash.h \
508 tpm2/crypto/openssl/TpmToOsslMath_fp.h \
509 tpm2/crypto/openssl/TpmToOsslMath.h \
510 tpm2/crypto/openssl/TpmToOsslSupport_fp.h \
511 tpm2/crypto/openssl/TpmToOsslSym.h
513 libtpms_tpm2_la_CFLAGS += \
516 -I tpm2/crypto/openssl
518 endif # LIBTPMS_USE_OPENSSL
520 # some of the original TPM2 files have been modified; in case of an update
521 # we do not want to loose these modifications
523 n=`grep "TPM_LIBTPMS_CALLBACK" $(libtpms_tpm2_la_SOURCES) | wc -l`; \
525 if test $$n -ne $$exp; then \
526 echo "TPM_LIBTPMS_CALLBACK occurrence has changed to $$n from $$exp"; \
529 n=`grep TPM_BUFFER_MAX tpm2/Implementation.h | grep -E "^#define" | wc -l`; \
531 if test $$n -ne $$exp; then \
532 echo "Lost patches to tpm2/Implementation.h ?"; \
538 @n=`grep -i "nuvo" $(libtpms_tpm2_la_SOURCES) | wc -l`; \
539 if test $$n -ne 0; then \
540 echo "Filter sources!"; \
547 tpm2_nvram_offsetchecks
549 TESTS = tpm2_nvram_offsetchecks
551 tpm2_nvram_offsetchecks_SOURCES = \
552 tests/tpm2_nvram_offsetchecks.c
554 tpm2_nvram_offsetchecks_CFLAGS = \
555 $(libtpms_tpm2_la_CFLAGS)
563 libtpms_la_SOURCES = \
566 libtpms_la_CFLAGS = $(common_CFLAGS)
568 libtpms_la_LDFLAGS = -Wl,--version-script=$(srcdir)/libtpms.syms \
569 -version-info $(LIBTPMS_VERSION_INFO) \
573 LDFLAGS_ARCH = $(findstring -m32, $(CFLAGS))
574 LDFLAGS_ARCH += $(findstring -m64, $(CFLAGS))
575 LDFLAGS_ARCH += $(findstring -m32, $(LDFLAGS))
576 LDFLAGS_ARCH += $(findstring -m64, $(LDFLAGS))
579 @case $(host_os) in \
580 openbsd*) ADDLIBS="-lc" ;; \
583 ($(CC) $(LDFLAGS_ARCH) -nostdlib -L./.libs -ltpms $$ADDLIBS 2>/dev/null || \
584 (echo "There are undefined symbols in libtpms ($(LDFLAGS_ARCH))";\
585 $(CC) $(LDFLAGS_ARCH) -nostdlib -L./.libs -ltpms $$ADDLIBS 2>&1 | grep libtpms))
586 @case $(host_os) in \
587 openbsd*) ADDLIBS="-lc" ;; \
590 $(CC) $(LDFLAGS_ARCH) -nostdlib -L./.libs -ltpms $$ADDLIBS 2>/dev/null
593 tpm12/tpm_crypto_freebl.c \