内核加密机制及应用

内核加密机制

  • linux 3.3.8

总体框架

仅显示关键结构

这里写图片描述

内核加密机制在内核中保存两个全局链表crypto_template_listcrypto_alg_list

  • crypto_template_list 保存所有的加密方式

    • e.g cbc ecb
  • crypto_alg_list 保存所有的加密算法

    • e.g md5 sha128 aes

crypto_template_list由各个算法通过crypto_register_template函数添加到链表中

crypto_alg_list由各个算法通过crypto_register_alg函数添加到链表中

数据结构说明

crypto_alg结构可以理解为真正保存加密接口的一个通用结构

  • struct list_head cra_users;

    指向crypto_spawn结构所在的链表

  • union cra_u;

    union {
    struct ablkcipher_alg ablkcipher;
      struct aead_alg aead;
    struct blkcipher_alg blkcipher;
    struct cipher_alg cipher;
    struct compress_alg compress;
    struct rng_alg rng;
    } cra_u;

    xxxxxx_alg结构体说明

    保存实际算法实现的函数接口和算法相关信息

    • blkcipher_alg
    struct blkcipher_alg {
      int (* setkey) (struct crypto_tfm *tfm, const u8 *key,unsigned int keylen);
      int (* encrypt) (struct blkcipher_desc *desc,struct scatterlist *dst, struct scatterlist *src,unsigned int nbytes);
      int (* decrypt) (struct blkcipher_desc *desc,struct scatterlist *dst, struct scatterlist *src,unsigned int nbytes);
      const char * geniv;
      unsigned int min_keysize;
      unsigned int max_keysize;
      unsigned int ivsize;
    };
  • 2
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: LPC1768是一种微控制器芯片,可以运行嵌入式应用程序。为了保护这些应用程序的安全性,在应用程序加载时对其进行加密是一种常见的做法。 应用程序加密的方法有很多,其中一种常见的方法是使用加密算法对应用程序进行加密。常见的加密算法包括AES、DES和RSA等。此外,还可以使用数字签名和认证机制来确保应用程序的完整性和身份验证。 在进行应用程序加密时,需要注意以下几点: 1. 选择适合的加密算法:根据应用程序的安全要求和系统资源限制,选择最适合的加密算法进行加密。 2. 存储密钥:加密算法需要使用密钥进行加密和解密,因此需要合理地存储密钥,并保证密钥的安全性。 3. 解密过程:需要在LPC1768芯片上加入解密模块,并根据实际情况调整程序的解密流程。解密模块需要保护好密钥,以免被恶意攻击者盗取。 应用程序加密可以有效地保护系统的安全性,但同时也会增加系统的复杂性和成本。因此,在应用程序加密时,需要充分考虑安全要求和实际可行性,权衡利弊,选择最佳方案。 ### 回答2: LPC1768是一款ARM Cortex-M3内核的微控制器,它是由恩智浦(NXP)公司生产的。LPC1768的应用程序(app)加密是指对在此芯片上开发的应用程序进行保护,防止未经授权的访问和修改。 应用程序加密有多种方法,以下是可能用于LPC1768的一些常见加密技术: 1. 代码混淆:通过对应用程序代码进行混淆,使其难以理解和分析。这可以通过重命名变量和函数名、添加冗余代码、优化代码结构等手段实现。 2. 加密编译:通过使用加密算法对应用程序进行编译,生成加密后的二进制文件。在运行时,需要解密才能正确执行。 3. 软件加密:使用专门的加密算法对应用程序进行加密,将其转换为加密格式的文件。在运行时,需要解密并还原为可执行文件才能运行。 4. 芯片级加密:LPC1768内置了硬件加密引擎,可以使用其提供的加密功能对应用程序进行加密。这种加密方式通常基于对称或非对称加密算法,并需要使用密钥进行加解密操作。 无论使用哪种加密方法,应用程序的安全性也与密钥的管理相关。在LPC1768中,需要注意密钥的存储、分发和使用方式,以保证加密的有效性。 总之,LPC1768的应用程序加密是保护开发的应用程序免受未经授权访问和修改的一种技术手段。通过使用合适的加密方法和密钥管理,可以有效提高应用程序的安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值