Request for PC-side GMAC example for S32K344 Basic Secure Boot

取消
显示结果 
显示  仅  | 搜索替代 
您的意思是: 
已解决

Request for PC-side GMAC example for S32K344 Basic Secure Boot

跳至解决方案
1,424 次查看
mws
Contributor I

Hello NXP Team,

I’m testing Basic Secure Boot on S32K344. I have extended the sample image S32K344_SecureBootBlinky.bin (AppBootHeader + App) to 0x40 + 0x1000 bytes. I’m trying to write a PC-side GMAC calculation tool so that the tag I compute matches what HSE produces, but so far I cannot obtain the same GMAC tag as HSE.

Could you please provide a PC-side reference implementation (any language is fine; C or Python would be ideal) that reproduces the HSE GMAC for Basic Secure Boot?

Because I cannot share my actual IV and ADKP, please feel free to choose arbitrary test values. A minimal package with:

  • Short test payload (binary),

  • Example ADKP (16 bytes) and the exact key derivation used by Basic Secure Boot,

  • IV (12 bytes),

  • Expected GMAC tag (16 bytes),

  • And the required image layout (including where/how to place IV and tag at the end)
    would be perfect.

Attachment: my extended S32K344_SecureBootBlinky binary (AppBootHeader + App = 0x40 + 0x1000).

If there is already an official PC-side example or a validated test vector for S32K344 Basic Secure Boot, a link or zip would be greatly appreciated.

Thank you for your support!

0 项奖励
回复
1 解答
1,370 次查看
lukaszadrapa
NXP TechSupport
NXP TechSupport

Hi @mws 

This is not something what we should provide but I spent some time on this because it's useful for me too. See attached python script. It contains ADKP (it's the same as in HSE_DemoExamples because I have already programmed this on my board). Then it expects file image.bin (pure binary format). It should contain the header+image+IV. The result can be found in generated gmac_tag.txt. 

It works on my side, I got the same GMAC as generated by HSE using service hseBootDataImageSignSrv_t. I reused example S32K344_Basic_SecureBoot which uses hseBootDataImageSignSrv_t to generate IV and GMAC. And it also programs it behind the image. Then I just exported header+image+IV to binary file and use that to develop the script. When calculating GMAC externally, user needs to provide the IV. You can either provide IV in the bin file as I did or you can change the script as necessary. 

Regards,

Lukas

在原帖中查看解决方案

0 项奖励
回复
2 回复数
1,371 次查看
lukaszadrapa
NXP TechSupport
NXP TechSupport

Hi @mws 

This is not something what we should provide but I spent some time on this because it's useful for me too. See attached python script. It contains ADKP (it's the same as in HSE_DemoExamples because I have already programmed this on my board). Then it expects file image.bin (pure binary format). It should contain the header+image+IV. The result can be found in generated gmac_tag.txt. 

It works on my side, I got the same GMAC as generated by HSE using service hseBootDataImageSignSrv_t. I reused example S32K344_Basic_SecureBoot which uses hseBootDataImageSignSrv_t to generate IV and GMAC. And it also programs it behind the image. Then I just exported header+image+IV to binary file and use that to develop the script. When calculating GMAC externally, user needs to provide the IV. You can either provide IV in the bin file as I did or you can change the script as necessary. 

Regards,

Lukas

