| 
									
										
										
										
											2018-02-15 08:53:56 -05:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * 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
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-09 14:54:05 +02:00
										 |  |  | #include "qemu/sockets.h"
 | 
					
						
							|  |  |  | #include "io/channel.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-15 08:53:56 -05:00
										 |  |  | struct tpm_hdr { | 
					
						
							|  |  |  |     uint16_t tag; | 
					
						
							|  |  |  |     uint32_t len; | 
					
						
							|  |  |  |     uint32_t code; /*ordinal/error */ | 
					
						
							|  |  |  |     char buffer[]; | 
					
						
							|  |  |  | } QEMU_PACKED; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct TestState { | 
					
						
							| 
									
										
										
										
											2018-05-04 15:34:46 +01:00
										 |  |  |     GMutex data_mutex; | 
					
						
							|  |  |  |     GCond data_cond; | 
					
						
							| 
									
										
										
										
											2018-09-07 11:47:06 -04:00
										 |  |  |     bool data_cond_signal; | 
					
						
							| 
									
										
										
										
											2018-02-15 08:53:56 -05:00
										 |  |  |     SocketAddress *addr; | 
					
						
							|  |  |  |     QIOChannel *tpm_ioc; | 
					
						
							|  |  |  |     GThread *emu_tpm_thread; | 
					
						
							|  |  |  |     struct tpm_hdr *tpm_msg; | 
					
						
							|  |  |  | } TestState; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void tpm_emu_test_wait_cond(TestState *s); | 
					
						
							|  |  |  | void *tpm_emu_ctrl_thread(void *data); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-15 15:51:23 +01:00
										 |  |  | #endif /* TESTS_TPM_EMU_H */
 |