Linux内核密码模块

news2025/1/27 12:26:20

目录

密码算法介绍

Hash摘要算法

Cipher加解密算法

块密码算法

认证算法 MAC和HMAC

AEAD算法

Linux内核密码模块的基本构件

Linux内核密码模块介绍

如何使用Linux密码模块

用户层调用Linux内核密码模块的方法

cryptodev

AF_ALG

如何开发一个密码引擎驱动

开发一个密码引擎驱动的流程

以cbc(aes)算法为例的实际代码示例


密码算法介绍

密码算法主要是为了保护双方或者多方的通信,涉及到保密性、完整性和可认证性

Hash摘要算法

Hash或Digest是属于完整性,根据指定输入得到“唯一”校验值,比如SHA1,MD5,等等。

针对HASH算法的三个标准:

1、尽可能少的碰撞出相同的摘要值

2、不可能根据摘要值重新生成原数据

3、一个小的修改就能生成完成不同的摘要值

Cipher加解密算法

要求使用一组或者几组数据来加密/解密数据

Cipher算法可以分为流密码算法和块密码算法,还可以分为对称密码算法和非对称密码算法。

其中流密码算法是对一串流数据加密,块密码算法需要限定数据大小的数据块;

其中对称密码算法是指加解密都使用相同的密钥,非对称密码算法加密使用公钥,解密使用私钥。有AES,RSA算法等

块密码算法

块密码算法只能对一小块数据进行加解密,我们需要找个方法来处理任意长度的数据,大部分的块密码算法都要求有Initialization Vector(IV)来混淆加密数据。此算法模式有ECB,CBC等。

认证算法 MAC和HMAC

MAC代表消息认证码,用来认证发送者消息的机制,使用一组密钥和转化算法来生成认证码,使用HASH算法就叫HMAC。

AEAD算法

AEAD算法表示对数据进行认证加密,把认证,加密和摘要一步完成。

Linux内核密码模块的基本构件

Linux内核密码模块介绍

Linux密码模块的基本构件主要为两个结构体:struct crypto_alg和struct crypto_tfm。支持所有的算法,比如Cipher(加解密)、Hash(摘要)、AEAD(链式)、HMAC(认证)和Compression(解压缩)。

密码算法可以用一个基本算法构建的模块来表示,比如hmac(sha1)表示用SHA1摘要实现的HMAC算法,cbc(aes)表示使用AES的CBC模式,authenc(hmac(sha1),cbc(aes))表示使用AES-CBC加解密和SHA1做认证的链式算法,即一次完成加密和认证。

如何使用Linux密码模块

使用Linux密码模块的流程如下图所示:

左侧为流程分割,右侧为对应的实现函数。

用户层调用Linux内核密码模块的方法

用户层调用Linux内核密码模块的方法有两种,一种是cryptodev,另一种是AF_ALG。

cryptodev

  • 据说性能超过AF_ALG
  • 使用内核密码模块内标准接口
  • 将设备暴露在/dev/crypto目录下
  • 使用ioctl函数设置密码运算上下文
  • 在OpenSSL里原生支持

AF_ALG

  • 在Linux 2.6.38版本后支持
  • 主要通过netlink套接字实现

如何开发一个密码引擎驱动

开发一个密码引擎驱动的流程

1、Linux内核密码模块并不区分硬件引擎与软件实现

2、开发一个密码引擎就只是通过向密码模块子系统注册crypto_alg

3、辨别你想新增算法的类型并与相关的crypto_alg接口绑定,比如skcipher_alg,ahash_alg等等

4、实现xxx_alg接口内容并调用crypto_register_xxx()来向密码子系统注册

以cbc(aes)算法为例的实际代码示例

struct skcipher_alg xxx_cbc_aes_alg = {
    ...
    .base = {
        /* Name used by the framework to find who is implementing what. */
        .cra_name = "cbc(aes)",
        /* Driver name. Can be used to request a specific implementation of an algorithm. */
        .cra_driver_name = "xxx-cbc-aes",
        /* Priority is used when implementation auto-selection takes place:
         * if there are several implementers, the one with the highest priority is chosen.
         * By convention: HW engine > ASM/arch-optimized > plain C
         */
        .cra_priority = 300,
        /* CRYPTO_ALG_TYPE_XX: describes the type algorithm implemented here
         * CRYPTO_ALG_ASYNC: the engine is operating in an asynchronous manner
         * CRYPTO_ALG_KERN_DRIVER_ONLY: engine is not directly accessible to userspace
         */
        .cra_flags = CRYPTO_ALG_TYPE_SKCIPHER | CRYPTO_ALG_KERN_DRIVER_ONLY | CRYPTO_ALG_ASYNC,
        /* Size of the data blocks this algo operates on. */
        .cra_blocksize = AES_BLOCK_SIZE,
        /* Size of the context attached to an algorithm instance. */
        .cra_ctxsize = sizeof(struct xxx_aes_ctx),
        /* constructor/destructor methods called every time an alg instance is created/destroyed. */
        .cra_init = xxx_skcipher_cra_init,
        .cra_exit = xxx_skcipher_cra_exit,
    },
};