0 项奖励
回复
1,234 次查看
mws
Contributor I
it's work! thanks
0 项奖励
回复
%3CLINGO-SUB%20id%3D%22lingo-sub-2156856%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%E7%B4%A2%E5%8F%96%20S32K344%20%E5%9F%BA%E6%9C%AC%E5%AE%89%E5%85%A8%E5%90%AF%E5%8A%A8%E7%9A%84%20PC%20%E7%AB%AF%20GMAC%20%E7%A4%BA%E4%BE%8B%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2156856%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E6%82%A8%E5%A5%BD%EF%BC%8CNXP%E5%9B%A2%E9%98%9F%EF%BC%8C%3C%2FP%3E%3CP%3E%E6%88%91%E6%AD%A3%E5%9C%A8%20%3CSTRONG%3ES32K344%3C%2FSTRONG%3E%20%E4%B8%8A%E6%B5%8B%E8%AF%95%3CSTRONG%3E%E5%9F%BA%E6%9C%AC%E5%AE%89%E5%85%A8%E5%90%AF%E5%8A%A8%3C%2FSTRONG%3E%E3%80%82%E6%88%91%E5%B7%B2%E5%B0%86%E7%A4%BA%E4%BE%8B%E5%9B%BE%E5%83%8F%20%3CSTRONG%3ES32K344_SecureBootBlinky.bin%3C%2FSTRONG%3E%EF%BC%88AppBootHeader%20%2B%20App%EF%BC%89%E6%89%A9%E5%B1%95%E5%88%B0%20%3CSTRONG%3E0x40%20%2B%200x%3C%2FSTRONG%3E%201000%20%E5%AD%97%E8%8A%82%E3%80%82%E6%88%91%E6%AD%A3%E5%9C%A8%E5%B0%9D%E8%AF%95%E7%BC%96%E5%86%99%E4%B8%80%E4%B8%AA%3CSTRONG%3EPC%20%E7%AB%AF%20GMAC%20%E8%AE%A1%E7%AE%97%E5%B7%A5%E5%85%B7%3C%2FSTRONG%3E%EF%BC%8C%E4%BB%A5%E4%BE%BF%E6%88%91%E8%AE%A1%E7%AE%97%E5%87%BA%E7%9A%84%E6%A0%87%E7%AD%BE%E4%B8%8E%20HSE%20%E7%94%9F%E6%88%90%E7%9A%84%E6%A0%87%E7%AD%BE%E4%B8%80%E8%87%B4%EF%BC%8C%E4%BD%86%E5%88%B0%E7%9B%AE%E5%89%8D%E4%B8%BA%E6%AD%A2%EF%BC%8C%E6%88%91%E6%97%A0%E6%B3%95%E8%8E%B7%E5%BE%97%E4%B8%8E%20HSE%20%E7%9B%B8%E5%90%8C%E7%9A%84%20GMAC%20%E6%A0%87%E7%AD%BE%E3%80%82%3C%2FP%3E%3CP%3E%E4%BD%A0%E8%83%BD%E5%90%A6%E6%8F%90%E4%BE%9B%E4%B8%80%E4%B8%AA%E9%87%8D%E7%8E%B0%E5%9F%BA%E6%9C%AC%E5%AE%89%E5%85%A8%E5%90%AF%E5%8A%A8%E7%9A%84%20HSE%20GMAC%20%E7%9A%84%3CSTRONG%3E%20PC%3C%2FSTRONG%3E%20%E7%AB%AF%E5%8F%82%E8%80%83%E5%AE%9E%E7%8E%B0%EF%BC%88%E4%BB%BB%E4%BD%95%E8%AF%AD%E8%A8%80%E9%83%BD%E5%8F%AF%E4%BB%A5%EF%BC%9BC%20%E6%88%96%20Python%20%E6%9C%80%E7%90%86%E6%83%B3%EF%BC%89%EF%BC%9F%3C%2FP%3E%3CP%3E%E7%94%B1%E4%BA%8E%E6%88%91%E6%97%A0%E6%B3%95%E5%88%86%E4%BA%AB%E6%88%91%E7%9A%84%E5%AE%9E%E9%99%85%20IV%3CSTRONG%3E%E5%80%BC%3C%2FSTRONG%3E%E5%92%8C%20ADKP%20%E5%80%BC%EF%BC%8C%E8%AF%B7%E9%9A%8F%E6%84%8F%E9%80%89%E6%8B%A9%E6%B5%8B%E8%AF%95%E5%80%BC%E3%80%82%E5%8C%85%E5%90%AB%E4%BB%A5%E4%B8%8B%E5%86%85%E5%AE%B9%E7%9A%84%E6%9C%80%E5%B0%8F%E5%A5%97%E9%A4%90%EF%BC%9A%3C%2FP%3E%3CUL%3E%3CLI%3E%3CP%3E%E7%9F%AD%E6%B5%8B%E8%AF%95%E6%9C%89%E6%95%88%E8%BD%BD%E8%8D%B7%EF%BC%88%E4%BA%8C%E8%BF%9B%E5%88%B6%EF%BC%89%EF%BC%8C%3C%2FP%3E%3C%2FLI%3E%3CLI%3E%3CP%3E%E7%A4%BA%E4%BE%8B%20%3CSTRONG%3EADKP%3C%2FSTRONG%3E%EF%BC%8816%20%E5%AD%97%E8%8A%82%EF%BC%89%E5%92%8C%E5%9F%BA%E6%9C%AC%E5%AE%89%E5%85%A8%E5%90%AF%E5%8A%A8%E4%BD%BF%E7%94%A8%E7%9A%84%E7%A1%AE%E5%88%87%3CSTRONG%3E%E5%AF%86%E9%92%A5%E6%B4%BE%E7%94%9F%3C%2FSTRONG%3E%EF%BC%8C%3C%2FP%3E%3C%2FLI%3E%3CLI%3E%3CP%3E%3CSTRONG%3EIV%3C%2FSTRONG%3E%EF%BC%8812%20%E5%AD%97%E8%8A%82%EF%BC%89%EF%BC%8C%3C%2FP%3E%3C%2FLI%3E%3CLI%3E%3CP%3E%E9%A2%84%E6%9C%9F%3CSTRONG%3E%E7%9A%84%20GMAC%20%E6%A0%87%E7%AD%BE%3C%2FSTRONG%3E%EF%BC%8816%20%E5%AD%97%E8%8A%82%EF%BC%89%EF%BC%8C%3C%2FP%3E%3C%2FLI%3E%3CLI%3E%3CP%3E%E8%80%8C%3CSTRONG%3E%E6%89%80%E9%9C%80%E7%9A%84%E5%9B%BE%E7%89%87%E5%B8%83%E5%B1%80%3C%2FSTRONG%3E%EF%BC%88%E5%8C%85%E6%8B%AC%E5%9C%A8%E4%BD%95%E5%A4%84%2F%E5%A6%82%E4%BD%95%E5%9C%A8%E6%9C%AB%E5%B0%BE%E6%94%BE%E7%BD%AE%20IV%20%E5%92%8C%E6%A0%87%E7%AD%BE%EF%BC%89%3CBR%20%2F%3E%E5%B0%86%E6%98%AF%E5%AE%8C%E7%BE%8E%E7%9A%84%E3%80%82%3C%2FP%3E%3C%2FLI%3E%3C%2FUL%3E%3CP%3E%3CSTRONG%3E%E9%99%84%E4%BB%B6%EF%BC%9A%3C%2FSTRONG%3E%E6%88%91%E7%9A%84%E6%89%A9%E5%B1%95%E7%89%88%20s32k344_secureBootBlinky%20%E4%BA%8C%E8%BF%9B%E5%88%B6%E6%96%87%E4%BB%B6%EF%BC%88AppBootHeader%20%2B%20App%20%3D%200x40%20%2B%200x1000%EF%BC%89%E3%80%82%3C%2FP%3E%3CP%3E%E5%A6%82%E6%9E%9C%E5%B7%B2%E7%BB%8F%E6%9C%89%20S32K344%20Basic%20Secure%20%E5%90%AF%E5%8A%A8%20%E7%9A%84%E5%AE%98%E6%96%B9%20PC%20%E7%AB%AF%E7%A4%BA%E4%BE%8B%E6%88%96%E7%BB%8F%E8%BF%87%E9%AA%8C%E8%AF%81%E7%9A%84%E6%B5%8B%E8%AF%95%E5%90%91%E9%87%8F%EF%BC%8C%E5%A6%82%E6%9C%89%E9%93%BE%E6%8E%A5%E6%88%96%20zip%EF%BC%8C%E5%B0%86%E4%B8%8D%E8%83%9C%E6%84%9F%E6%BF%80%E3%80%82%3C%2FP%3E%3CP%3E%E6%84%9F%E8%B0%A2%E6%82%A8%E7%9A%84%E6%94%AF%E6%8C%81%EF%BC%81%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-2161638%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%20translate%3D%22no%22%3ERe%3A%20Request%20for%20PC-side%20GMAC%20example%20for%20S32K344%20Basic%20Secure%20Boot%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2161638%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%E5%AE%83%E7%9A%84%E5%B7%A5%E4%BD%9C%EF%BC%81%E8%B0%A2%E8%B0%A2%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-2157544%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%20translate%3D%22no%22%3ERe%3A%20Request%20for%20PC-side%20GMAC%20example%20for%20S32K344%20Basic%20Secure%20Boot%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2157544%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E4%BD%A0%E5%A5%BD%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fuser%2Fviewprofilepage%2Fuser-id%2F254028%22%20target%3D%22_blank%22%3E%40mws%3C%2FA%3E%3C%2FP%3E%0A%3CP%3E%E8%BF%99%E4%B8%8D%E6%98%AF%E6%88%91%E4%BB%AC%E5%BA%94%E8%AF%A5%E6%8F%90%E4%BE%9B%E7%9A%84%E4%B8%9C%E8%A5%BF%EF%BC%8C%E4%BD%86%E6%88%91%E8%8A%B1%E4%BA%86%E4%B8%80%E4%BA%9B%E6%97%B6%E9%97%B4%E5%9C%A8%E8%BF%99%E4%B8%8A%E9%9D%A2%EF%BC%8C%E5%9B%A0%E4%B8%BA%E5%AE%83%E5%AF%B9%E6%88%91%E4%B9%9F%E5%BE%88%E6%9C%89%E7%94%A8%E3%80%82%E8%AF%B7%E5%8F%82%E8%A7%81%E6%89%80%E9%99%84%E7%9A%84%20python%20%E8%84%9A%E6%9C%AC%E3%80%82%E5%AE%83%E5%8C%85%E5%90%AB%20ADKP%EF%BC%88%E4%B8%8E%20HSE_DemoExamples%20%E4%B8%AD%E7%9A%84%E7%9B%B8%E5%90%8C%EF%BC%8C%E5%9B%A0%E4%B8%BA%E6%88%91%E5%B7%B2%E7%BB%8F%E5%9C%A8%E6%9D%BF%E4%B8%8A%E5%AF%B9%E5%85%B6%E8%BF%9B%E8%A1%8C%E4%BA%86%E7%BC%96%E7%A8%8B%EF%BC%89%E3%80%82%E7%84%B6%E5%90%8E%E5%AE%83%E9%9C%80%E8%A6%81%E6%96%87%E4%BB%B6%20image.bin%EF%BC%88%E7%BA%AF%E4%BA%8C%E8%BF%9B%E5%88%B6%E6%A0%BC%E5%BC%8F%EF%BC%89%E3%80%82%E5%AE%83%E5%BA%94%E5%8C%85%E5%90%AB%E9%A1%B5%E7%9C%89%2B%E5%9B%BE%E5%83%8F%2BIV%E3%80%82%E7%BB%93%E6%9E%9C%E5%8F%AF%E5%9C%A8%E7%94%9F%E6%88%90%E7%9A%84%20gmac_tag.txt%20%E4%B8%AD%E6%89%BE%E5%88%B0%E3%80%82%20%3C%2FP%3E%0A%3CP%3E%E5%AE%83%E5%9C%A8%E6%88%91%E8%BF%99%E8%BE%B9%E8%B5%B7%E4%BD%9C%E7%94%A8%EF%BC%8C%E6%88%91%E5%BE%97%E5%88%B0%E7%9A%84%20GMAC%20%E4%B8%8E%20HSE%20%E4%BD%BF%E7%94%A8%E6%9C%8D%E5%8A%A1%20hsebootdataimagesignsrv_T%20%E7%94%9F%E6%88%90%E7%9A%84%20GMAC%20%E7%9B%B8%E5%90%8C%E3%80%82%E6%88%91%E9%87%8D%E5%A4%8D%E4%BD%BF%E7%94%A8%E4%BA%86%E7%A4%BA%E4%BE%8B%20s32k344_basic_secureBoot%EF%BC%8C%E5%AE%83%E4%BD%BF%E7%94%A8%20hsebootdataimagesignsrv_T%20%E7%94%9F%E6%88%90%20IV%20%E5%92%8C%20GMAC%E3%80%82%E5%AE%83%E8%BF%98%E8%83%BD%E5%9C%A8%E5%9B%BE%E5%83%8F%E8%83%8C%E5%90%8E%E8%BF%9B%E8%A1%8C%E7%BC%96%E7%A8%8B%E3%80%82%E7%84%B6%E5%90%8E%E6%88%91%E5%B0%86%E6%A0%87%E9%A2%98%2B%E5%9B%BE%E5%83%8F%2BIV%20%E5%AF%BC%E5%87%BA%E5%88%B0%E4%BA%8C%E8%BF%9B%E5%88%B6%E6%96%87%E4%BB%B6%E5%B9%B6%E7%94%A8%E5%AE%83%E6%9D%A5%E5%BC%80%E5%8F%91%E8%84%9A%E6%9C%AC%E3%80%82%E5%9C%A8%E5%A4%96%E9%83%A8%E8%AE%A1%E7%AE%97%20GMAC%20%E6%97%B6%EF%BC%8C%E7%94%A8%E6%88%B7%E9%9C%80%E8%A6%81%E6%8F%90%E4%BE%9B%20IV%E3%80%82%E6%82%A8%E5%8F%AF%E4%BB%A5%E5%83%8F%E6%88%91%E4%B8%80%E6%A0%B7%E5%9C%A8%20bin%20%E6%96%87%E4%BB%B6%E4%B8%AD%E6%8F%90%E4%BE%9B%20IV%EF%BC%8C%E4%B9%9F%E5%8F%AF%E4%BB%A5%E6%A0%B9%E6%8D%AE%E9%9C%80%E8%A6%81%E4%BF%AE%E6%94%B9%E8%84%9A%E6%9C%AC%E3%80%82%20%3C%2FP%3E%0A%3CP%3E%E6%AD%A4%E8%87%B4%EF%BC%8C%3C%2FP%3E%0A%3CP%3ELukas%3C%2FP%3E%3C%2FLINGO-BODY%3E