5020ce6d2aa7c51ca7d5dc83da1f4fdf7b7ec27c
[aaf/sshsm.git] / TPM2-Plugin / src / main.c
1 //**********************************************************************;
2 // Copyright (c) 2017, Intel Corporation
3 // All rights reserved.
4 //
5 // Redistribution and use in source and binary forms, with or without
6 // modification, are permitted provided that the following conditions are met:
7 //
8 // 1. Redistributions of source code must retain the above copyright notice,
9 // this list of conditions and the following disclaimer.
10 //
11 // 2. Redistributions in binary form must reproduce the above copyright notice,
12 // this list of conditions and the following disclaimer in the documentation
13 // and/or other materials provided with the distribution.
14 //
15 // 3. Neither the name of Intel Corporation nor the names of its contributors
16 // may be used to endorse or promote products derived from this software without
17 // specific prior written permission.
18 //
19 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
20 // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22 // ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
23 // LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 // CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 // SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 // INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 // CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 // ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
29 // THE POSSIBILITY OF SUCH DAMAGE.
30 //**********************************************************************;
31
32 #include <stdio.h>
33 #include "tpm2_plugin_api.h"
34 //#include "plugin_register.h"
35 //#include "hwpluginif.h"
36
37 void main(void)
38 {
39     unsigned long mechanism =1;
40     void *param = NULL;
41     size_t len = 100;
42     void *keyHandle_sign = NULL;
43
44     unsigned char *msg;
45     int msg_len;
46     unsigned char *sig;
47     int *sig_len;
48
49     SSHSM_HW_PLUGIN_ACTIVATE_LOAD_IN_INFO_t *activate_in_info;
50     activate_in_info = malloc(sizeof(SSHSM_HW_PLUGIN_ACTIVATE_LOAD_IN_INFO_t));
51     SSHSM_HW_PLUGIN_ACTIVATE_LOAD_IN_INFO_t *loadkey_in_info;
52     void **keyHandle;
53
54     printf("---------------------------------------------\n");
55     printf("Test app calling tpm2_plugin APIs\n");
56
57     printf("---------------------------------------------\n");
58     tpm2_plugin_init();
59
60     printf("---------------------------------------------\n");
61     tpm2_plugin_uninit();
62
63     printf("---------------------------------------------\n");
64     tpm2_plugin_activate(activate_in_info);
65
66     printf("---------------------------------------------\n");
67     tpm2_plugin_load_key(loadkey_in_info, keyHandle );
68
69     printf("---------------------------------------------\n");
70     tpm2_plugin_rsa_sign_init(keyHandle_sign, mechanism, param, len);
71
72     printf("---------------------------------------------\n");
73     tpm2_plugin_rsa_sign(keyHandle_sign, mechanism, msg, msg_len, sig, sig_len);
74
75 }