OpenSSL 3.0.0 设计(四)|代码维护、FIPS 测试

译|王祖熙 (花名:金九 )

蚂蚁集团开发工程师
负责国产化密码库 Tongsuo 的开发和维护
专注于密码学、高性能网络、网络安全等领域

本文 2862 字 阅读 8 分钟

本文翻译 OpenSSL 官网文档:https://www.openssl.org/docs/OpenSSL300Design.html

Tongsuo-8.4.0 是基于 OpenSSL-3.0.3 开发,所以本文对 Tongsuo 开发者同样适用,内容丰富,值得一读!

由于文章篇幅较长,今天带来的是 《代码维护、FIPS 测试》 部分内

后续内容将随每周推送完整发布,请持续关注铜锁

代码维护

源代码结构/目录树的清理

密码学实现(crypto/evp/e_*.c和大部分crypto/evp/m_*.c,以及任何定义EVP_CIPHEREVP_MDEVP_PKEY_METHODEVP_MACEVP_KDF的代码)必须移出 evp 目录,它们最终将成为一个或两个 Provider 的一部分,因此它们应该位于特定 Provider 的子目录中。

将创建一个新的目录providers/,用于存放特定 Provider 的代码。providers/build.info定义了哪些源文件在哪些 Provider 模块中使用。

共享源代码

FIPS Provider 模块和默认 Provider 将共享相同的源代码,在不同的条件下,例如不同的#include路径或定义的宏不同(后者需要在构建系统中添加支持)。下面是一个示例build.info文件,实现了这一点:

PROVIDERS=p_fips p_default

SOURCE[p_fips]=foo.c
INCLUDE[p_fips]=include/fips

SOURCE[p_default]=foo.c
INCLUDE[p_default]=include/default

或者,使用宏:

PROVIDERS=p_fips p_default

SOURCE[p_fips]=foo.c
DEFINE[p_fips]=FIPS_MODE

SOURCE[p_default]=foo.c

注意:一些关键字还不是 build.info 语言的一部分。

条件代码

我们需要对编译时包含 FIPS 特定代码的方法进行一致处理,并在某些情况下排除 FIPS 不允许的代码。

编译时的控制将通过#ifdef FIPS_MODE来进行,这确保所有相关的文件都明确地为非 FIPS 或在 FIPS 模块内部进行编译,由于每个文件都将被编译两次(在默认 Provider 和 FIPS 模块中各一次),一次使用每个设置,因此使用具有恒定值的运行时if语句没有好处。(此外,运行时设置并不总是有效(例如在扩展诸如BLOCK_CIPHER_custom之类的宏时,会创建全局变量或函数指针。)

构建系统将通过使用-DFIPS_MODE编译 FIPS Provider 对象文件,以及不带命令行定义的来自相同源的默认 Provider 对象文件来支持此操作。

对于运行时检查,将需要检查 TLS 连接是否处于 FIPS 模式,这可以通过以通用方式检查与特定SSL_CTXSSL对象关联的属性查询字符串来完成,以查看是否设置了“fips”属性。

FIPS 测试

需要进行以下类型的测试:

  • 用于 CMVP 验证算法的 CAVS 测试;
  • 能够运行所有 FIPS 模块算法的 FIPS 测试套件;
  • 启动后故障测试;
  • Acumen 将编写使用 libcrypto 的应用程序,通过 EVP 层访问 FIPS Provider。

任何需要返回中间值(例如 CAVS 密钥生成)以显示信息(自检状态)或更改 FIPS 模块代码的正常流程的特殊情况代码(例如自检失败或在提供固定随机值的密钥生成循环中失败),将通过将回调函数嵌入到FIPS模块代码中进行控制。

建议将这些回调代码以条件编译的方式编入模块中中,因为其中一些值不应该被返回(例如,FIPS 模块不应该输出密钥生成中的中间值)。

针对需要使用固定 rand_bytes 的测试,将对rand_bytes()进行重写。

FIPS 测试回调

应用程序可以选择提供一个回调函数,用于处理从 FIPS 模块接收到的值(如果需要,可以注册多个回调函数)。

可选的应用程序回调函数的形式如下:

static int fips_test_callback(const char *type, void *arg)
{
    return 1;
}

回调函数的返回值可用于控制 FIPS 模块代码中的特殊情况的流程。

类型由 FIPS 模块钩子传入,FIPS模块中的每个不同的钩子应具有唯一的类型,类型决定了参数 arg 的内容(可以是结构体(例如中间值)、名称或整数)。

FIPS 模块中的回调函数的形式如下:

MY_STRUCT  data;   /* values that need to be returned to the application */
data.i = 1;
.....
if (FIPS_test_cb != NULL)
    FIPS_test_cb(FIPS_TEST_CB_RSA_KEYGEN_GET, (void *)&data);

POST 故障测试和日志记录

为了支持多个测试的失败,所有测试将始终运行而不提前退出(只是标记失败),在所有测试完成后,将返回失败状态。

用于日志记录或失败的参数将为:

