blob: 5755698ad2a465846f18ed85e10cc69c9822f4a6 [file] [log] [blame]
Stefan Bergerb21373d2018-03-07 14:45:06 -05001/*
2 * QTest TPM utilities
3 *
4 * Copyright (c) 2018 IBM Corporation
5 *
6 * Authors:
7 * Stefan Berger <stefanb@linux.vnet.ibm.com>
8 *
9 * This work is licensed under the terms of the GNU GPL, version 2 or later.
10 * See the COPYING file in the top-level directory.
11 */
12
13#ifndef TESTS_TPM_UTIL_H
14#define TESTS_TPM_UTIL_H
15
Stefan Bergerb21373d2018-03-07 14:45:06 -050016#include "io/channel-socket.h"
17
18typedef void (tx_func)(QTestState *s,
19 const unsigned char *req, size_t req_size,
20 unsigned char *rsp, size_t rsp_size);
21
22void tpm_util_crb_transfer(QTestState *s,
23 const unsigned char *req, size_t req_size,
24 unsigned char *rsp, size_t rsp_size);
Stefan Berger70663852018-05-30 13:44:41 -040025void tpm_util_tis_transfer(QTestState *s,
26 const unsigned char *req, size_t req_size,
27 unsigned char *rsp, size_t rsp_size);
Stefan Bergerb21373d2018-03-07 14:45:06 -050028
29void tpm_util_startup(QTestState *s, tx_func *tx);
30void tpm_util_pcrextend(QTestState *s, tx_func *tx);
31void tpm_util_pcrread(QTestState *s, tx_func *tx,
32 const unsigned char *exp_resp, size_t exp_resp_size);
33
Marc-André Lureaue2f246a2018-10-03 17:21:29 +040034bool tpm_util_swtpm_has_tpm2(void);
35
Stefan Bergerb21373d2018-03-07 14:45:06 -050036gboolean tpm_util_swtpm_start(const char *path, GPid *pid,
37 SocketAddress **addr, GError **error);
38void tpm_util_swtpm_kill(GPid pid);
39
Stefan Bergerb1e4b7c2018-05-30 12:12:50 -040040void tpm_util_migrate(QTestState *who, const char *uri);
41
42void tpm_util_migration_start_qemu(QTestState **src_qemu,
43 QTestState **dst_qemu,
44 SocketAddress *src_tpm_addr,
45 SocketAddress *dst_tpm_addr,
Stefan Bergerea71a332018-05-30 14:31:12 -040046 const char *miguri,
47 const char *ifmodel);
Stefan Bergerb1e4b7c2018-05-30 12:12:50 -040048
49void tpm_util_wait_for_migration_complete(QTestState *who);
50
Stefan Bergerb21373d2018-03-07 14:45:06 -050051#endif /* TESTS_TPM_UTIL_H */