 907b5105f1
			
		
	
	
		907b5105f1
		
	
	
	
	
		
			
			Since commit a2ce7dbd917 ("meson: convert tests/qtest to meson"),
libqtest.h is under libqos/ directory, while libqtest.c is still in
qtest/. Move back to its original location to avoid mixing with libqos/.
Suggested-by: Thomas Huth <thuth@redhat.com>
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
Reviewed-by: Thomas Huth <thuth@redhat.com>
Reviewed-by: Stefan Berger <stefanb@linux.ibm.com>
		
	
			
		
			
				
	
	
		
			57 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			57 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Minimal TPM emulator for TPM test cases
 | |
|  *
 | |
|  * Copyright (c) 2018 Red Hat, Inc.
 | |
|  *
 | |
|  * Authors:
 | |
|  *   Marc-André Lureau <marcandre.lureau@redhat.com>
 | |
|  *
 | |
|  * This work is licensed under the terms of the GNU GPL, version 2 or later.
 | |
|  * See the COPYING file in the top-level directory.
 | |
|  */
 | |
| 
 | |
| #ifndef TESTS_TPM_EMU_H
 | |
| #define TESTS_TPM_EMU_H
 | |
| 
 | |
| #define TPM_RC_FAILURE 0x101
 | |
| #define TPM2_ST_NO_SESSIONS 0x8001
 | |
| 
 | |
| #define TPM_FAIL 9
 | |
| #define TPM_TAG_RSP_COMMAND 0xc4
 | |
| 
 | |
| #include "qemu/sockets.h"
 | |
| #include "io/channel.h"
 | |
| #include "sysemu/tpm.h"
 | |
| #include "libqtest.h"
 | |
| 
 | |
| struct tpm_hdr {
 | |
|     uint16_t tag;
 | |
|     uint32_t len;
 | |
|     uint32_t code; /*ordinal/error */
 | |
|     char buffer[];
 | |
| } QEMU_PACKED;
 | |
| 
 | |
| #ifndef CONFIG_TPM
 | |
| enum TPMVersion {
 | |
|     TPM_VERSION_1_2 = 1,
 | |
|     TPM_VERSION_2_0 = 2,
 | |
| };
 | |
| #endif
 | |
| 
 | |
| typedef struct TPMTestState {
 | |
|     GMutex data_mutex;
 | |
|     GCond data_cond;
 | |
|     bool data_cond_signal;
 | |
|     SocketAddress *addr;
 | |
|     QIOChannel *tpm_ioc;
 | |
|     GThread *emu_tpm_thread;
 | |
|     struct tpm_hdr *tpm_msg;
 | |
|     enum TPMVersion tpm_version;
 | |
| } TPMTestState;
 | |
| 
 | |
| void tpm_emu_test_wait_cond(TPMTestState *s);
 | |
| void *tpm_emu_ctrl_thread(void *data);
 | |
| bool tpm_model_is_available(const char *args, const char *tpm_if);
 | |
| 
 | |
| #endif /* TESTS_TPM_EMU_H */
 |