~jocave/checkbox/hybrid-amd-gpu-mods

« back to all changes in this revision

Viewing changes to providers/plainbox-provider-tpm2/bin/test_tpm2_encryptdecrypt.sh

  • Committer: Sylvain Pineau
  • Author(s): Sylvain Pineau
  • Date: 2016-05-09 22:02:27 UTC
  • mfrom: (4323.2.1 launchpad/tpm2-provider)
  • Revision ID: sylvain_pineau-20160509220227-wt2e8boo9ktitvzl
"automatic merge of lp:~sylvain-pineau/checkbox/tpm2-provider/ by tarmac [r=sylvain-pineau][bug=][author=sylvain-pineau]"

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
#!/bin/bash
 
2
new_path=`pwd`
 
3
PATH="$PATH":"$new_path"
 
4
 
 
5
alg_primary_obj=0x0004
 
6
alg_primary_key=0x0001
 
7
alg_create_obj=0x000B
 
8
alg_create_key=0x0025
 
9
 
 
10
file_input_data=secret.data
 
11
file_primary_key_ctx=context.p_"$alg_primary_obj"_"$alg_primary_key"
 
12
file_en_decrypt_key_pub=opu_"$alg_create_obj"_"$alg_create_key"
 
13
file_en_decrypt_key_priv=opr_"$alg_create_obj"_"$alg_create_key"
 
14
file_en_decrypt_key_name=name.load_"$alg_primary_obj"_"$alg_primary_key"-"$alg_create_obj"_"$alg_create_key"
 
15
file_en_decrypt_key_ctx=ctx_load_out_"$alg_primary_obj"_"$alg_primary_key"-"$alg_create_obj"_"$alg_create_key"
 
16
file_encrypt_output_data=encrypt_"$file_en_decrypt_key_ctx"
 
17
file_decrypt_output_data=decrypt_"$file_en_decrypt_key_ctx"
 
18
 
 
19
fail()
 
20
{
 
21
            echo "$1 test fail, please check the environment or parameters!"
 
22
 exit 1
 
23
}
 
24
Pass()
 
25
{
 
26
            echo ""$1" pass" >>test_getpubak_pass.log
 
27
}
 
28
 
 
29
rm $file_primary_key_ctx $file_en_decrypt_key_pub $file_en_decrypt_key_priv $file_en_decrypt_key_name $file_en_decrypt_key_ctx  $file_encrypt_output_data $file_decrypt_output_data -rf
 
30
 
 
31
 
 
32
if [ ! -e "$file_input_data" ]   
 
33
  then    
 
34
echo "12345678" > $file_input_data
 
35
fi 
 
36
 
 
37
tpm2_takeownership -c
 
38
 
 
39
tpm2_createprimary -A e -g $alg_primary_obj -G $alg_primary_key -C $file_primary_key_ctx
 
40
if [ $? != 0 ];then
 
41
         fail createprimary 
 
42
fi
 
43
tpm2_create -g $alg_create_obj -G $alg_create_key -o $file_en_decrypt_key_pub -O $file_en_decrypt_key_priv  -c $file_primary_key_ctx
 
44
if [ $? != 0 ];then
 
45
        fail create 
 
46
fi
 
47
 
 
48
tpm2_load -c $file_primary_key_ctx  -u $file_en_decrypt_key_pub  -r $file_en_decrypt_key_priv -n $file_en_decrypt_key_name -C $file_en_decrypt_key_ctx
 
49
if [ $? != 0 ];then
 
50
        fail load   
 
51
fi
 
52
 
 
53
tpm2_encryptdecrypt -c $file_en_decrypt_key_ctx  -D NO -I secret.data -o $file_encrypt_output_data
 
54
if [ $? != 0 ];then
 
55
        fail decrypt 
 
56
fi
 
57
tpm2_encryptdecrypt -c  $file_en_decrypt_key_ctx -D YES -I $file_encrypt_output_data -o $file_decrypt_output_data
 
58
if [ $? != 0 ];then
 
59
        fail decrypt 
 
60
fi
 
61
 
 
62
echo "encryptdecrypt test OK!"
 
63