Perform AES-GCM encryption and decryption of plaintext using the CAAM hardware on the LS1028A board

キャンセル
次の結果を表示 
表示  限定  | 次の代わりに検索 
もしかして: 

Perform AES-GCM encryption and decryption of plaintext using the CAAM hardware on the LS1028A board

ソリューションへジャンプ
669件の閲覧回数
Sweet
Contributor I
I am developing a Security Engine (CAAM) driver for a Layerscape board. I’m currently looking for guidance or source code references for the following operation:
 
I want to create a black key and use it for AES-GCM encryption/decryption of plaintext.
I am already able to generate a black key successfully using AES-CCM. However, I need to encrypt and decrypt the plaintext using the AES-GCM algorithm, and I'm unable to find any example code or clear steps to build the required job descriptor.
 
While the Linux kernel source includes code to construct shared descriptors, I need to create a non-shared (simple) descriptor for this operation.
 
Additionally, could someone please explain how the black key is properly used to encrypt and decrypt data using AES-GCM? Specifically:
 
- How to load the black key and key modifier in the descriptor.
- How the CAAM uses this key internally for GCM encryption/decryption.
 
Any reference links or working examples would be greatly appreciated.

 

0 件の賞賛
返信
1 解決策
494件の閲覧回数
Sweet
Contributor I
0 件の賞賛
返信
2 返答(返信)
632件の閲覧回数
Oswalag
NXP TechSupport
NXP TechSupport

Hello,

You can find a reference of how to generate a black key.

GitHub - nxp-imx/keyctl_caam: Keyctl CAAM Security

DPDK default supports AES_GCM in dpaa sec driver. You can refer to DPDK source code on descriptor building in DPAA_SEC_AEAD case.
DPDK/drivers/crypto/dpaa_sec/dpaa_sec.c

You can also find more information in the LS1028ASECRM

