当前位置: 首页 > news >正文

boringssl EVP_aes_128_ecb实现

最近学习boringssl,发现没找到EVP_aes_128_ecb在哪里实现的

饶了一大圈,发现它的定义很无语

#define EVP_CIPHER_FUNCTION(keybits, mode)             \const EVP_CIPHER *EVP_aes_##keybits##_##mode(void) { \return aes_##keybits##_##mode##_generic();         \}EVP_CIPHER_FUNCTION(128, cbc)
EVP_CIPHER_FUNCTION(128, ctr)
EVP_CIPHER_FUNCTION(128, ofb)
EVP_CIPHER_FUNCTION(128, gcm)EVP_CIPHER_FUNCTION(192, cbc)
EVP_CIPHER_FUNCTION(192, ctr)
EVP_CIPHER_FUNCTION(192, ofb)
EVP_CIPHER_FUNCTION(192, gcm)EVP_CIPHER_FUNCTION(256, cbc)
EVP_CIPHER_FUNCTION(256, ctr)
EVP_CIPHER_FUNCTION(256, ofb)
EVP_CIPHER_FUNCTION(256, gcm)EVP_ECB_CIPHER_FUNCTION(128)
EVP_ECB_CIPHER_FUNCTION(192)
EVP_ECB_CIPHER_FUNCTION(256)

随便拿EVP_CIPHER_FUNCTION(128, cbc)展开

EVP_CIPHER_FUNCTION(128, cbc) =   const EVP_CIPHER *EVP_aes_128_cbc(void) {  \return aes_128_cbc_generic();                                            \}

这里的 aes_128_cbc_generic 参考boringssl DEFINE_LOCAL_DATA

其实有方向的情况下可以用gcc -E ./src/crypto/fipsmodule/cipher/e_aes.c -o test.i -I include/

-E,只执行到预编译,直接输出预编译结果【有目标的情况下】

可以看看如下的预编译结果

# 855 "./src/crypto/fipsmodule/cipher/e_aes.c"
const EVP_CIPHER *EVP_aes_128_cbc(void) { return aes_128_cbc_generic(); }
const EVP_CIPHER *EVP_aes_128_ctr(void) { return aes_128_ctr_generic(); }
const EVP_CIPHER *EVP_aes_128_ofb(void) { return aes_128_ofb_generic(); }
const EVP_CIPHER *EVP_aes_128_gcm(void) { return aes_128_gcm_generic(); }const EVP_CIPHER *EVP_aes_192_cbc(void) { return aes_192_cbc_generic(); }
const EVP_CIPHER *EVP_aes_192_ctr(void) { return aes_192_ctr_generic(); }
const EVP_CIPHER *EVP_aes_192_ofb(void) { return aes_192_ofb_generic(); }
const EVP_CIPHER *EVP_aes_192_gcm(void) { return aes_192_gcm_generic(); }const EVP_CIPHER *EVP_aes_256_cbc(void) { return aes_256_cbc_generic(); }
const EVP_CIPHER *EVP_aes_256_ctr(void) { return aes_256_ctr_generic(); }
const EVP_CIPHER *EVP_aes_256_ofb(void) { return aes_256_ofb_generic(); }
const EVP_CIPHER *EVP_aes_256_gcm(void) { return aes_256_gcm_generic(); }const EVP_CIPHER *EVP_aes_128_ecb(void) { if (hwaes_capable()) { return aes_hw_128_ecb(); } return aes_128_ecb_generic(); }
const EVP_CIPHER *EVP_aes_192_ecb(void) { if (hwaes_capable()) { return aes_hw_192_ecb(); } return aes_192_ecb_generic(); }
const EVP_CIPHER *EVP_aes_256_ecb(void) { if (hwaes_capable()) { return aes_hw_256_ecb(); } return aes_256_ecb_generic(); }

文件 "./src/crypto/fipsmodule/cipher/e_aes.c + 行号;855

http://www.lryc.cn/news/145520.html

相关文章:

  • vxe-table中树形结构
  • Linux命令查看CPU、内存、IO使用情况简单介绍
  • RPC框架的核心是什么
  • 直播、AI赋能,美团披着荆棘前行
  • 提升代码逻辑的感觉——python循环语句
  • 【ARM Coresight 系列文章 20 -- linux perf 与 ARM coresight】
  • 微服务之Nacos
  • jvm 新生代的区域划分
  • 【C++】对于string的补充(成员函数c_str()、大小写转换、字符串和实数之间的相互转换)
  • 华为OD机试真题【羊狼农夫过河】
  • 【线性代数-3Blue1Brown】- 5 三维空间的线性变换
  • Maven入门教程(二):idea/Eclipse使用Maven
  • 【MySQL】MySQL里的用户账户和角色是什么?如何管理?
  • vbs病毒
  • 用Java实现Huffman编码
  • day-04 基于UDP的服务器端/客户端
  • FFmpeg rtp rtp_mpegts的区别
  • 【链表OJ】相交链表 环形链表1
  • DevOps之自动化测试
  • Java 程序打印 OpenCV 的版本
  • ChatGPT⼊门到精通(2):ChatGPT 能为我们做什么
  • 线程和进程的区别是什么?
  • 力扣27.移除元素
  • 指针(个人学习笔记黑马学习)
  • vue 路由动态加载
  • 电脑识别不了固态硬盘怎么办?
  • QCustomPlot 绘制卡顿问题
  • uni-app开发小程序,radio单选按钮,点击可以选中,再次点击可以取消
  • 【Qt专栏】实现单例程序,禁止程序多开的几种方式
  • 力扣26. 删除有序数组中的重复项