struct {
    const char *desc;
    const char *state;
    const char *fail_reason;
};

其中:

  • type 是“post_integrity”、“post_cipher”、“post_digest”、“post_signature”、“post_drbg”等之一;
  • desc 是标识性名称,例如 AES_128_CBC
  • state 是以下之一:
    • “start” - 表示测试开始
    • “corrupt” - 如果返回值为0,则测试将失败
    • “pass” - 表示测试通过
    • “fail” - 表示测试失败
  • fail_reason - 是失败的具体原因(例如,无法读取完整性模块文件或完整性校验和文件)。

CAVS测试

CAVS 测试将由实验室执行。

然而,每个 CAVS 测试文件也可以进行抽样,并添加到单元测试中,这意味着可以将单个测试的文件数据转换为单元测试内的二进制数据。

DRBG_ctr 是已经实现了此功能的示例)。

这将确保以下内容:

  • CAVS 测试将可访问所需的接口(某些 CAVS 测试需要访问通常不需要的内部接口);
  • 算法的正常工作;
  • 覆盖率。

如果与实验室之间有良好的沟通,我们可以跳过此步骤,但如果实验室发现缺少对内部访问器的访问,可能需要在代码中添加一些额外的回调钩子。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: openssl 3.0.0 x86版编译版是一种开源软件包,用于安全通信领域中的加密和解密操作。它的编译版指的是已经经过编译的、可直接运行的版本,而x86版是指适用于x86架构的计算机。 OpenSSL是一个功能强大的加密库,它支持各种密码算法安全协议和密钥管理功能。它的用途非常广泛,可以用于构建安全的通信通道、保护数据传输的机密性和完整性、以及数字证书的生成和管理等。编译版的意思是,开发者已经将源代码编译为可执行程序,用户无需再进行编译步骤,可以直接运行使用。 x86版是指针对基于Intel x86架构的计算机而设计的版本。这种架构是目前使用最广泛的计算机架构之一,适用于大多数个人电脑和服务器。因此,OpenSSL 3.0.0 x86版编译版可以在这些计算机上运行,并提供其强大的加密和解密功能。 使用OpenSSL 3.0.0 x86版编译版,您可以轻松地在您的系统中集成各种加密和解密操作。您可以使用它来保护敏感数据,比如在网络上进行加密通信、对密码进行加密存储和验证、生成和验证数字证书等。 总之,OpenSSL 3.0.0 x86版编译版是一种功能强大的加密库,适用于基于Intel x86架构的计算机。它可以用于构建安全的通信通道、保护数据传输的机密性和完整性,并提供数字证书的生成和管理功能。 ### 回答2: openssl3.0.0是一个流行的开源加密库,具有强大的加密和安全功能。x86版编译版是指特定的架构和编译选项下生成的可执行文件。 对于openssl3.0.0 x86版的编译版,一般是为x86架构的计算机系统编译的。在编译此版本时,会根据具体的操作系统和编译选项进行配置,以便生成适合x86架构的可执行文件。 编译版通常包括openssl的库文件和命令行工具。库文件可供开发人员在自己的应用程序中使用,以实现加密和安全功能。命令行工具则提供了各种加密和解密操作命令,例如生成证书、加密文件等。 使用openssl3.0.0 x86版编译版,你可以在自己的项目中使用openssl库的功能,比如创建SSL/TLS连接、进行数据的加密和解密,验证证书等等。你还可以使用openssl命令行工具来执行各种加密和解密操作,对文件和数据进行处理。 通过使用openssl3.0.0 x86版编译版,你能够获得最新版本的openssl库,并且根据你的需要进行编译和配置。这将使你能够使用openssl强大的加密和安全功能来保护你的数据和通信。无论是在开发过程中还是在实际应用中,openssl3.0.0 x86版编译版都是一个非常有用的工具。 ### 回答3: OpenSSL 3.0.0 x86版编译版是一款适用于x86架构的编译版本。OpenSSL是一种开放源代码的加密库,提供了各种功能,如密码学算法、网络通信协议的支持等。其最新版本为3.0.0,针对x86架构进行了编译优化。 通过对OpenSSL库进行编译,可以在x86架构的计算机系统上使用和运行OpenSSL的功能。编译版的好处是可以更好地适应特定硬件和操作系统的特性,提供更高效和稳定的性能。同时,编译版也可以优化库的大小和功能,以满足不同的需求。 对于OpenSSL 3.0.0 x86版编译版的使用,需要将其安装到操作系统中,并在开发和部署应用程序时将其链接到相应的编程语言或框架中。在开发过程中,可以使用OpenSSL的功能来实现安全通信、加密数据、生成证书等操作。在部署应用程序时,需要确保系统可以访问到正确版本的OpenSSL库。 总之,OpenSSL 3.0.0 x86版编译版是一种适用于x86架构的编译版本,通过使用它可以在x86计算机系统上进行加密通信、数据保护等操作。它的使用需要进行安装和链接,并与开发和部署的应用程序进行集成。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值