summaryrefslogtreecommitdiff
path: root/src/tspi/tsp_random.c
blob: 80aff6689ac33289fe40eac8850ab7c8413df8e1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89

/*
 * Licensed Materials - Property of IBM
 *
 * trousers - An open source TCG Software Stack
 *
 * (C) Copyright International Business Machines Corp. 2004, 2007
 *
 */


#include <stdlib.h>
#include <syslog.h>
#include <unistd.h>

#include "trousers/tss.h"
#include "trousers/trousers.h"
#include "trousers_types.h"
#include "spi_utils.h"
#include "tsplog.h"
#include "obj.h"


#ifdef TSS_BUILD_TRANSPORT
TSS_RESULT
Transport_GetRandom(TSS_HCONTEXT tspContext,	/* in */
		    UINT32 bytesRequested,	/* in */
		    BYTE ** randomBytes)	/* out */
{
	TSS_RESULT result;
        UINT32 decLen = 0;
        BYTE *dec = NULL;
        UINT64 offset;
	TCS_HANDLE handlesLen = 0;
        BYTE data[sizeof(UINT32)];

	if ((result = obj_context_transport_init(tspContext)))
		return result;

        LogDebugFn("Executing in a transport session");

        offset = 0;
        Trspi_LoadBlob_UINT32(&offset, bytesRequested, data);

        if ((result = obj_context_transport_execute(tspContext, TPM_ORD_GetRandom, sizeof(data),
                                                    data, NULL, &handlesLen, NULL, NULL, NULL,
						    &decLen, &dec)))
                return result;

	*randomBytes = dec;

        return result;

}

TSS_RESULT
Transport_StirRandom(TSS_HCONTEXT tspContext,	/* in */
		     UINT32 inDataSize,	/* in */
		     BYTE * inData)	/* in */
{
	TSS_RESULT result;
        UINT64 offset;
	UINT32 dataLen;
	TCS_HANDLE handlesLen = 0;
        BYTE *data;

	if ((result = obj_context_transport_init(tspContext)))
		return result;

        LogDebugFn("Executing in a transport session");

	dataLen = sizeof(UINT32) + inDataSize;
	if ((data = malloc(dataLen)) == NULL) {
                LogError("malloc of %u bytes failed", dataLen);
                return TSPERR(TSS_E_OUTOFMEMORY);
	}

        offset = 0;
        Trspi_LoadBlob_UINT32(&offset, inDataSize, data);
        Trspi_LoadBlob(&offset, inDataSize, data, inData);

	result = obj_context_transport_execute(tspContext, TPM_ORD_StirRandom, dataLen, data, NULL,
					       &handlesLen, NULL, NULL, NULL, NULL, NULL);
	free(data);

	return result;
}
#endif