1b21373d0SStefan Berger /* 2b21373d0SStefan Berger * QTest TPM utilities 3b21373d0SStefan Berger * 4b21373d0SStefan Berger * Copyright (c) 2018 IBM Corporation 5b21373d0SStefan Berger * 6b21373d0SStefan Berger * Authors: 7b21373d0SStefan Berger * Stefan Berger <stefanb@linux.vnet.ibm.com> 8b21373d0SStefan Berger * 9b21373d0SStefan Berger * This work is licensed under the terms of the GNU GPL, version 2 or later. 10b21373d0SStefan Berger * See the COPYING file in the top-level directory. 11b21373d0SStefan Berger */ 12b21373d0SStefan Berger 13b21373d0SStefan Berger #ifndef TESTS_TPM_UTIL_H 14b21373d0SStefan Berger #define TESTS_TPM_UTIL_H 15b21373d0SStefan Berger 16b21373d0SStefan Berger #include "io/channel-socket.h" 17b21373d0SStefan Berger 18b21373d0SStefan Berger typedef void (tx_func)(QTestState *s, 19b21373d0SStefan Berger const unsigned char *req, size_t req_size, 20b21373d0SStefan Berger unsigned char *rsp, size_t rsp_size); 21b21373d0SStefan Berger 22b21373d0SStefan Berger void tpm_util_crb_transfer(QTestState *s, 23b21373d0SStefan Berger const unsigned char *req, size_t req_size, 24b21373d0SStefan Berger unsigned char *rsp, size_t rsp_size); 2570663851SStefan Berger void tpm_util_tis_transfer(QTestState *s, 2670663851SStefan Berger const unsigned char *req, size_t req_size, 2770663851SStefan Berger unsigned char *rsp, size_t rsp_size); 28b21373d0SStefan Berger 29b21373d0SStefan Berger void tpm_util_startup(QTestState *s, tx_func *tx); 30b21373d0SStefan Berger void tpm_util_pcrextend(QTestState *s, tx_func *tx); 31b21373d0SStefan Berger void tpm_util_pcrread(QTestState *s, tx_func *tx, 32b21373d0SStefan Berger const unsigned char *exp_resp, size_t exp_resp_size); 33b21373d0SStefan Berger 34e2f246a5SMarc-André Lureau bool tpm_util_swtpm_has_tpm2(void); 35e2f246a5SMarc-André Lureau 36b21373d0SStefan Berger gboolean tpm_util_swtpm_start(const char *path, GPid *pid, 37b21373d0SStefan Berger SocketAddress **addr, GError **error); 38b21373d0SStefan Berger void tpm_util_swtpm_kill(GPid pid); 39b21373d0SStefan Berger 40b1e4b7c6SStefan Berger void tpm_util_migrate(QTestState *who, const char *uri); 41b1e4b7c6SStefan Berger 42b1e4b7c6SStefan Berger void tpm_util_migration_start_qemu(QTestState **src_qemu, 43b1e4b7c6SStefan Berger QTestState **dst_qemu, 44b1e4b7c6SStefan Berger SocketAddress *src_tpm_addr, 45b1e4b7c6SStefan Berger SocketAddress *dst_tpm_addr, 46ea71a336SStefan Berger const char *miguri, 47*551cabdfSEric Auger const char *ifmodel, 48*551cabdfSEric Auger const char *machine_options); 49b1e4b7c6SStefan Berger 50b1e4b7c6SStefan Berger void tpm_util_wait_for_migration_complete(QTestState *who); 51b1e4b7c6SStefan Berger 52b21373d0SStefan Berger #endif /* TESTS_TPM_UTIL_H */ 53