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

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

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

ソリューションへジャンプ
665件の閲覧回数
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 解決策
612件の閲覧回数
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 返答(返信)
613件の閲覧回数
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 件の賞賛
返信
476件の閲覧回数
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%3ES32K344%20%E5%9F%BA%E6%9C%AC%E3%82%BB%E3%82%AD%E3%83%A5%E3%82%A2%E3%83%96%E3%83%BC%E3%83%88%E3%81%AE%20PC%20%E5%81%B4%20GMAC%20%E3%81%AE%E4%BE%8B%E3%81%AE%E3%83%AA%E3%82%AF%E3%82%A8%E3%82%B9%E3%83%88%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2156856%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3ENXP%E3%83%81%E3%83%BC%E3%83%A0%E3%81%AE%E7%9A%86%E6%A7%98%E3%80%81%E3%81%93%E3%82%93%E3%81%AB%E3%81%A1%E3%81%AF%E3%80%82%3C%2FP%3E%3CP%3E%3CSTRONG%3ES32K344%3C%2FSTRONG%3E%E3%81%A7%3CSTRONG%3E%E5%9F%BA%E6%9C%AC%E7%9A%84%E3%81%AA%E3%82%BB%E3%82%AD%E3%83%A5%E3%82%A2%20%E3%83%96%E3%83%BC%E3%83%88%3C%2FSTRONG%3E%E3%82%92%E3%83%86%E3%82%B9%E3%83%88%E3%81%97%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%E3%82%B5%E3%83%B3%E3%83%97%E3%83%AB%E3%82%A4%E3%83%A1%E3%83%BC%E3%82%B8%3CSTRONG%3ES32K344_SecureBootBlinky.bin%3C%2FSTRONG%3E%20(AppBootHeader%20%2B%20App)%20%E3%82%92%3CSTRONG%3E0x40%20%2B%200x1000%3C%2FSTRONG%3E%E3%83%90%E3%82%A4%E3%83%88%E3%81%AB%E6%8B%A1%E5%BC%B5%E3%81%97%E3%81%BE%E3%81%97%E3%81%9F%E3%80%82%E8%A8%88%E7%AE%97%E3%81%97%E3%81%9F%E3%82%BF%E3%82%B0%E3%81%8C%20HSE%20%E3%81%8C%E7%94%9F%E6%88%90%E3%81%97%E3%81%9F%E3%82%82%E3%81%AE%E3%81%A8%E4%B8%80%E8%87%B4%E3%81%99%E3%82%8B%E3%82%88%E3%81%86%E3%81%AB%3CSTRONG%3EPC%20%E5%81%B4%E3%81%AE%20GMAC%20%E8%A8%88%E7%AE%97%E3%83%84%E3%83%BC%E3%83%AB%E3%82%92%3C%2FSTRONG%3E%E4%BD%9C%E6%88%90%E3%81%97%E3%82%88%E3%81%86%E3%81%A8%E3%81%97%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%E3%81%8C%E3%80%81%E4%BB%8A%E3%81%AE%E3%81%A8%E3%81%93%E3%82%8D%20HSE%20%E3%81%A8%E5%90%8C%E3%81%98%20GMAC%20%E3%82%BF%E3%82%B0%E3%82%92%E5%8F%96%E5%BE%97%E3%81%A7%E3%81%8D%E3%81%BE%E3%81%9B%E3%82%93%E3%80%82%3C%2FP%3E%3CP%3E%E5%9F%BA%E6%9C%AC%E7%9A%84%E3%81%AA%E3%82%BB%E3%82%AD%E3%83%A5%E3%82%A2%20%E3%83%96%E3%83%BC%E3%83%88%E3%81%AE%20HSE%20GMAC%20%E3%82%92%E5%86%8D%E7%8F%BE%E3%81%99%E3%82%8B%3CSTRONG%3EPC%20%E5%81%B4%E3%81%AE%E3%83%AA%E3%83%95%E3%82%A1%E3%83%AC%E3%83%B3%E3%82%B9%E5%AE%9F%E8%A3%85%3C%2FSTRONG%3E(%E3%81%A9%E3%81%AE%E8%A8%80%E8%AA%9E%E3%81%A7%E3%82%82%E6%A7%8B%E3%81%84%E3%81%BE%E3%81%9B%E3%82%93%E3%81%8C%E3%80%81C%20%E3%81%BE%E3%81%9F%E3%81%AF%20Python%20%E3%81%8C%E7%90%86%E6%83%B3%E7%9A%84%E3%81%A7%E3%81%99)%20%E3%82%92%E6%8F%90%E4%BE%9B%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%3C%2FP%3E%3CP%3E%E5%AE%9F%E9%9A%9B%E3%81%AE%20IV%20%E3%81%A8%20ADKP%20%E3%82%92%E5%85%B1%E6%9C%89%E3%81%A7%E3%81%8D%E3%81%AA%E3%81%84%E3%81%9F%E3%82%81%E3%80%81%3CSTRONG%3E%E4%BB%BB%E6%84%8F%E3%81%AE%E3%83%86%E3%82%B9%E3%83%88%E5%80%A4%E3%82%92%E8%87%AA%E7%94%B1%E3%81%AB%E9%81%B8%E6%8A%9E%E3%81%97%E3%81%A6%3C%2FSTRONG%3E%E3%81%8F%E3%81%A0%E3%81%95%E3%81%84%E3%80%82%E4%BB%A5%E4%B8%8B%E3%82%92%E5%90%AB%E3%82%80%E6%9C%80%E5%B0%8F%E9%99%90%E3%81%AE%E3%83%91%E3%83%83%E3%82%B1%E3%83%BC%E3%82%B8%3A%3C%2FP%3E%3CUL%3E%3CLI%3E%3CP%3E%E7%9F%AD%E3%81%84%E3%83%86%E3%82%B9%E3%83%88%E3%83%9A%E3%82%A4%E3%83%AD%E3%83%BC%E3%83%89%EF%BC%88%E3%83%90%E3%82%A4%E3%83%8A%E3%83%AA%EF%BC%89%3C%2FP%3E%3C%2FLI%3E%3CLI%3E%3CP%3E%3CSTRONG%3EADKP%3C%2FSTRONG%3E%20%EF%BC%8816%E3%83%90%E3%82%A4%E3%83%88%EF%BC%89%E3%81%AE%E4%BE%8B%E3%81%A8%E3%80%81Basic%20Secure%20Boot%E3%81%A7%E4%BD%BF%E7%94%A8%E3%81%95%E3%82%8C%E3%82%8B%E6%AD%A3%E7%A2%BA%E3%81%AA%3CSTRONG%3E%E3%82%AD%E3%83%BC%E5%B0%8E%E5%87%BA%3C%2FSTRONG%3E%E3%80%82%3C%2FP%3E%3C%2FLI%3E%3CLI%3E%3CP%3E%3CSTRONG%3EIV%3C%2FSTRONG%3E%20%EF%BC%8812%E3%83%90%E3%82%A4%E3%83%88%EF%BC%89%E3%80%81%3C%2FP%3E%3C%2FLI%3E%3CLI%3E%3CP%3E%E4%BA%88%E6%83%B3%E3%81%95%E3%82%8C%E3%82%8B%3CSTRONG%3EGMAC%E3%82%BF%E3%82%B0%3C%2FSTRONG%3E%EF%BC%8816%E3%83%90%E3%82%A4%E3%83%88%EF%BC%89%3C%2FP%3E%3C%2FLI%3E%3CLI%3E%3CP%3E%3CSTRONG%3E%E5%BF%85%E8%A6%81%E3%81%AA%E7%94%BB%E5%83%8F%E3%83%AC%E3%82%A4%E3%82%A2%E3%82%A6%E3%83%88%3C%2FSTRONG%3E%EF%BC%88%E6%9C%AB%E5%B0%BE%E3%81%ABIV%E3%81%A8%E3%82%BF%E3%82%B0%E3%82%92%E9%85%8D%E7%BD%AE%E3%81%99%E3%82%8B%E5%A0%B4%E6%89%80%E3%81%A8%E6%96%B9%E6%B3%95%E3%82%92%E5%90%AB%E3%82%80%EF%BC%89%3CBR%20%2F%3E%E5%AE%8C%E7%92%A7%E3%81%A7%E3%81%97%E3%82%87%E3%81%86%E3%80%82%3C%2FP%3E%3C%2FLI%3E%3C%2FUL%3E%3CP%3E%3CSTRONG%3E%E6%B7%BB%E4%BB%98%E3%83%95%E3%82%A1%E3%82%A4%E3%83%AB%3A%3C%2FSTRONG%3E%E6%8B%A1%E5%BC%B5%E3%81%95%E3%82%8C%E3%81%9F%20S32K344_SecureBootBlinky%20%E3%83%90%E3%82%A4%E3%83%8A%E3%83%AA%20(AppBootHeader%20%2B%20App%20%3D%200x40%20%2B%200x1000)%E3%80%82%3C%2FP%3E%3CP%3ES32K344%20%E5%9F%BA%E6%9C%AC%E3%82%BB%E3%82%AD%E3%83%A5%E3%82%A2%20%E3%83%96%E3%83%BC%E3%83%88%E7%94%A8%E3%81%AE%E5%85%AC%E5%BC%8F%E3%81%AE%20PC%20%E5%81%B4%E3%81%AE%E4%BE%8B%E3%81%BE%E3%81%9F%E3%81%AF%E6%A4%9C%E8%A8%BC%E6%B8%88%E3%81%BF%E3%81%AE%E3%83%86%E3%82%B9%E3%83%88%20%E3%83%99%E3%82%AF%E3%83%88%E3%83%AB%E3%81%8C%E3%81%99%E3%81%A7%E3%81%AB%E5%AD%98%E5%9C%A8%E3%81%99%E3%82%8B%E5%A0%B4%E5%90%88%E3%81%AF%E3%80%81%E3%83%AA%E3%83%B3%E3%82%AF%E3%81%BE%E3%81%9F%E3%81%AF%20zip%20%E3%82%92%E6%8F%90%E4%BE%9B%E3%81%97%E3%81%A6%E3%81%84%E3%81%9F%E3%81%A0%E3%81%91%E3%82%8C%E3%81%B0%E5%B9%B8%E3%81%84%E3%81%A7%E3%81%99%E3%80%82%3C%2FP%3E%3CP%3E%E3%82%B5%E3%83%9D%E3%83%BC%E3%83%88%E3%81%82%E3%82%8A%E3%81%8C%E3%81%A8%E3%81%86%E3%81%94%E3%81%96%E3%81%84%E3%81%BE%E3%81%99%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%E3%81%9D%E3%82%8C%E3%81%AF%E4%BB%95%E4%BA%8B%E3%81%A7%E3%81%99%EF%BC%81%E3%81%82%E3%82%8A%E3%81%8C%E3%81%A8%E3%81%86%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%E3%81%93%E3%82%93%E3%81%AB%E3%81%A1%E3%81%AF%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%E3%81%93%E3%82%8C%E3%81%AF%E7%A7%81%E3%81%9F%E3%81%A1%E3%81%8C%E6%8F%90%E4%BE%9B%E3%81%99%E3%81%B9%E3%81%8D%E3%82%82%E3%81%AE%E3%81%A7%E3%81%AF%E3%81%82%E3%82%8A%E3%81%BE%E3%81%9B%E3%82%93%E3%81%8C%E3%80%81%E7%A7%81%E3%81%AB%E3%81%A8%E3%81%A3%E3%81%A6%E3%82%82%E5%BD%B9%E7%AB%8B%E3%81%A4%E3%81%9F%E3%82%81%E3%80%81%E3%81%93%E3%82%8C%E3%81%AB%E6%99%82%E9%96%93%E3%82%92%E8%B2%BB%E3%82%84%E3%81%97%E3%81%BE%E3%81%97%E3%81%9F%E3%80%82%E6%B7%BB%E4%BB%98%E3%81%AE%20Python%20%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%97%E3%83%88%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%E3%81%93%E3%82%8C%E3%81%AB%E3%81%AF%20ADKP%20%E3%81%8C%E5%90%AB%E3%81%BE%E3%82%8C%E3%81%A6%E3%81%84%E3%81%BE%E3%81%99%20(%E3%81%93%E3%82%8C%E3%81%AF%E3%81%99%E3%81%A7%E3%81%AB%E3%83%9C%E3%83%BC%E3%83%89%E4%B8%8A%E3%81%A7%E3%83%97%E3%83%AD%E3%82%B0%E3%83%A9%E3%83%A0%E3%81%95%E3%82%8C%E3%81%A6%E3%81%84%E3%82%8B%E3%81%9F%E3%82%81%E3%80%81HSE_DemoExamples%20%E3%81%A8%E5%90%8C%E3%81%98%E3%81%A7%E3%81%99)%E3%80%82%E6%AC%A1%E3%81%AB%E3%80%81%E3%83%95%E3%82%A1%E3%82%A4%E3%83%AB%20image.bin%20(%E7%B4%94%E7%B2%8B%E3%81%AA%E3%83%90%E3%82%A4%E3%83%8A%E3%83%AA%E5%BD%A2%E5%BC%8F)%20%E3%82%92%E6%83%B3%E5%AE%9A%E3%81%97%E3%81%BE%E3%81%99%E3%80%82%E3%83%98%E3%83%83%E3%83%80%E3%83%BC%2B%E7%94%BB%E5%83%8F%2BIV%E3%82%92%E5%90%AB%E3%82%81%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%E7%B5%90%E6%9E%9C%E3%81%AF%E7%94%9F%E6%88%90%E3%81%95%E3%82%8C%E3%81%9F%20gmac_tag.txt%20%E3%81%AB%E3%81%82%E3%82%8A%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%0A%3CP%3E%E7%A7%81%E3%81%AE%E7%92%B0%E5%A2%83%E3%81%A7%E3%81%AF%E5%95%8F%E9%A1%8C%E3%81%AA%E3%81%8F%E5%8B%95%E4%BD%9C%E3%81%97%E3%80%81HSE%E3%81%8ChseBootDataImageSignSrv_t%E3%82%B5%E3%83%BC%E3%83%93%E3%82%B9%E3%82%92%E4%BD%BF%E3%81%A3%E3%81%A6%E7%94%9F%E6%88%90%E3%81%97%E3%81%9F%E3%82%82%E3%81%AE%E3%81%A8%E5%90%8C%E3%81%98GMAC%E3%82%92%E5%8F%96%E5%BE%97%E3%81%A7%E3%81%8D%E3%81%BE%E3%81%97%E3%81%9F%E3%80%82hseBootDataImageSignSrv_t%E3%82%92%E4%BD%BF%E3%81%A3%E3%81%A6IV%E3%81%A8GMAC%E3%82%92%E7%94%9F%E6%88%90%E3%81%99%E3%82%8B%E3%82%B5%E3%83%B3%E3%83%97%E3%83%ABS32K344_Basic_SecureBoot%E3%82%92%E5%86%8D%E5%88%A9%E7%94%A8%E3%81%97%E3%81%BE%E3%81%97%E3%81%9F%E3%80%82%E3%81%BE%E3%81%9F%E3%80%81%E7%94%BB%E5%83%8F%E3%81%AE%E8%83%8C%E5%BE%8C%E3%81%AB%E3%83%97%E3%83%AD%E3%82%B0%E3%83%A9%E3%83%A0%E3%81%99%E3%82%8B%E3%81%93%E3%81%A8%E3%82%82%E3%81%A7%E3%81%8D%E3%81%BE%E3%81%99%E3%80%82%E6%AC%A1%E3%81%AB%E3%80%81%E3%83%98%E3%83%83%E3%83%80%E3%83%BC%20%2B%20%E7%94%BB%E5%83%8F%20%2B%20IV%20%E3%82%92%E3%83%90%E3%82%A4%E3%83%8A%E3%83%AA%20%E3%83%95%E3%82%A1%E3%82%A4%E3%83%AB%E3%81%AB%E3%82%A8%E3%82%AF%E3%82%B9%E3%83%9D%E3%83%BC%E3%83%88%E3%81%97%E3%80%81%E3%81%9D%E3%82%8C%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%A6%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%97%E3%83%88%E3%82%92%E9%96%8B%E7%99%BA%E3%81%97%E3%81%BE%E3%81%97%E3%81%9F%E3%80%82GMAC%20%E3%82%92%E5%A4%96%E9%83%A8%E3%81%A7%E8%A8%88%E7%AE%97%E3%81%99%E3%82%8B%E5%A0%B4%E5%90%88%E3%80%81%E3%83%A6%E3%83%BC%E3%82%B6%E3%83%BC%E3%81%AF%20IV%20%E3%82%92%E6%8F%90%E4%BE%9B%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%E7%A7%81%E3%81%8C%E8%A1%8C%E3%81%A3%E3%81%9F%E3%82%88%E3%81%86%E3%81%AB%E3%80%81bin%20%E3%83%95%E3%82%A1%E3%82%A4%E3%83%AB%E3%81%A7%20IV%20%E3%82%92%E6%8F%90%E4%BE%9B%E3%81%99%E3%82%8B%E3%81%93%E3%81%A8%E3%82%82%E3%80%81%E5%BF%85%E8%A6%81%E3%81%AB%E5%BF%9C%E3%81%98%E3%81%A6%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%97%E3%83%88%E3%82%92%E5%A4%89%E6%9B%B4%E3%81%99%E3%82%8B%E3%81%93%E3%81%A8%E3%82%82CAN%E3%80%82%3C%2FP%3E%0A%3CP%3E%E3%82%88%E3%82%8D%E3%81%97%E3%81%8F%E3%81%8A%E9%A1%98%E3%81%84%E3%81%84%E3%81%9F%E3%81%97%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%0A%3CP%3E%E3%83%AB%E3%83%BC%E3%82%AB%E3%82%B9%3C%2FP%3E%3C%2FLINGO-BODY%3E