Select one of the symbols to view example projects that use it.
 
Outline
...
...
...
...
...
...
#define NX_CRYPTO_GCM_H
#include "nx_crypto.h"
#define NX_CRYPTO_GCM_BLOCK_SIZE
#define NX_CRYPTO_GCM_BLOCK_SIZE_BITS
#define NX_CRYPTO_GCM_BLOCK_SIZE_INT
#define NX_CRYPTO_GCM_BLOCK_SIZE_SHIFT
NX_CRYPTO_GCM_STRUCT
_nx_crypto_gcm_encrypt_init(void *, NX_CRYPTO_GCM *, UINT (*)(void *, UCHAR *, UCHAR *, UINT), void *, UINT, UCHAR *, UINT);
_nx_crypto_gcm_encrypt_update(void *, NX_CRYPTO_GCM *, UINT (*)(void *, UCHAR *, UCHAR *, UINT), UCHAR *, UCHAR *, UINT, UINT);
_nx_crypto_gcm_encrypt_calculate(void *, NX_CRYPTO_GCM *, UINT (*)(void *, UCHAR *, UCHAR *, UINT), UCHAR *, UINT, UINT);
_nx_crypto_gcm_decrypt_update(void *, NX_CRYPTO_GCM *, UINT (*)(void *, UCHAR *, UCHAR *, UINT), UCHAR *, UCHAR *, UINT, UINT);
_nx_crypto_gcm_decrypt_calculate(void *, NX_CRYPTO_GCM *, UINT (*)(void *, UCHAR *, UCHAR *, UINT), UCHAR *, UINT, UINT);
#define _nx_crypto_gcm_decrypt_init
Files
loading...
CodeScopeSTM32 Libraries and Samplesnetxduocrypto_libraries/inc/nx_crypto_gcm.h
 
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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
/**************************************************************************/ /* */ /* Copyright (c) Microsoft Corporation. All rights reserved. */ /* */ /* This software is licensed under the Microsoft Software License */ /* Terms for Microsoft Azure RTOS. Full text of the license can be */ /* found in the LICENSE file at https://aka.ms/AzureRTOS_EULA */ /* and in the root directory of this software. */ /* */... /**************************************************************************/ ... /**************************************************************************/ /**************************************************************************/ /** */ /** NetX Crypto Component */ /** */ /** GCM Mode */ /** */... /**************************************************************************/ /**************************************************************************/ ... /**************************************************************************/ /* */ /* APPLICATION INTERFACE DEFINITION RELEASE */ /* */ /* nx_crypto_gcm.h PORTABLE C */ /* 6.1 */ /* AUTHOR */ /* */ /* Timothy Stapko, Microsoft Corporation */ /* */ /* DESCRIPTION */ /* */ /* This file defines the basic Application Interface (API) to the */ /* NetX Crypto GCM module. */ /* */ /* RELEASE HISTORY */ /* */ /* DATE NAME DESCRIPTION */ /* */ /* 05-19-2020 Timothy Stapko Initial Version 6.0 */ /* 09-30-2020 Timothy Stapko Modified comment(s), */ /* resulting in version 6.1 */ /* */... /**************************************************************************/ #ifndef NX_CRYPTO_GCM_H #define NX_CRYPTO_GCM_H /* Determine if a C++ compiler is being used. If so, ensure that standard C is used to process the API information. *//* ... */ #ifdef __cplusplus /* Yes, C++ compiler is present. Use standard C. */ extern "C" { #endif /* Include the ThreadX and port-specific data type file. */ #include "nx_crypto.h" #define NX_CRYPTO_GCM_BLOCK_SIZE 16 #define NX_CRYPTO_GCM_BLOCK_SIZE_BITS 128 #define NX_CRYPTO_GCM_BLOCK_SIZE_INT 4 #define NX_CRYPTO_GCM_BLOCK_SIZE_SHIFT 4 typedef struct NX_CRYPTO_GCM_STRUCT { /* Total length of input. */ ULONG nx_crypto_gcm_input_total_length; /* Internal context of GCM mode. */ UCHAR nx_crypto_gcm_hkey[NX_CRYPTO_GCM_BLOCK_SIZE]; UCHAR nx_crypto_gcm_j0[NX_CRYPTO_GCM_BLOCK_SIZE]; UCHAR nx_crypto_gcm_s[NX_CRYPTO_GCM_BLOCK_SIZE]; UCHAR nx_crypto_gcm_counter[NX_CRYPTO_GCM_BLOCK_SIZE]; /* Pointer of additional data. */ VOID *nx_crypto_gcm_additional_data; /* Length of additional data. */ UINT nx_crypto_gcm_additional_data_len; ...} NX_CRYPTO_GCM; NX_CRYPTO_KEEP UINT _nx_crypto_gcm_encrypt_init(VOID *crypto_metadata, NX_CRYPTO_GCM *gcm_metadata, UINT (*crypto_function)(VOID *, UCHAR *, UCHAR *, UINT), VOID *additional_data, UINT additional_len, UCHAR *iv, UINT block_size); NX_CRYPTO_KEEP UINT _nx_crypto_gcm_encrypt_update(VOID *crypto_metadata, NX_CRYPTO_GCM *gcm_metadata, UINT (*crypto_function)(VOID *, UCHAR *, UCHAR *, UINT), UCHAR *input, UCHAR *output, UINT length, UINT block_size); NX_CRYPTO_KEEP UINT _nx_crypto_gcm_encrypt_calculate(VOID *crypto_metadata, NX_CRYPTO_GCM *gcm_metadata, UINT (*crypto_function)(VOID *, UCHAR *, UCHAR *, UINT), UCHAR *output, UINT icv_len, UINT block_size); NX_CRYPTO_KEEP UINT _nx_crypto_gcm_decrypt_update(VOID *crypto_metadata, NX_CRYPTO_GCM *gcm_metadata, UINT (*crypto_function)(VOID *, UCHAR *, UCHAR *, UINT), UCHAR *input, UCHAR *output, UINT length, UINT block_size); NX_CRYPTO_KEEP UINT _nx_crypto_gcm_decrypt_calculate(VOID *crypto_metadata, NX_CRYPTO_GCM *gcm_metadata, UINT (*crypto_function)(VOID *, UCHAR *, UCHAR *, UINT), UCHAR *input, UINT icv_len, UINT block_size); #define _nx_crypto_gcm_decrypt_init _nx_crypto_gcm_encrypt_init #ifdef __cplusplus }extern "C" { ... } #endif /* ... */ #endif /* NX_CRYPTO_GCM_H */...