日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 >

Linux kernel内核调用crypto算法的方法

發(fā)布時間:2025/3/21 49 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Linux kernel内核调用crypto算法的方法 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

快速鏈接:
.
👉👉👉 個人博客筆記導(dǎo)讀目錄(全部) 👈👈👈


相關(guān)推薦:
The Armv8 Cryptographic Extension在Linux Kernel中的應(yīng)用
Armv8 Cryptographic Extension介紹
Linux Kernel aarch64 Crypto原理和框架介紹
Linux Kernel aarch64的ARM-CE aes-ecb的底層代碼解析


說明: 在無特別的說明下,本文講述得都是armv8-aarch64體系、linux kernel 4.14 arm64軟件環(huán)境!

文章目錄

        • 1、定義一個算法
        • 2、注冊crypto算法
        • 3、crypto算法的查找
        • 4、算法調(diào)用的示例

1、定義一個算法

Linux Kernel中crypto算法的定義是以crypto_alg結(jié)構(gòu)體來實現(xiàn)的

{.cra_name = "__ecb-aes-" MODE,.cra_driver_name = "__driver-ecb-aes-" MODE,.cra_priority = 0,.cra_flags = CRYPTO_ALG_TYPE_BLKCIPHER |CRYPTO_ALG_INTERNAL,.cra_blocksize = AES_BLOCK_SIZE,.cra_ctxsize = sizeof(struct crypto_aes_ctx),.cra_alignmask = 7,.cra_type = &crypto_blkcipher_type,.cra_module = THIS_MODULE,.cra_blkcipher = {.min_keysize = AES_MIN_KEY_SIZE,.max_keysize = AES_MAX_KEY_SIZE,.ivsize = 0,.setkey = aes_setkey,.encrypt = ecb_encrypt,.decrypt = ecb_decrypt,},

2、注冊crypto算法

注冊一個算法(algapi.c),crypto_alg_list鏈表維護(hù)著一些列crypto_alg結(jié)構(gòu)體

int crypto_register_alg(struct crypto_alg *alg) {struct crypto_larval *larval;int err;alg->cra_flags &= ~CRYPTO_ALG_DEAD;err = crypto_check_alg(alg);if (err)return err;down_write(&crypto_alg_sem);larval = __crypto_register_alg(alg);up_write(&crypto_alg_sem);if (IS_ERR(larval))return PTR_ERR(larval);crypto_wait_for_test(larval);return 0; } EXPORT_SYMBOL_GPL(crypto_register_alg);

3、crypto算法的查找

根據(jù)名字查詢一個算法(api.c),返回crypto_alg

struct crypto_alg *crypto_alg_lookup(const char *name, u32 type, u32 mask) {struct crypto_alg *alg;down_read(&crypto_alg_sem);alg = __crypto_alg_lookup(name, type, mask);up_read(&crypto_alg_sem);return alg; } EXPORT_SYMBOL_GPL(crypto_alg_lookup);

4、算法調(diào)用的示例

(以tcrypt為例)
而在tcrypt.c的測試模塊中,可根據(jù)名字,直接調(diào)用crypto_alg接口模塊

test_cipher_speed("ecb(aes)", ENCRYPT, sec, NULL, 0,speed_template_16_24_32);test_cipher_speed("ecb(aes)", DECRYPT, sec, NULL, 0,speed_template_16_24_32);test_cipher_speed("cbc(aes)", ENCRYPT, sec, NULL, 0,speed_template_16_24_32);test_cipher_speed("cbc(aes)", DECRYPT, sec, NULL, 0,speed_template_16_24_32);test_cipher_speed("lrw(aes)", ENCRYPT, sec, NULL, 0,speed_template_32_40_48);test_cipher_speed("lrw(aes)", DECRYPT, sec, NULL, 0,speed_template_32_40_48);test_cipher_speed("xts(aes)", ENCRYPT, sec, NULL, 0,speed_template_32_48_64);test_cipher_speed("xts(aes)", DECRYPT, sec, NULL, 0,speed_template_32_48_64);test_cipher_speed("ctr(aes)", ENCRYPT, sec, NULL, 0,speed_template_16_24_32);test_cipher_speed("ctr(aes)", DECRYPT, sec, NULL, 0,speed_template_16_24_32);

總結(jié)

以上是生活随笔為你收集整理的Linux kernel内核调用crypto算法的方法的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。