免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2028 | 回复: 4
打印 上一主题 下一主题

[内核入门] 求助关于内核MD5摘要算法的crypto框架实现 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-08-10 10:32 |只看该作者 |倒序浏览
查看前辈们的资料得知,要首先通过crypto_alloc_tfm()来分配一个加密函数对象的实例。初始化这些实例,然后就可以通过框架提供的API对数据进行加密和解密。完成以后,必须通过crypto_free_tfm()撤销实例。
按照前辈们的攻略,头文件为:
#include <linux/kernel.h>#include <linux/module.h>#include <linux/crypto.h>#include <linux/scatterlist.h>#include <linux/gfp.h>#include <linux/err.h>#include <linux/syscalls.h>#include <linux/slab.h>
然而我按照网上的实例编译的时候,发现系统给出了几个错误,疑似缺少某头文件:
error: implicit declaration of function ‘crypto_alloc_tfm’
error: implicit declaration of function ‘crypto_digest_init’
error: implicit declaration of function ‘crypto_digest_update’
error: implicit declaration of function ‘crypto_digest_final’
也就是说,这些接口函数都没有声明,然后我又去查这些头文件,并没有发现有这些函数。可是奇怪的是,我查看了对应位置一个demo,其里面居然也有调用这4个函数!
我起初以为是内核没有加载crypto,但是查看了内核模块之后,发现内核确实有加载这些模块,包括shal,md4,md5等等摘要算法都已经加载进去;
之后我觉得可能是内核版本的问题,但是我从复古版的2.6版本到比较新的3.18选择性的尝试了一些,然而都无济于是。
Makefile文件如下
obj-m := test.
KERNELDIR ?= /lib/modules/$(shell uname -r)/build
PWD := $(shell pwd
all:
$(MAKE) -C $(KERNELDIR) M=$(PWD)
clean:
rm -rf *.o *~ core .depend .*.cmd *.ko *.mod.c .tmp_versions
内核用的是2.6.32版本,内核源码中有crypto的函数,其中api.c中定义了crypto_alloc_tfm:
void *crypto_alloc_tfm(const char *alg_name,
                       const struct crypto_type *frontend, u32 type, u32 mask)
{
        void *tfm;
        int err;
        for (; {
                struct crypto_alg *alg;

                alg = crypto_find_alg(alg_name, frontend, type, mask);
                if (IS_ERR(alg)) {
                        err = PTR_ERR(alg);
                        goto err;
                }
                tfm = crypto_create_tfm(alg, frontend);
                if (!IS_ERR(tfm))
                        return tfm;
                crypto_mod_put(alg);
                err = PTR_ERR(tfm);
err:
                if (err != -EAGAIN)
                        break;
                if (signal_pending(current)) {
                        err = -EINTR;
                        break;
                }
        }
        return ERR_PTR(err);
}
求助大侠们解答,感激不尽

论坛徽章:
20
程序设计版块每日发帖之星
日期:2015-08-17 06:20:00程序设计版块每日发帖之星
日期:2016-07-16 06:20:00程序设计版块每日发帖之星
日期:2016-07-18 06:20:00每日论坛发贴之星
日期:2016-07-18 06:20:00黑曼巴
日期:2016-12-26 16:00:3215-16赛季CBA联赛之江苏
日期:2017-06-26 11:05:5615-16赛季CBA联赛之上海
日期:2017-07-21 18:12:5015-16赛季CBA联赛之青岛
日期:2017-09-04 17:32:0515-16赛季CBA联赛之吉林
日期:2018-03-26 10:02:16程序设计版块每日发帖之星
日期:2016-07-15 06:20:0015-16赛季CBA联赛之江苏
日期:2016-07-07 18:37:512015亚冠之萨济拖拉机
日期:2015-08-17 12:21:08
2 [报告]
发表于 2015-08-10 11:52 |只看该作者
本帖最后由 nswcfd 于 2015-08-10 11:53 编辑

#include <linux/crypto.h>
+
MODULE_LICENSE("GPL");
  1. //test@2.6.18
  2. #include <linux/module.h>
  3. #include <linux/crypto.h>

  4. int init(void)
  5. {
  6.         crypto_alloc_tfm("do_not_exist_should_return_error", 0);
  7.         return -1;
  8. }

  9. module_init(init);
  10. MODULE_LICENSE("GPL");
复制代码

论坛徽章:
0
3 [报告]
发表于 2015-08-10 16:48 |只看该作者
回复 2# nswcfd
请教一下 这个是什么意思?

   

论坛徽章:
0
4 [报告]
发表于 2015-08-10 16:51 |只看该作者
我发现问题了,crypto.h里面提供的借口函数和api.c里面的不一样,之后我把代码修改成这样,但是每次生成的md5摘要都不一样,求解是怎么一回事?
  1. char *do_digest(char * code) {
  2.     char *result;
  3.     int code_len = strlen(code);
  4.    
  5.         tfm = crypto_alloc_hash("md5",0,CRYPTO_ALG_ASYNC);
  6.         if(IS_ERR(tfm))
  7.                 return 0;
  8.         desc = (struct hash_desc *)kmalloc(sizeof(struct hash_desc),GFP_KERNEL);
  9.         desc->tfm = tfm;
  10.         desc->flags = 0;
  11.         sg_init_one(sg,code,code_len);

  12.         crypto_hash_init(desc);
  13.         crypto_hash_update(desc,sg,1);
  14.     result = (char *)kmalloc(sizeof(char)*50,GFP_KERNEL);
  15.     if(result == NULL) {
  16.         crypto_free_hash(tfm);
  17.         return 0;
  18.     }
  19.     memset(result,0,sizeof(char)*50);
  20.     crypto_hash_final(desc,result);
  21.         crypto_free_hash(tfm);
  22.     return result;
  23. }
复制代码

论坛徽章:
20
程序设计版块每日发帖之星
日期:2015-08-17 06:20:00程序设计版块每日发帖之星
日期:2016-07-16 06:20:00程序设计版块每日发帖之星
日期:2016-07-18 06:20:00每日论坛发贴之星
日期:2016-07-18 06:20:00黑曼巴
日期:2016-12-26 16:00:3215-16赛季CBA联赛之江苏
日期:2017-06-26 11:05:5615-16赛季CBA联赛之上海
日期:2017-07-21 18:12:5015-16赛季CBA联赛之青岛
日期:2017-09-04 17:32:0515-16赛季CBA联赛之吉林
日期:2018-03-26 10:02:16程序设计版块每日发帖之星
日期:2016-07-15 06:20:0015-16赛季CBA联赛之江苏
日期:2016-07-07 18:37:512015亚冠之萨济拖拉机
日期:2015-08-17 12:21:08
5 [报告]
发表于 2015-08-11 15:52 |只看该作者
回复 3# 奋斗的大菜鸟

不好意思,忘了写说明了,是说可以正常编译和加载模块,没有出现符号找不到的信息,说明内核里面是有这些符号的,在编译层面没有问题,只是用法的问题而已。



   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP