hc
2023-12-11 6778948f9de86c3cfaf36725a7c87dcff9ba247f
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
/* SPDX-License-Identifier: GPL-2.0 */
/*
 * Shared descriptors for aead, skcipher algorithms
 *
 * Copyright 2016 NXP
 */
 
#ifndef _CAAMALG_DESC_H_
#define _CAAMALG_DESC_H_
 
/* length of descriptors text */
#define DESC_AEAD_BASE            (4 * CAAM_CMD_SZ)
#define DESC_AEAD_ENC_LEN        (DESC_AEAD_BASE + 11 * CAAM_CMD_SZ)
#define DESC_AEAD_DEC_LEN        (DESC_AEAD_BASE + 15 * CAAM_CMD_SZ)
#define DESC_AEAD_GIVENC_LEN        (DESC_AEAD_ENC_LEN + 8 * CAAM_CMD_SZ)
#define DESC_QI_AEAD_ENC_LEN        (DESC_AEAD_ENC_LEN + 3 * CAAM_CMD_SZ)
#define DESC_QI_AEAD_DEC_LEN        (DESC_AEAD_DEC_LEN + 3 * CAAM_CMD_SZ)
#define DESC_QI_AEAD_GIVENC_LEN        (DESC_AEAD_GIVENC_LEN + 3 * CAAM_CMD_SZ)
 
/* Note: Nonce is counted in cdata.keylen */
#define DESC_AEAD_CTR_RFC3686_LEN    (4 * CAAM_CMD_SZ)
 
#define DESC_AEAD_NULL_BASE        (3 * CAAM_CMD_SZ)
#define DESC_AEAD_NULL_ENC_LEN        (DESC_AEAD_NULL_BASE + 11 * CAAM_CMD_SZ)
#define DESC_AEAD_NULL_DEC_LEN        (DESC_AEAD_NULL_BASE + 13 * CAAM_CMD_SZ)
 
#define DESC_GCM_BASE            (3 * CAAM_CMD_SZ)
#define DESC_GCM_ENC_LEN        (DESC_GCM_BASE + 16 * CAAM_CMD_SZ)
#define DESC_GCM_DEC_LEN        (DESC_GCM_BASE + 12 * CAAM_CMD_SZ)
#define DESC_QI_GCM_ENC_LEN        (DESC_GCM_ENC_LEN + 6 * CAAM_CMD_SZ)
#define DESC_QI_GCM_DEC_LEN        (DESC_GCM_DEC_LEN + 3 * CAAM_CMD_SZ)
 
#define DESC_RFC4106_BASE        (3 * CAAM_CMD_SZ)
#define DESC_RFC4106_ENC_LEN        (DESC_RFC4106_BASE + 16 * CAAM_CMD_SZ)
#define DESC_RFC4106_DEC_LEN        (DESC_RFC4106_BASE + 13 * CAAM_CMD_SZ)
#define DESC_QI_RFC4106_ENC_LEN        (DESC_RFC4106_ENC_LEN + 5 * CAAM_CMD_SZ)
#define DESC_QI_RFC4106_DEC_LEN        (DESC_RFC4106_DEC_LEN + 5 * CAAM_CMD_SZ)
 
#define DESC_RFC4543_BASE        (3 * CAAM_CMD_SZ)
#define DESC_RFC4543_ENC_LEN        (DESC_RFC4543_BASE + 11 * CAAM_CMD_SZ)
#define DESC_RFC4543_DEC_LEN        (DESC_RFC4543_BASE + 12 * CAAM_CMD_SZ)
#define DESC_QI_RFC4543_ENC_LEN        (DESC_RFC4543_ENC_LEN + 4 * CAAM_CMD_SZ)
#define DESC_QI_RFC4543_DEC_LEN        (DESC_RFC4543_DEC_LEN + 4 * CAAM_CMD_SZ)
 
#define DESC_SKCIPHER_BASE        (3 * CAAM_CMD_SZ)
#define DESC_SKCIPHER_ENC_LEN        (DESC_SKCIPHER_BASE + \
                    21 * CAAM_CMD_SZ)
#define DESC_SKCIPHER_DEC_LEN        (DESC_SKCIPHER_BASE + \
                    16 * CAAM_CMD_SZ)
 
void cnstr_shdsc_aead_null_encap(u32 * const desc, struct alginfo *adata,
                unsigned int icvsize, int era);
 
void cnstr_shdsc_aead_null_decap(u32 * const desc, struct alginfo *adata,
                unsigned int icvsize, int era);
 
void cnstr_shdsc_aead_encap(u32 * const desc, struct alginfo *cdata,
               struct alginfo *adata, unsigned int ivsize,
               unsigned int icvsize, const bool is_rfc3686,
               u32 *nonce, const u32 ctx1_iv_off,
               const bool is_qi, int era);
 
void cnstr_shdsc_aead_decap(u32 * const desc, struct alginfo *cdata,
               struct alginfo *adata, unsigned int ivsize,
               unsigned int icvsize, const bool geniv,
               const bool is_rfc3686, u32 *nonce,
               const u32 ctx1_iv_off, const bool is_qi, int era);
 
void cnstr_shdsc_aead_givencap(u32 * const desc, struct alginfo *cdata,
                  struct alginfo *adata, unsigned int ivsize,
                  unsigned int icvsize, const bool is_rfc3686,
                  u32 *nonce, const u32 ctx1_iv_off,
                  const bool is_qi, int era);
 
void cnstr_shdsc_gcm_encap(u32 * const desc, struct alginfo *cdata,
              unsigned int ivsize, unsigned int icvsize,
              const bool is_qi);
 
void cnstr_shdsc_gcm_decap(u32 * const desc, struct alginfo *cdata,
              unsigned int ivsize, unsigned int icvsize,
              const bool is_qi);
 
void cnstr_shdsc_rfc4106_encap(u32 * const desc, struct alginfo *cdata,
                  unsigned int ivsize, unsigned int icvsize,
                  const bool is_qi);
 
void cnstr_shdsc_rfc4106_decap(u32 * const desc, struct alginfo *cdata,
                  unsigned int ivsize, unsigned int icvsize,
                  const bool is_qi);
 
void cnstr_shdsc_rfc4543_encap(u32 * const desc, struct alginfo *cdata,
                  unsigned int ivsize, unsigned int icvsize,
                  const bool is_qi);
 
void cnstr_shdsc_rfc4543_decap(u32 * const desc, struct alginfo *cdata,
                  unsigned int ivsize, unsigned int icvsize,
                  const bool is_qi);
 
void cnstr_shdsc_chachapoly(u32 * const desc, struct alginfo *cdata,
               struct alginfo *adata, unsigned int ivsize,
               unsigned int icvsize, const bool encap,
               const bool is_qi);
 
void cnstr_shdsc_skcipher_encap(u32 * const desc, struct alginfo *cdata,
               unsigned int ivsize, const bool is_rfc3686,
               const u32 ctx1_iv_off);
 
void cnstr_shdsc_skcipher_decap(u32 * const desc, struct alginfo *cdata,
               unsigned int ivsize, const bool is_rfc3686,
               const u32 ctx1_iv_off);
 
void cnstr_shdsc_xts_skcipher_encap(u32 * const desc, struct alginfo *cdata);
 
void cnstr_shdsc_xts_skcipher_decap(u32 * const desc, struct alginfo *cdata);
 
#endif /* _CAAMALG_DESC_H_ */