1*758e9fbaSOystein Eftevaag /* SPDX-License-Identifier: BSD-2-Clause */
2*758e9fbaSOystein Eftevaag /***********************************************************************
3*758e9fbaSOystein Eftevaag * Copyright (c) 2017-2018, Intel Corporation
4*758e9fbaSOystein Eftevaag *
5*758e9fbaSOystein Eftevaag * All rights reserved.
6*758e9fbaSOystein Eftevaag ***********************************************************************/
7*758e9fbaSOystein Eftevaag #ifdef HAVE_CONFIG_H
8*758e9fbaSOystein Eftevaag #include <config.h>
9*758e9fbaSOystein Eftevaag #endif
10*758e9fbaSOystein Eftevaag
11*758e9fbaSOystein Eftevaag #include "tss2_tpm2_types.h"
12*758e9fbaSOystein Eftevaag #include "sapi-util.h"
13*758e9fbaSOystein Eftevaag #include "session-util.h"
14*758e9fbaSOystein Eftevaag
15*758e9fbaSOystein Eftevaag static ENTITY *entities = NULL;
16*758e9fbaSOystein Eftevaag
17*758e9fbaSOystein Eftevaag int
AddEntity(TPM2_HANDLE handle,TPM2B_AUTH * auth)18*758e9fbaSOystein Eftevaag AddEntity(TPM2_HANDLE handle, TPM2B_AUTH *auth)
19*758e9fbaSOystein Eftevaag {
20*758e9fbaSOystein Eftevaag ENTITY *e;
21*758e9fbaSOystein Eftevaag
22*758e9fbaSOystein Eftevaag HASH_FIND_INT(entities, &handle, e);
23*758e9fbaSOystein Eftevaag
24*758e9fbaSOystein Eftevaag if (!e) {
25*758e9fbaSOystein Eftevaag e = calloc(1, sizeof(*e));
26*758e9fbaSOystein Eftevaag if (!e)
27*758e9fbaSOystein Eftevaag return -1;
28*758e9fbaSOystein Eftevaag
29*758e9fbaSOystein Eftevaag e->entityHandle = handle;
30*758e9fbaSOystein Eftevaag HASH_ADD_INT(entities, entityHandle, e);
31*758e9fbaSOystein Eftevaag }
32*758e9fbaSOystein Eftevaag CopySizedByteBuffer((TPM2B *)&e->entityAuth, (TPM2B *)auth);
33*758e9fbaSOystein Eftevaag return 0;
34*758e9fbaSOystein Eftevaag }
35*758e9fbaSOystein Eftevaag
36*758e9fbaSOystein Eftevaag void
DeleteEntity(TPM2_HANDLE handle)37*758e9fbaSOystein Eftevaag DeleteEntity(TPM2_HANDLE handle)
38*758e9fbaSOystein Eftevaag {
39*758e9fbaSOystein Eftevaag ENTITY *e;
40*758e9fbaSOystein Eftevaag
41*758e9fbaSOystein Eftevaag HASH_FIND_INT(entities, &handle, e);
42*758e9fbaSOystein Eftevaag if (!e)
43*758e9fbaSOystein Eftevaag return;
44*758e9fbaSOystein Eftevaag
45*758e9fbaSOystein Eftevaag HASH_DEL(entities, e);
46*758e9fbaSOystein Eftevaag free(e);
47*758e9fbaSOystein Eftevaag }
48*758e9fbaSOystein Eftevaag
49*758e9fbaSOystein Eftevaag int
GetEntityAuth(TPM2_HANDLE handle,TPM2B_AUTH * auth)50*758e9fbaSOystein Eftevaag GetEntityAuth(TPM2_HANDLE handle, TPM2B_AUTH *auth)
51*758e9fbaSOystein Eftevaag {
52*758e9fbaSOystein Eftevaag ENTITY *e;
53*758e9fbaSOystein Eftevaag
54*758e9fbaSOystein Eftevaag HASH_FIND_INT(entities, &handle, e);
55*758e9fbaSOystein Eftevaag if (!e)
56*758e9fbaSOystein Eftevaag return -1;
57*758e9fbaSOystein Eftevaag
58*758e9fbaSOystein Eftevaag CopySizedByteBuffer((TPM2B *)auth, (TPM2B *)&e->entityAuth);
59*758e9fbaSOystein Eftevaag return 0;
60*758e9fbaSOystein Eftevaag }
61*758e9fbaSOystein Eftevaag
62*758e9fbaSOystein Eftevaag ENTITY *
GetEntity(TPM2_HANDLE handle)63*758e9fbaSOystein Eftevaag GetEntity(TPM2_HANDLE handle)
64*758e9fbaSOystein Eftevaag {
65*758e9fbaSOystein Eftevaag ENTITY *e;
66*758e9fbaSOystein Eftevaag
67*758e9fbaSOystein Eftevaag HASH_FIND_INT(entities, &handle, e);
68*758e9fbaSOystein Eftevaag return e;
69*758e9fbaSOystein Eftevaag }
70