Testing signed images

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

Testing signed images

跳至解决方案
2,034 次查看
eduardo3
Contributor III

Hello,

I am in the process of adding signed images to our board but I was left with questions on how to test that.

After getting a signed os_cntr_signed.bin image, it boots fine. On u-boot when I try ahab_status, I see SECO events (because I don't have my keys fused yet).

Initially I thought I could use u-boot fuse override for testing the fuse values I need to use, but that is not implemented. After searching on how to use fuse shadow registers, I found that it is not possible. Examples:

https://community.nxp.com/t5/i-MX-Processors/Access-to-OCOTP-registers-from-SCU-on-IMX8QM-leads-to-h...

https://community.nxp.com/t5/i-MX-Processors/IMX8-unable-to-override-OCOTP-shadow-registers-Is-there...

Initially If thought I could implement something like what is mentioned in the first link.

Based on that, how am I supposed to test secure boot keys / commands without permanently fusing the keys or bricking the board?

What is NXP advice on that?

For reference, we are using i.MX8X (imx8qxp).

 

0 项奖励
回复
1 解答
1,987 次查看
Bio_TICFSL
NXP TechSupport
NXP TechSupport

Hello,

If not burning the SRK fuse, you may can use OPENSSL command to analyze the images with their key.

 

Regards

在原帖中查看解决方案

0 项奖励
回复
3 回复数
1,958 次查看
eduardo3
Contributor III

I'll try the openssl approach in the future. Another FAE we contacted also confirmed there is no way of testing on a imx8 board without fusing the keys. His suggestion in that case was to fuse (if we are fine with that) but not close the device.

0 项奖励
回复
1,988 次查看
Bio_TICFSL
NXP TechSupport
NXP TechSupport

Hello,

If not burning the SRK fuse, you may can use OPENSSL command to analyze the images with their key.

 

Regards

0 项奖励
回复
366 次查看
imx8mp_developer
Contributor I

I am interested in this topic!
I need to verify the os_cntr_signed.bin container coming out from a Yocto AHAB-signed build for imx93

If I do:
~/cst-4.0.0/linux64/bin/ahab_image_verifier os_cntr_signed.bin 0 0


I get:

Signature Block:
 Version: 0
 Length: 2648 bytes
 Tag: 0x90
 Certificate Offset: 0x0
 SRK Table/Array Offset: 0x10
 SRK Table:
   Tag: 0xD7
   Length: 2112 bytes
   Version: 66
   SRK Record:
     Tag: 0xE1
     Length: 527 bytes
     Sign Algorithm: RSA       
     Hash Algorithm: SHA2_384       
     Key Size/Curve: RSA4096       
     SRK Flags: CA Flags       
     Modulus (N):
.....
Signature verification failed

This doesn't happen for imx-boot-imx93-var-som-aski-sd.bin-flash_singleboot_gdet

Signature Block:
 Version: 0
 Length: 400 bytes
 Tag: 0x90
 Certificate Offset: 0x0
 SRK Table/Array Offset: 0x10
 SRK Table:
   Tag: 0xD7
   Length: 308 bytes
   Version: 66
   SRK Record:
     Tag: 0xE1
     Length: 76 bytes
     Sign Algorithm: ECDSA       
     Hash Algorithm: SHA2_256       
     Key Size/Curve: PRIME256V1       
     SRK Flags: None       
     X Coordinate:  ....
     Y Coordinate:  ...

......

Signature verification successful

I am using a Digicert HSM for the signature

does anybody have a clue about the verification failed for os_cntr_signed ?
does anybody have a hint on how to verify the signature with openssl ?(just to exclude the issue is ahab_image_verifier itself)

0 项奖励
回复
%3CLINGO-SUB%20id%3D%22lingo-sub-1667502%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%E6%B5%8B%E8%AF%95%E7%AD%BE%E5%90%8D%E5%9B%BE%E5%83%8F%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1667502%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E4%BD%A0%E5%A5%BD%3C%2FP%3E%3CP%3E%E6%88%91%E6%AD%A3%E5%9C%A8%E5%90%91%E6%88%91%E4%BB%AC%E7%9A%84%E6%9D%BF%E6%B7%BB%E5%8A%A0%E7%AD%BE%E5%90%8D%E5%9B%BE%E7%89%87%EF%BC%8C%E4%BD%86%E6%88%91%E5%AF%B9%E5%A6%82%E4%BD%95%E6%B5%8B%E8%AF%95%E6%9C%89%E7%96%91%E9%97%AE%E3%80%82%3C%2FP%3E%3CP%3E%E8%8E%B7%E5%BE%97%E7%AD%BE%E5%90%8D%E7%9A%84%20os_cntr_signed.bin%20%E9%95%9C%E5%83%8F%E5%90%8E%EF%BC%8C%E5%90%AF%E5%8A%A8%E6%AD%A3%E5%B8%B8%E3%80%82%E5%9C%A8%20u-boot%20%E4%B8%AD%EF%BC%8C%E5%BD%93%E6%88%91%E5%B0%9D%E8%AF%95%20ahab_status%20%E6%97%B6%EF%BC%8C%E6%88%91%E4%BC%9A%E7%9C%8B%E5%88%B0%20SECO%20%E4%BA%8B%E4%BB%B6%EF%BC%88%E5%9B%A0%E4%B8%BA%E6%88%91%E8%BF%98%E6%B2%A1%E6%9C%89%E7%86%94%E4%B8%9D%E6%88%91%E7%9A%84%E5%AF%86%E9%92%A5%EF%BC%89%E3%80%82%3C%2FP%3E%3CP%3E%E8%B5%B7%E5%88%9D%E6%88%91%E4%BB%A5%E4%B8%BA%E6%88%91%E5%8F%AF%E4%BB%A5%E4%BD%BF%E7%94%A8%20u-boot%20%E7%86%94%E4%B8%9D%E8%A6%86%E7%9B%96%E6%9D%A5%E6%B5%8B%E8%AF%95%E6%88%91%E9%9C%80%E8%A6%81%E4%BD%BF%E7%94%A8%E7%9A%84%E7%86%94%E4%B8%9D%E5%80%BC%EF%BC%8C%E4%BD%86%E8%BF%99%E5%B9%B6%E6%B2%A1%E6%9C%89%E5%AE%9E%E7%8E%B0%E3%80%82%E5%9C%A8%E6%90%9C%E7%B4%A2%E4%BA%86%E5%A6%82%E4%BD%95%E4%BD%BF%E7%94%A8%E7%86%94%E4%B8%9D%E9%98%B4%E5%BD%B1%E5%AF%84%E5%AD%98%E5%99%A8%E4%B9%8B%E5%90%8E%EF%BC%8C%E6%88%91%E5%8F%91%E7%8E%B0%E8%BF%99%E6%98%AF%E4%B8%8D%E5%8F%AF%E8%83%BD%E7%9A%84%E3%80%82%E4%BE%8B%E5%A6%82%3C%2FP%3E%3CP%3E%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fi-MX-Processors%2FAccess-to-OCOTP-registers-from-SCU-on-IMX8QM-leads-to-hang%2Ftd-p%2F1335399%22%20target%3D%22_blank%22%3Ehttps%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fi-MX-Processors%2FAccess-to-OCOTP-registers-from-SCU-on-IMX8QM-leads-to-hang%2Ftd-p%2F1335399%3C%2FA%3E%3C%2FP%3E%3CP%3E%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fi-MX-Processors%2FIMX8-unable-to-override-OCOTP-shadow-registers-Is-there-a-way%2Ftd-p%2F1424010%22%20target%3D%22_blank%22%3Ehttps%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fi-MX-Processors%2FIMX8-unable-to-override-OCOTP-shadow-registers-Is-there-a-way%2Ftd-p%2F1424010%3C%2FA%3E%3C%2FP%3E%3CP%3E%E8%B5%B7%E5%88%9D%EF%BC%8C%E6%88%91%E4%BB%A5%E4%B8%BA%E5%8F%AF%E4%BB%A5%E5%AE%9E%E7%8E%B0%E7%AC%AC%E4%B8%80%E4%B8%AA%E9%93%BE%E6%8E%A5%E4%B8%AD%E6%8F%90%E5%88%B0%E7%9A%84%E5%8A%9F%E8%83%BD%E3%80%82%3C%2FP%3E%3CP%3E%E5%9F%BA%E4%BA%8E%E6%AD%A4%EF%BC%8C%E6%88%91%E5%BA%94%E8%AF%A5%E5%A6%82%E4%BD%95%E5%9C%A8%E4%B8%8D%E6%B0%B8%E4%B9%85%E7%86%94%E4%B8%9D%E5%AF%86%E9%92%A5%E6%88%96%E7%A0%B4%E5%9D%8F%E6%9D%BF%E7%9A%84%E6%83%85%E5%86%B5%E4%B8%8B%E6%B5%8B%E8%AF%95%E5%AE%89%E5%85%A8%E5%90%AF%E5%8A%A8%E5%AF%86%E9%92%A5%2F%E5%91%BD%E4%BB%A4%EF%BC%9F%3C%2FP%3E%3CP%3E%E6%81%A9%E6%99%BA%E6%B5%A6%E5%AF%B9%E6%AD%A4%E6%9C%89%E4%BD%95%E5%BB%BA%E8%AE%AE%EF%BC%9F%3C%2FP%3E%3CP%3E%E4%BD%9C%E4%B8%BA%E5%8F%82%E8%80%83%EF%BC%8C%E6%88%91%E4%BB%AC%E4%BD%BF%E7%94%A8%E7%9A%84%E6%98%AF%20i.mx8X%20(imx8qxp)%E3%80%82%3C%2FP%3E%3CBR%20%2F%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-2186760%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%20translate%3D%22no%22%3ERe%3A%20Testing%20signed%20images%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2186760%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E6%88%91%E5%AF%B9%E8%BF%99%E4%B8%AA%E8%AF%9D%E9%A2%98%E5%BE%88%E6%84%9F%E5%85%B4%E8%B6%A3%EF%BC%81%3CBR%20%2F%3E%E6%88%91%E9%9C%80%E8%A6%81%E9%AA%8C%E8%AF%81%3CSPAN%3E%E4%BB%8E%20Yocto%20AHAB%20%E7%AD%BE%E5%90%8D%E7%9A%84%20imx93%20%E7%89%88%E6%9C%AC%E4%B8%AD%E7%94%9F%E6%88%90%E7%9A%84%20os_cntr_signed.bin%20%E5%AE%B9%E5%99%A8%20%3CBR%20%2F%3E%3C%2FSPAN%3E%3C%2FP%3E%3CP%3E%3CSPAN%3E%E5%A6%82%E6%9E%9C%E6%88%91%E8%BF%99%E6%A0%B7%E5%81%9A%EF%BC%9A%3CBR%20%2F%3E~%2Fcst-4.0.0%2Flinux64%2Fbin%2Fahab_image_verifier%20os_cntr_signed.bin%200%200%3C%2FSPAN%3E%3C%2FP%3E%3CP%3E%3CSPAN%3E%3CBR%20%2F%3E%E6%88%91%E6%98%8E%E7%99%BD%E4%BA%86%EF%BC%9A%3C%2FSPAN%3E%3C%2FP%3E%3CP%3E%3CSPAN%3E%3CFONT%20color%3D%22%23999999%22%3E%E7%AD%BE%E5%90%8D%E5%9D%97%EF%BC%9A%3C%2FFONT%3E%3CBR%20%2F%3E%3CFONT%20color%3D%22%23999999%22%3E%20%E7%89%88%E6%9C%AC%EF%BC%9A%200%3C%2FFONT%3E%3CBR%20%2F%3E%3CFONT%20color%3D%22%23999999%22%3E%20%E9%95%BF%E5%BA%A6%EF%BC%9A%202648%20%E5%AD%97%E8%8A%82%3C%2FFONT%3E%3CBR%20%2F%3E%3CFONT%20color%3D%22%23999999%22%3E%20%E6%A0%87%E7%AD%BE%EF%BC%9A%200x90%3C%2FFONT%3E%3CBR%20%2F%3E%3CFONT%20color%3D%22%23999999%22%3E%20%E8%AF%81%E4%B9%A6%E5%81%8F%E7%A7%BB%E9%87%8F%EF%BC%9A0x0%3C%2FFONT%3E%3CBR%20%2F%3E%3CFONT%20color%3D%22%23999999%22%3E%20SRK%20%E8%A1%A8%2F%E6%95%B0%E7%BB%84%E5%81%8F%E7%A7%BB%E9%87%8F%EF%BC%9A0x%2010%3C%2FFONT%3E%3CBR%20%2F%3E%3CFONT%20color%3D%22%23999999%22%3E%20SRK%3C%2FFONT%3E%3CBR%20%2F%3E%3CFONT%20color%3D%22%23999999%22%3E%20%E8%A1%A8%EF%BC%9A%E6%A0%87%E7%AD%BE%EF%BC%9A0xD7%3C%2FFONT%3E%3CBR%20%2F%3E%3CFONT%20color%3D%22%23999999%22%3E%20%E9%95%BF%E5%BA%A6%EF%BC%9A2%20112%3C%2FFONT%3E%3CBR%20%2F%3E%3CFONT%20color%3D%22%23999999%22%3E%20%E5%AD%97%E8%8A%82%E7%89%88%E6%9C%AC%EF%BC%9A66%3C%2FFONT%3E%3CBR%20%2F%3E%3CFONT%20color%3D%22%23999999%22%3E%20SRK%20%E8%AE%B0%E5%BD%95%EF%BC%9A%3C%2FFONT%3E%3CBR%20%2F%3E%3CFONT%20color%3D%22%23999999%22%3E%20%E6%A0%87%E7%AD%BE%EF%BC%9A0xE1%3C%2FFONT%3E%3CBR%20%2F%3E%3CFONT%20color%3D%22%23999999%22%3E%20%E9%95%BF%E5%BA%A6%EF%BC%9A527%20%E5%AD%97%E8%8A%82%3C%2FFONT%3E%3CBR%20%2F%3E%3CFONT%20color%3D%22%23999999%22%3E%20%E7%AD%BE%E5%90%8D%E7%AE%97%E6%B3%95%EF%BC%9ARSA%3C%2FFONT%3E%3CBR%20%2F%3E%3CFONT%20color%3D%22%23999999%22%3E%20%E5%93%88%E5%B8%8C%E7%AE%97%E6%B3%95%EF%BC%9ASHA2_384%3C%2FFONT%3E%3CBR%20%2F%3E%3CFONT%20color%3D%22%23999999%22%3E%20%E5%AF%86%E9%92%A5%E5%A4%A7%E5%B0%8F%2F%E6%9B%B2%E7%BA%BF%EF%BC%9ARSA4096%3C%2FFONT%3E%3CBR%20%2F%3E%3CFONT%20color%3D%22%23999999%22%3E%20SRK%3C%2FFONT%3E%3CBR%20%2F%3E%3CFONT%20color%3D%22%23999999%22%3E%20%E6%A0%87%E5%BF%97%EF%BC%9AC%20A%3C%2FFONT%3E%3CBR%20%2F%3E%3CFONT%20color%3D%22%23999999%22%3E%20%3C%2FFONT%3E%3CBR%20%2F%3E%3CFONT%20color%3D%22%23999999%22%3E%E6%A0%87%E5%BF%97%20%E6%A8%A1%E6%95%B0%20(N)%EF%BC%9A...%20%E7%AD%BE%E5%90%8D%E9%AA%8C%E8%AF%81%E5%A4%B1%E8%B4%A5%3C%2FFONT%3E%3CBR%20%2F%3E%3CBR%20%2F%3E%3C%2FSPAN%3E%3C%2FP%3E%3CP%3E%3CSPAN%3Eimx-%E5%90%AF%E5%8A%A8-imx93-var-som-aski-sd.bin-flash_singleboot_gdet%20%E4%B8%8D%E4%BC%9A%E5%8F%91%E7%94%9F%E8%BF%99%E7%A7%8D%E6%83%85%E5%86%B5%20%3CBR%20%2F%3E%3C%2FSPAN%3E%3C%2FP%3E%3CP%3E%3CFONT%20color%3D%22%23808080%22%3E%3CSPAN%3E%E7%AD%BE%E5%90%8D%E5%9D%97%EF%BC%9A%3CBR%20%2F%3E%E7%89%88%E6%9C%AC%EF%BC%9A0%20%3CBR%20%2F%3E%20%E9%95%BF%E5%BA%A6%EF%BC%9A400%20%E5%AD%97%E8%8A%82%3CBR%20%2F%3E%E6%A0%87%E7%AD%BE%EF%BC%9A0x90%20%3CBR%20%2F%3E%20%E8%AF%81%E4%B9%A6%E5%81%8F%E7%A7%BB%E9%87%8F%EF%BC%9A0x0%20%3CBR%20%2F%3E%20SRK%20%E8%A1%A8%2F%E6%95%B0%E7%BB%84%E5%81%8F%E7%A7%BB%E9%87%8F%EF%BC%9A0x10%20SRK%20%E8%A1%A8%EF%BC%9A%E6%A0%87%E7%AD%BE%EF%BC%9A0xD7%20%3CBR%20%2F%3E%20%E9%95%BF%E5%BA%A6%EF%BC%9A308%20%E5%AD%97%E8%8A%82%3CBR%20%2F%3E%E7%89%88%E6%9C%AC%EF%BC%9A66%20%3CBR%20%2F%3E%20SRK%20%E8%AE%B0%E5%BD%95%EF%BC%9A%3CBR%20%2F%3E%E6%A0%87%E7%AD%BE%EF%BC%9A0xE1%20%E9%95%BF%E5%BA%A6%EF%BC%9A76%20%E5%AD%97%E8%8A%82%E7%AD%BE%E5%90%8D%E7%AE%97%E6%B3%95%EF%BC%9AECDSA%20%E5%93%88%E5%B8%8C%E7%AE%97%E6%B3%95%EF%BC%9ASHA2%20%3CBR%20%2F%3E%20_256%20%E5%AF%86%E9%92%A5%E5%A4%A7%E5%B0%8F%2F%E6%9B%B2%E7%BA%BF%EF%BC%9APRIME256V1%20%3CBR%20%2F%3E%20SRK%20%3CBR%20%2F%3E%20%E6%A0%87%E5%BF%97%EF%BC%9A%E6%97%A0%20X%20%E5%9D%90%3CBR%20%2F%3E%E6%A0%87%EF%BC%9A...%20%3CBR%20%2F%3E%20%3CBR%20%2F%3E%20%3CBR%20%2F%3E%20%3CBR%20%2F%3E%3CBR%20%2F%3EY%20%E5%9D%90%E6%A0%87%EF%BC%9A...%3CBR%20%2F%3E%3C%2FSPAN%3E%3C%2FFONT%3E%3C%2FP%3E%3CP%3E%3CFONT%20color%3D%22%23808080%22%3E%3CSPAN%3E......%3C%2FSPAN%3E%3C%2FFONT%3E%3C%2FP%3E%3CP%3E%3CSPAN%3E%3CFONT%20color%3D%22%23808080%22%3E%E7%AD%BE%E5%90%8D%E9%AA%8C%E8%AF%81%E6%88%90%E5%8A%9F%3CBR%20%2F%3E%3CBR%20%2F%3E%3C%2FFONT%3E%E6%88%91%E4%BD%BF%E7%94%A8%20Digicert%20HSM%20%E8%BF%9B%E8%A1%8C%E7%AD%BE%E5%90%8D%3CBR%20%2F%3E%3CBR%20%2F%3E%E6%9C%89%E8%B0%81%E7%9F%A5%E9%81%93%20os_cntr_signed%20%E9%AA%8C%E8%AF%81%E5%A4%B1%E8%B4%A5%E7%9A%84%E5%8E%9F%E5%9B%A0%E5%90%97%EF%BC%9F%3CBR%20%2F%3E%E6%9C%89%E8%B0%81%E7%9F%A5%E9%81%93%E5%A6%82%E4%BD%95%E4%BD%BF%E7%94%A8%20openssl%20%E9%AA%8C%E8%AF%81%E7%AD%BE%E5%90%8D%E5%90%97%EF%BC%9F%EF%BC%88%E5%8F%AA%E6%98%AF%E4%B8%BA%E4%BA%86%E6%8E%92%E9%99%A4%20ahab_image_verifier%20%E6%9C%AC%E8%BA%AB%E7%9A%84%E9%97%AE%E9%A2%98%EF%BC%89%3CBR%20%2F%3E%3CBR%20%2F%3E%3C%2FSPAN%3E%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-1670908%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%20translate%3D%22no%22%3ERe%3A%20Testing%20signed%20images%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1670908%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E6%88%91%E4%BB%A5%E5%90%8E%E4%BC%9A%E5%B0%9D%E8%AF%95%E4%BD%BF%E7%94%A8%20openssl%20%E6%96%B9%E6%B3%95%E3%80%82%E6%88%91%E4%BB%AC%E8%81%94%E7%B3%BB%E7%9A%84%E5%8F%A6%E4%B8%80%E4%B8%AA%20FAE%20%E4%B9%9F%E8%AF%81%E5%AE%9E%EF%BC%8C%E5%A6%82%E6%9E%9C%E4%B8%8D%E7%86%94%E4%B8%9D%E6%8C%89%E9%94%AE%EF%BC%8C%E5%B0%B1%E6%97%A0%E6%B3%95%E5%9C%A8%20imx8%20%E6%9D%BF%E4%B8%8A%E8%BF%9B%E8%A1%8C%E6%B5%8B%E8%AF%95%E3%80%82%E5%9C%A8%E8%BF%99%E7%A7%8D%E6%83%85%E5%86%B5%E4%B8%8B%EF%BC%8C%E4%BB%96%E7%9A%84%E5%BB%BA%E8%AE%AE%E6%98%AF%E7%86%94%E4%B8%9D%EF%BC%88%E5%A6%82%E6%9E%9C%E6%88%91%E4%BB%AC%E8%83%BD%E6%8E%A5%E5%8F%97%E7%9A%84%E8%AF%9D%EF%BC%89%EF%BC%8C%E4%BD%86%E4%B8%8D%E8%A6%81%E5%85%B3%E9%97%AD%E8%AE%BE%E5%A4%87%E3%80%82%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-1669327%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%20translate%3D%22no%22%3ERe%3A%20Testing%20signed%20images%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1669327%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E4%BD%A0%E5%A5%BD%3C%2FP%3E%0A%3CP%3E%E5%A6%82%E6%9E%9C%E6%9C%AA%E7%83%A7%E6%AF%81%20SRK%20%E7%86%94%E4%B8%9D%EF%BC%8C%E5%88%99%E5%8F%AF%E4%BB%A5%E4%BD%BF%E7%94%A8%20OPENSSL%20%E5%91%BD%E4%BB%A4%E4%BD%BF%E7%94%A8%E5%85%B6%E5%AF%86%E9%92%A5%E5%88%86%E6%9E%90%E5%9B%BE%E5%83%8F%E3%80%82%3C%2FP%3E%0A%3CBR%20%2F%3E%0A%3CP%3E%E6%AD%A4%E8%87%B4%3C%2FP%3E%3C%2FLINGO-BODY%3E