struct skcipher_alg mv_cesa_cbc_aes_alg = {
    /* Set key implementation. */
    .setkey = xxx_aes_setkey,
    /* Encrypt/decrypt implementation. */
    .encrypt = xxx_cbc_aes_encrypt,
    .decrypt = xxx_cbc_aes_decrypt,
    /* Symmetric key size. */
    .min_keysize = AES_MIN_KEY_SIZE,
    .max_keysize = AES_MAX_KEY_SIZE,
    /* IV size */
    .ivsize = AES_BLOCK_SIZE,
    .base = {
        ....
    },
};

static int xxx_encrypt(struct skcipher_request *req)
{
    struct my_ctx *ctx = crypto_tfm_ctx(req->base.tfm);
    /* Prepare and queue the request here. Return 0 if the request has
     * been executed, -EINPROGRESS if it's been queued, -EBUSY if it's
     * been backlogged or a different error code for other kind of
     * errors.
     */
    return ret;
}

static int xxx_decrypt(struct skcipher_request *req)
{
    struct my_ctx *ctx = crypto_tfm_ctx(req->base.tfm);
    /* Similar to xxx_encrypt() except this time we prepare and queue
     * a decrypt operation.
     */
    return ret;
}

static int xxx_setkey(struct crypto_skcipher *cipher, const u8 *key,
unsigned int len)
{
    struct my_ctx *ctx = crypto_tfm_ctx(req->base.tfm);
    /* Expand key and assing store the result in the ctx. */
    return ret;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1194351.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Pycharm常用快捷键和替换正则表达式

原生快捷键的使用: 1.CtrlF:查找 2.CtrlZ:返回上一步 3.Alt 鼠标左键选择:多行同时编辑(上、下、左、右键能够移动光标) 按住Ctrl,左键点击,定位光标 编辑过程 URL常用的替换正则表达式&am…

从小白到测试专家:掌握Pytest的实用技巧和优秀实践

pytest是一个功能丰富且易于使用的Python测试框架,它建立在Python标准库的unittest模块之上,提供了更简洁、灵活和可读性强的测试代码编写方式。下面,我将按照步骤引导您学习pytest。 步骤1:安装pytest 首先,您需要安装…

python3.8及以上版本绑定gdal库的一个注意事项

作者:朱金灿 来源:clever101的专栏 为什么大多数人学不会人工智能编程?>>> gdal和python绑定参考文章:windows环境下python和gdal绑定方法   值得注意的是绑定python3.8及以上版本后在python程序中初始化gdal库时会出…

自媒体项目详述

总体框架 本项目主要着手于获取最新最热新闻资讯,以微服务构架为技术基础搭建校内仅供学生教师使用的校园新媒体app。以文章为主线的核心业务主要分为如下子模块。自媒体模块实现用户创建功能、文章发布功能、素材管理功能。app端用户模块实现文章搜索、文章点赞、…

Qt QTableWidget表格的宽度

默认值 QTableWIdget的表格宽度默认是一个给定值,可以手动调整每列的宽度,也不填满父窗口 MainWindow::MainWindow(QWidget *parent): QMainWindow(parent) {this->resize(800,600);QStringList contents{"11","111111111111",&…

ios 对话框 弹框,输入对话框 普通对话框

1 普通对话框 UIAlertController* alert [UIAlertController alertControllerWithTitle:"a" message:"alert12222fdsfs" pr…

Springboot自动装配(SPI技术、@Import动态加载配置类)

SpringBoot原理 起步依赖 依赖传递,a依赖b,b依赖c 自动配置 Springboot的自动配置就是当Spring容器启动后,一些配置类、bean对象就自动存入到了IOC容器中,不用手动配置了 Springboot采用的是EnableXXXX注解,分装…

带你一分钟看懂 “Docker”

2010年,几个搞IT的年轻人,在美国旧金山成立了一家名叫“dotCloud”的公司。 这家公司主要提供基于PaaS的云计算技术服务。具体来说,是和LXC有关的容器技术。 后来,dotCloud公司将自己的容器技术进行了简化和标准化,并…

腾讯云优惠券是什么?详细介绍及领取攻略来了!

1、腾讯云优惠券介绍 腾讯云优惠券是腾讯云推出的一种优惠活动,包括代金券和折扣券。代金券是可抵扣费用的优惠券,可以在结算时使用代金券抵扣订单金额。折扣券可以在结算时使用享受一定的折扣优惠。 2、腾讯云优惠券领取 领取入口:txy.in…

Bond配置文件配置

1、选择2个自己需要的网口,查看有哪些网口 [roothostname ~]# ifconfig -a [roothostname ~]#systemctl disable NetworkManager 开机不启动图形化网络服务 2、编辑网口的配置文件 [roothostname ~]# cd /etc/sysconfig/network-scripts [roothostname n…

GPT最佳实践:五分钟打造你自己的GPT

前几天OpenAI的My GPTs栏目还是灰色的,就在今天已经开放使用了。有幸第一时间体验了一把生成自己的GPT,效果着实惊艳!!!我打造的GPT模型我会放到文章末尾,大家感兴趣也可以自己体验一下。 打造自己的GPT模型…

竞赛选题 深度学习疲劳检测 驾驶行为检测 - python opencv cnn

文章目录 0 前言1 课题背景2 相关技术2.1 Dlib人脸识别库2.2 疲劳检测算法2.3 YOLOV5算法 3 效果展示3.1 眨眼3.2 打哈欠3.3 使用手机检测3.4 抽烟检测3.5 喝水检测 4 最后 0 前言 🔥 优质竞赛项目系列,今天要分享的是 🚩 **基于深度学习加…

RedisDesktopManager连接不上redis的解决方法

RedisDesktopManager连接不上redis的解决方法 RedisDesktopManager是一款连接redis数据库的客户端。 当连接不上redis的时候,解决方案: 第一步:在自己的本机外面试下,能不能连接上虚拟机 打开cmd,使用ping 虚拟机ip地址。如果…

[PyTorch][chapter 61][强化学习-免模型学习 off-policy]

前言: 蒙特卡罗的学习基本流程: Policy Evaluation : 生成动作-状态轨迹,完成价值函数的估计。 Policy Improvement: 通过价值函数估计来优化policy。 同策略(one-policy):产生 采样轨迹的策略 和要改…

ros1 基础学习10 -全局字典参数的定义,获取,改值

全局字典参数的定义,获取,改值 一、参数模型二、 创建功能包三、参数命令行的使用(rosparam)四、使用程序来使用参数(C)4.1创建代码4.2编译4.3 编译文件 测试 在ROS Master中,存在一个参数服务器(Parameter…

MPSO-WPA

MPSO-WPA算法 DCAP means ’ discretized Cauchy’s argument principle’ 辅助信息 作者未提供代码

使用github copilot

现在的大模型的应用太广了,作为程序员我们当然野可以借助大模型来帮我们敲代码。 下面是自己注册使用github copilot的过程。 一、注册github copilot 1. 需要拥有github账号 ,登录github之后,点右侧自己的头像位置,下面会出现…

【Linux网络】手把手实操Linux系统网络服务DHCP

目录 一、什么是dhcp 二、详解dhcp的工作原理 三、dhcp的实操 第一步:3台机器的防火墙和安全机制都需要关闭!!! 第二步:Linux下载dhcp软件,并查看配置文件位置 第三步:读配置文件&#xf…

(二十七)ATP应用测试平台——基于mybatisplus和aop切面实现数据权限隔离的案例实战

前言 在实际项目开发中,我们经常会用到俩种权限,一种是功能权限,一种是数据权限。功能权限主要是用来限制用户的操作,而数据权限是限制用户能查看到哪些数据。功能权限我们可以使用流行的框架shiro或者spring-security实现&#…

智慧在线拜佛上供品花供果祈福求愿公众号开发

智慧在线拜佛上供品花供果祈福求愿公众号开发 在线点灯祈福:用户可以在线选择点灯祈福的数量和供养的香灯类型,进行祈福祈愿。 上供品花:用户可以选择不同的鲜花供养,包括鲜花种类、数量和价值,以及写上心愿祝福语。 …