0 件の賞賛
返信
495件の閲覧回数
Sweet
Contributor I
0 件の賞賛
返信
%3CLINGO-SUB%20id%3D%22lingo-sub-2137506%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3ELS1028A%E3%83%9C%E3%83%BC%E3%83%89%E4%B8%8A%E3%81%AECAAM%E3%83%8F%E3%83%BC%E3%83%89%E3%82%A6%E3%82%A7%E3%82%A2%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%A6%E3%80%81%E3%83%97%E3%83%AC%E3%83%BC%E3%83%B3%E3%83%86%E3%82%AD%E3%82%B9%E3%83%88%E3%81%AEAES-GCM%E6%9A%97%E5%8F%B7%E5%8C%96%E3%81%A8%E5%BE%A9%E5%8F%B7%E5%8C%96%E3%82%92%E5%AE%9F%E8%A1%8C%E3%81%97%E3%81%BE%E3%81%99%E3%80%82%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2137506%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CDIV%3E%E7%A7%81%E3%81%AFLayerscape%E3%83%9C%E3%83%BC%E3%83%89%E7%94%A8%E3%81%AE%E3%82%BB%E3%82%AD%E3%83%A5%E3%83%AA%E3%83%86%E3%82%A3%E3%82%A8%E3%83%B3%E3%82%B8%E3%83%B3(CAAM)%E3%83%89%E3%83%A9%E3%82%A4%E3%83%90%E3%82%92%E9%96%8B%E7%99%BA%E3%81%97%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%E7%8F%BE%E5%9C%A8%E3%80%81%E6%AC%A1%E3%81%AE%E6%93%8D%E4%BD%9C%E3%81%AB%E9%96%A2%E3%81%99%E3%82%8B%E3%82%AC%E3%82%A4%E3%83%80%E3%83%B3%E3%82%B9%E3%81%BE%E3%81%9F%E3%81%AF%E3%82%BD%E3%83%BC%E3%82%B9%20%E3%82%B3%E3%83%BC%E3%83%89%E3%81%AE%E5%8F%82%E7%85%A7%E3%82%92%E6%8E%A2%E3%81%97%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%E3%83%96%E3%83%A9%E3%83%83%E3%82%AF%E3%82%AD%E3%83%BC%E3%82%92%E4%BD%9C%E6%88%90%E3%81%97%E3%80%81%E3%81%9D%E3%82%8C%E3%82%92%E3%83%97%E3%83%AC%E3%83%BC%E3%83%B3%E3%83%86%E3%82%AD%E3%82%B9%E3%83%88%E3%81%AE%20AES-GCM%20%E6%9A%97%E5%8F%B7%E5%8C%96%2F%E5%BE%A9%E5%8F%B7%E5%8C%96%E3%81%AB%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%9F%E3%81%84%E3%81%A8%E8%80%83%E3%81%88%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%3C%2FDIV%3E%3CDIV%3E%E3%81%99%E3%81%A7%E3%81%AB%20AES-CCM%20%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%A6%E3%83%96%E3%83%A9%E3%83%83%E3%82%AF%20%E3%82%AD%E3%83%BC%E3%82%92%E6%AD%A3%E5%B8%B8%E3%81%AB%E7%94%9F%E6%88%90%E3%81%A7%E3%81%8D%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%E3%81%9F%E3%81%A0%E3%81%97%E3%80%81AES-GCM%20%E3%82%A2%E3%83%AB%E3%82%B4%E3%83%AA%E3%82%BA%E3%83%A0%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%A6%E3%83%97%E3%83%AC%E3%83%BC%E3%83%B3%E3%83%86%E3%82%AD%E3%82%B9%E3%83%88%E3%82%92%E6%9A%97%E5%8F%B7%E5%8C%96%E3%81%8A%E3%82%88%E3%81%B3%E5%BE%A9%E5%8F%B7%E5%8C%96%E3%81%99%E3%82%8B%E5%BF%85%E8%A6%81%E3%81%8C%E3%81%82%E3%82%8A%E3%81%BE%E3%81%99%E3%81%8C%E3%80%81%E5%BF%85%E8%A6%81%E3%81%AA%E3%82%B8%E3%83%A7%E3%83%96%E8%A8%98%E8%BF%B0%E5%AD%90%E3%82%92%E6%A7%8B%E7%AF%89%E3%81%99%E3%82%8B%E3%81%9F%E3%82%81%E3%81%AE%E3%82%B5%E3%83%B3%E3%83%97%E3%83%AB%20%E3%82%B3%E3%83%BC%E3%83%89%E3%82%84%E6%98%8E%E7%A2%BA%E3%81%AA%E6%89%8B%E9%A0%86%E3%81%8C%E8%A6%8B%E3%81%A4%E3%81%8B%E3%82%8A%E3%81%BE%E3%81%9B%E3%82%93%E3%80%82%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3ELinux%20%E3%82%AB%E3%83%BC%E3%83%8D%E3%83%AB%20%E3%82%BD%E3%83%BC%E3%82%B9%E3%81%AB%E3%81%AF%E5%85%B1%E6%9C%89%E8%A8%98%E8%BF%B0%E5%AD%90%E3%82%92%E6%A7%8B%E7%AF%89%E3%81%99%E3%82%8B%E3%81%9F%E3%82%81%E3%81%AE%E3%82%B3%E3%83%BC%E3%83%89%E3%81%8C%E5%90%AB%E3%81%BE%E3%82%8C%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%81%8C%E3%80%81%E3%81%93%E3%81%AE%E6%93%8D%E4%BD%9C%E3%81%A7%E3%81%AF%E9%9D%9E%E5%85%B1%E6%9C%89%20(%E5%8D%98%E7%B4%94)%20%E8%A8%98%E8%BF%B0%E5%AD%90%E3%82%92%E4%BD%9C%E6%88%90%E3%81%99%E3%82%8B%E5%BF%85%E8%A6%81%E3%81%8C%E3%81%82%E3%82%8A%E3%81%BE%E3%81%99%E3%80%82%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%E3%81%95%E3%82%89%E3%81%AB%E3%80%81AES-GCM%20%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%A6%E3%83%87%E3%83%BC%E3%82%BF%E3%82%92%E6%9A%97%E5%8F%B7%E5%8C%96%E3%81%8A%E3%82%88%E3%81%B3%E5%BE%A9%E5%8F%B7%E5%8C%96%E3%81%99%E3%82%8B%E3%81%9F%E3%82%81%E3%81%AB%E3%83%96%E3%83%A9%E3%83%83%E3%82%AF%20%E3%82%AD%E3%83%BC%E3%81%8C%E9%81%A9%E5%88%87%E3%81%AB%E4%BD%BF%E7%94%A8%E3%81%95%E3%82%8C%E3%82%8B%E6%96%B9%E6%B3%95%E3%81%AB%E3%81%A4%E3%81%84%E3%81%A6%E8%AA%AC%E6%98%8E%E3%81%97%E3%81%A6%E3%81%84%E3%81%9F%E3%81%A0%E3%81%91%E3%81%BE%E3%81%99%E3%81%8B%3F%E5%85%B7%E4%BD%93%E7%9A%84%E3%81%AB%E3%81%AF%EF%BC%9A%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E-%20%E8%A8%98%E8%BF%B0%E5%AD%90%E3%81%AB%E9%BB%92%E9%8D%B5%E3%81%A8%E3%82%AD%E3%83%BC%E4%BF%AE%E9%A3%BE%E5%AD%90%E3%82%92%E3%83%AD%E3%83%BC%E3%83%89%E3%81%99%E3%82%8B%E6%96%B9%E6%B3%95%E3%80%82%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%3CSPAN%3E-%20CAAM%20%E3%81%8C%20GCM%20%E3%81%AE%E6%9A%97%E5%8F%B7%E5%8C%96%2F%E5%BE%A9%E5%8F%B7%E5%8C%96%E3%81%AE%E3%81%9F%E3%82%81%E3%81%AB%E3%81%93%E3%81%AE%E3%82%AD%E3%83%BC%E3%82%92%E5%86%85%E9%83%A8%E7%9A%84%E3%81%AB%E3%81%A9%E3%81%AE%E3%82%88%E3%81%86%E3%81%AB%E4%BD%BF%E7%94%A8%E3%81%99%E3%82%8B%E3%81%8B%E3%80%82%3C%2FSPAN%3E%3C%2FDIV%3E%3CDIV%3E%26nbsp%3B%3C%2FDIV%3E%3CDIV%3E%E5%8F%82%E8%80%83%E3%83%AA%E3%83%B3%E3%82%AF%E3%82%84%E5%AE%9F%E9%9A%9B%E3%81%AE%E4%BE%8B%E3%81%8C%E3%81%82%E3%82%8C%E3%81%B0%E3%80%81%E3%81%9C%E3%81%B2%E6%95%99%E3%81%88%E3%81%A6%E3%81%8F%E3%81%A0%E3%81%95%E3%81%84%E3%80%82%3C%2FDIV%3E%3CBR%20%2F%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-2144152%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%20translate%3D%22no%22%3ERe%3A%20Perform%20AES-GCM%20encryption%20and%20decryption%20of%20plaintext%20using%20the%20CAAM%20hardware%20on%20the%20LS1028A%20bo%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2144152%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E3%81%82%E3%82%8A%E3%81%8C%E3%81%A8%E3%81%86%E3%80%81%20%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fuser%2Fviewprofilepage%2Fuser-id%2F199933%22%20target%3D%22_blank%22%3E%40Oswalag%3C%2FA%3E%3C%2FP%3E%3CP%3E%3CSTRONG%3E%E3%83%96%E3%83%A9%E3%83%83%E3%82%AF%20%E3%82%AD%E3%83%BC%3C%2FSTRONG%3E%E3%81%AB%E3%81%A4%E3%81%84%E3%81%A6%E3%81%AF%3CA%20href%3D%22https%3A%2F%2Fgitlab.navisincontrol.com%2Fvarigit%2Flinux-imx%2F-%2Fblob%2Flf-5.15.y_var01%2Fdrivers%2Fcrypto%2Fcaam%2Fcaamkeyblob.c%22%20target%3D%22_blank%22%20rel%3D%22nofollow%20noopener%20noreferrer%22%3Ehttps%3A%2F%2Fgitlab.navisincontrol.com%2Fvarigit%2Flinux-imx%2F-%2Fblob%2Flf-5.15.y_var01%2Fdrivers%2Fcrypto%2Fcaam%2Fcaamkeyblob.c%3C%2FA%3E%E3%81%A7%E3%80%81%20%3CSTRONG%3EAES-GCM%3C%2FSTRONG%3E%E3%81%AB%E3%81%A4%E3%81%84%E3%81%A6%E3%81%AF%3CA%20href%3D%22https%3A%2F%2Fgithub.com%2Fnxp-mcuxpresso%2Fmcux-sdk%2Fblob%2Fmain%2Fdrivers%2Fcaam%2Ffsl_caam.c%22%20target%3D%22_blank%22%20rel%3D%22nofollow%20noopener%20noreferrer%22%3Ehttps%3A%2F%2Fgithub.com%2Fnxp-mcuxpresso%2Fmcux-sdk%2Fblob%2Fmain%2Fdrivers%2Fcaam%2Ffsl_caam.c%3C%2FA%3E%E3%81%A7%E5%84%AA%E3%82%8C%E3%81%9F%E3%83%AA%E3%83%95%E3%82%A1%E3%83%AC%E3%83%B3%E3%82%B9%E3%82%92%E8%A6%8B%E3%81%A4%E3%81%91%E3%81%BE%E3%81%97%E3%81%9F%E3%80%82%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-2138480%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%20translate%3D%22no%22%3ERe%3A%20Perform%20AES-GCM%20encryption%20and%20decryption%20of%20plaintext%20using%20the%20CAAM%20hardware%20on%20the%20LS1028A%20bo%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2138480%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E3%81%93%E3%82%93%E3%81%AB%E3%81%A1%E3%81%AF%E3%80%81%3C%2FP%3E%0A%3CP%3E%E9%BB%92%E9%8D%B5%E3%82%92%E7%94%9F%E6%88%90%E3%81%99%E3%82%8B%E6%96%B9%E6%B3%95%E3%81%AB%E3%81%A4%E3%81%84%E3%81%A6%E3%81%AE%E3%83%AA%E3%83%95%E3%82%A1%E3%83%AC%E3%83%B3%E3%82%B9%E3%82%92CAN%E8%A6%8B%E3%81%A4%E3%81%91%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%0A%3CP%3E%3CA%20href%3D%22https%3A%2F%2Fgithub.com%2Fnxp-imx%2Fkeyctl_caam%22%20target%3D%22_blank%22%20rel%3D%22nofollow%20noopener%20noreferrer%22%3EGitHub%20-%20nxp-imx%2Fkeyctl_caam%3A%20Keyctl%20CAAM%20%E3%82%BB%E3%82%AD%E3%83%A5%E3%83%AA%E3%83%86%E3%82%A3%3C%2FA%3E%3C%2FP%3E%0A%3CP%3E%3CSPAN%3EDPDK%E3%81%AF%E3%83%87%E3%83%95%E3%82%A9%E3%83%AB%E3%83%88%E3%81%A7%E3%80%81dpaa%20sec%E3%83%89%E3%83%A9%E3%82%A4%E3%83%90%E3%81%A7AES_GCM%E3%82%92%E3%82%B5%E3%83%9D%E3%83%BC%E3%83%88%E3%81%97%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%80%82DPAA_SEC_AEAD%E3%81%AECASE%E3%81%AE%E8%A8%98%E8%BF%B0%E5%AD%90%E3%83%93%E3%83%AB%E3%83%87%E3%82%A3%E3%83%B3%E3%82%B0%E3%81%AB%E3%81%A4%E3%81%84%E3%81%A6%E3%81%AF%E3%80%81DPDK%E3%82%BD%E3%83%BC%E3%82%B9%E3%82%B3%E3%83%BC%E3%83%89%E3%82%92%E5%8F%82%E7%85%A7%E3%81%97%E3%81%A6%E3%81%8F%E3%81%A0%E3%81%95%E3%81%84%E3%80%82%3C%2FSPAN%3E%3CBR%20clear%3D%22none%22%20%2F%3E%3CSPAN%3EDPDK%2F%E3%83%89%E3%83%A9%E3%82%A4%E3%83%90%2F%E6%9A%97%E5%8F%B7%2Fdpaa_sec%2Fdpaa_sec.c%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%3E%3CSPAN%3E%3CA%20href%3D%22https%3A%2F%2Fwww.nxp.com%2Fwebapp%2FDownload%3FcolCode%3DLS1028ASECRM%22%20target%3D%22_self%22%20rel%3D%22nofollow%20noopener%20noreferrer%22%3ELS1028ASECRM%3C%2FA%3E%E3%81%A7%E3%82%82%E3%81%95%E3%82%89%E3%81%AB%E8%A9%B3%E3%81%97%E3%81%84%E6%83%85%E5%A0%B1%E3%82%92%E3%81%94%E8%A6%A7%E3%81%84%E3%81%9F%E3%81%A0%E3%81%91%E3%81%BE%E3%81%99%E3%80%82%3C%2FSPAN%3E%3C%2FP%3E%3C%2FLINGO-BODY%3E