summaryrefslogtreecommitdiffstats
path: root/man/man3/TPMLIB_DecodeBlob.pod
blob: e6004458cbad9c4ecb788a108c4fb505a965b82d (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
=head1 NAME

TPMLIB_DecodeBlob    - Decode a base64-encode TPM blob
 
=head1 SYNOPSIS

B<#include <libtpms/tpm_types.h>>

B<#include <libtpms/tpm_library.h>>

B<TPM_RESULT TPMLIB_DecodeBlob(const char> *I<buffer>B<,
                             enum TPMLIB_BlobType> I<type>B<,
                             unsigned char> **I<result>B<
                             size_t> *I<result_len>B<);>

=head1 DESCRIPTION

The B<TPMLIB_DecodeBlob()> function is used to decode a base64-encoded
TPM state blob. The caller must pass what type of blob is expected to be
decoded and following that the function will look for the start and
end markers of the data.

The following types of blobs are supported along with their start and 
end markers:

=over 4

=item B<BLOB_TYPE_INITSTATE>

'-----BEGIN INITSTATE-----' marks the beginning of the base64-encoded blob.

'-----END INITSTATE-----' marks the end of the base64-encoded blob.

=back

This function is useful when passing state to the TPM inside the
callback that is invoked to get the TPM's state blob.
See I<TPMLIB_RegisterCallbacks>(3).

=head1 ERRORS

=over 4

=item B<TPM_SUCCESS>

The function completed successfully.

=item B<TPM_SIZE>

The size of a requested buffer exceeds the limit or the
system is out of memory.

=item B<TPM_FAIL>

An error occurred while attempting to decode the blob.

=back

For a complete list of TPM error codes please consult the include file
B<libtpms/tpm_error.h>

=head1 SEE ALSO

B<TPMLIB_MainInit>(3), B<TPMLIB_RegisterCallbacks>(3)

=cut