]>
Commit | Line | Data |
---|---|---|
b21373d0 SB |
1 | /* |
2 | * QTest TPM utilities | |
3 | * | |
4 | * Copyright (c) 2018 IBM Corporation | |
5 | * | |
6 | * Authors: | |
7 | * Stefan Berger <[email protected]> | |
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 | ||
b21373d0 SB |
16 | #include "io/channel-socket.h" |
17 | ||
5166c326 EA |
18 | extern uint64_t tpm_tis_base_addr; |
19 | ||
20 | #define TIS_REG(LOCTY, REG) \ | |
21 | (tpm_tis_base_addr + ((LOCTY) << 12) + REG) | |
22 | ||
b21373d0 SB |
23 | typedef void (tx_func)(QTestState *s, |
24 | const unsigned char *req, size_t req_size, | |
25 | unsigned char *rsp, size_t rsp_size); | |
26 | ||
27 | void tpm_util_crb_transfer(QTestState *s, | |
28 | const unsigned char *req, size_t req_size, | |
70663851 SB |
29 | unsigned char *rsp, size_t rsp_size); |
30 | void tpm_util_tis_transfer(QTestState *s, | |
31 | const unsigned char *req, size_t req_size, | |
b21373d0 SB |
32 | unsigned char *rsp, size_t rsp_size); |
33 | ||
34 | void tpm_util_startup(QTestState *s, tx_func *tx); | |
35 | void tpm_util_pcrextend(QTestState *s, tx_func *tx); | |
36 | void tpm_util_pcrread(QTestState *s, tx_func *tx, | |
37 | const unsigned char *exp_resp, size_t exp_resp_size); | |
38 | ||
e2f246a5 MAL |
39 | bool tpm_util_swtpm_has_tpm2(void); |
40 | ||
b21373d0 SB |
41 | gboolean tpm_util_swtpm_start(const char *path, GPid *pid, |
42 | SocketAddress **addr, GError **error); | |
43 | void tpm_util_swtpm_kill(GPid pid); | |
44 | ||
b1e4b7c6 SB |
45 | void tpm_util_migrate(QTestState *who, const char *uri); |
46 | ||
47 | void tpm_util_migration_start_qemu(QTestState **src_qemu, | |
48 | QTestState **dst_qemu, | |
49 | SocketAddress *src_tpm_addr, | |
50 | SocketAddress *dst_tpm_addr, | |
ea71a336 | 51 | const char *miguri, |
551cabdf EA |
52 | const char *ifmodel, |
53 | const char *machine_options); | |
b1e4b7c6 SB |
54 | |
55 | void tpm_util_wait_for_migration_complete(QTestState *who); | |
56 | ||
b21373d0 | 57 | #endif /* TESTS_TPM_UTIL_H */ |