函数逻辑报告 |
Source Code:lib\crypto\chacha20poly1305.c |
Create Date:2022-07-27 07:42:20 |
| Last Modify:2020-03-12 14:18:49 | Copyright©Brick |
| 首页 | 函数Tree |
| 注解内核,赢得工具 | 下载SCCT | English |
函数名称:chacha20poly1305_crypt_sg_inplace
函数原型:static bool chacha20poly1305_crypt_sg_inplace(struct scatterlist *src, const size_t src_len, const u8 *ad, const size_t ad_len, const u64 nonce, const u8 key[CHACHA20POLY1305_KEY_SIZE], int encrypt)
返回类型:bool
参数:
| 类型 | 参数 | 名称 |
|---|---|---|
| struct scatterlist * | src | |
| const size_t | src_len | |
| const u8 * | ad | |
| const size_t | ad_len | |
| const u64 | nonce | |
| const u8 | key | |
| int | encrypt |
| 217 | pad0等于page_address(ZERO_PAGE(0)) |
| 221 | partial等于0 |
| 223 | bool ret = true |
| 225 | union{struct{u32 k[(32 / sizeof(u32))];__le64 iv[2];}u8 block0[32];u8 chacha_stream[64];struct{u8 mac[2][16];}__le64 lens[2];}b((__aligned__(16))) __attribute__((__aligned__(16))) |
| 241 | chacha_load_key(k, key) |
| 243 | iv[0]等于0 |
| 246 | chacha_init(chacha_state, k, (u8 * )iv) |
| 247 | chacha20_crypt(chacha_state, block0, pad0, block0的长度) |
| 248 | poly1305_init( & poly1305_state, block0) |
| 250 | 如果此条件成立可能性小(为编译器优化)(ad_len)则 |
| 251 | poly1305_update( & poly1305_state, ad, ad_len) |
| 252 | 如果ad_len按位与0xf则poly1305_update( & poly1305_state, pad0, 0x10 - (ad_len & 0xf)) |
| 257 | 如果非preemptible()则flags或等于use kmap_atomic |
| 260 | 开始映射迭代一个SG名单 |
| 264 | length等于min_t - return minimum of two values, using the specified type*@type: data type to use*@x: first value*@y: second value(size_t, sl, length of the mapped area ) |
| 266 | 如果非encrypt则poly1305_update( & poly1305_state, addr, length) |
| 269 | 如果此条件成立可能性小(为编译器优化)(partial)则 |
| 270 | l等于两数取小(length, CHACHA_BLOCK_SIZE - partial) |
| 272 | crypto_xor(addr, chacha_stream + partial, l) |
| 273 | partial等于partial加l按位与CHACHA_BLOCK_SIZE减1 |
| 279 | 如果此条件成立可能性大(为编译器优化)(length >= CHACHA_BLOCK_SIZE || length == sl)则 |
| 282 | 如果此条件成立可能性小(为编译器优化)(length < sl)则l与等于CHACHA_BLOCK_SIZE减1的差的反 |
| 284 | chacha20_crypt(chacha_state, addr, addr, l) |
| 289 | 如果此条件成立可能性小(为编译器优化)(length > 0)则 |
| 292 | crypto_xor(addr, chacha_stream, length) |
| 301 | 如果src_len按位与0xf则poly1305_update( & poly1305_state, pad0, 0x10 - (src_len & 0xf)) |
| 306 | poly1305_update( & poly1305_state, (u8 * )lens, lens的长度) |
| 308 | 如果此条件成立可能性大(为编译器优化)(sl <= - POLY1305_DIGEST_SIZE)则 |
| 323 | 如果此条件成立可能性小(为编译器优化)(sl > - POLY1305_DIGEST_SIZE)则 |
| 324 | poly1305_final( & poly1305_state, mac[1]) |
| 334 | 返回:ret |
| 源代码转换工具 开放的插件接口 | X |
|---|---|
| 支持:c/c++/esqlc/java Oracle/Informix/Mysql 插件可实现:逻辑报告 代码生成和批量转换代码 |