[SKE]Python gmssl库的C绑定
Python gmssl库的C绑定
摘要:本文展示gmssl库的C绑定,并给出完整代码。将参考模型从Python脚本迁移到纯C代码中使用gmssl库(TongSuo项目,支持国密算法如SM4,同时兼容AES、DES、3DES、RSA等)。这样,UVM(SystemVerilog)可以通过DPI-C直接调用C函数,而无需嵌入Python解释器。这简化了集成,避免了Python依赖,提高了性能,但需要您编译和链接gmssl库(libcrypto.so或libtongsuo.so)。
一、关键调整与假设
- 纯gmssl C绑定:所有加密/解密逻辑都在C代码中实现,使用gmssl的EVP API(高层次抽象,支持AES、SM4、DES、3DES、RSA)。gmssl是OpenSSL的分支,因此兼容标准算法,同时添加SM4支持。
- 下载/编译gmssl:从