Linux加密API SHA1

时间:2017-06-27 10:16:14

标签: linux api cryptography kernel sha1

我尝试使用Linux Crypto API在内核模块中计算sha1哈希,但是我找不到有关如何设置异步请求使用的分散列表的信息。另外,我应该如何等待异步操作完成?

static int plaintext_to_sha1(void) {

    struct scatterlist sg[8];
    struct crypto_ahash *tfm;
    struct ahash_request *req;

    char *plaintext = "TEST!\0";
    unsigned char *result = kmalloc(sizeof(unsigned char) * SHA1_LENGTH, GFP_KERNEL);
    unsigned int len = strlen(plaintext);

    tfm = crypto_alloc_ahash("sha1", 0, CRYPTO_ALG_ASYNC);
    if (IS_ERR(tfm)) {
        printk(KERN_ERR "tfm allocation failed\n");
        return -1;
    }

    /* ... set up the scatterlists ... */

    req = ahash_request_alloc(tfm, GFP_ATOMIC);
    if (!req) {
        printk(KERN_ERR "request allocation failed\n");
        return -1;
    }

    ahash_request_set_callback(req, 0, NULL, NULL);
    ahash_request_set_crypt(req, sg, result, 2);

    if (crypto_ahash_digest(req)) {
        printk(KERN_ERR "digest failed\n");
        return -1;
    }

    ahash_request_free(req);
    crypto_free_ahash(tfm);

    return 0;
}

0 个答案:

没有答案