NXP iMX95: ARM SMMU problem with PCIe

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

NXP iMX95: ARM SMMU problem with PCIe

ソリューションへジャンプ
234件の閲覧回数
pierluigi_p
Senior Contributor I

Dear NXP support,

we are trying to integrate a PCIe-USB bridge eval kit (https://www.microchip.com/en-us/development-tool/ev96n38a) with NXP iMX95 using kernel 6.12.49.

The PCIe bridge successfully completes PCIe enumeration and all endpoints (xHCI controller, i2c controller, etc.) show up when running "lspci".

When plugging in a USB device (flash drive, keyboard, etc.) to a USB port on the PCI11400 eval kit, the following messages are listed

[ 1631.912942] arm-smmu-v3 490d0000.iommu: event 0x10 received:

[ 1631.918618] arm-smmu-v3 490d0000.iommu: 0x0000001000000010

[ 1631.924188] arm-smmu-v3 490d0000.iommu: 0x0000020200000000

[ 1631.929760] arm-smmu-v3 490d0000.iommu: 0x0000000000000000

[ 1631.935326] arm-smmu-v3 490d0000.iommu: 0x0000000000000000

but no USB device is actually enumerated.

Suspecting some kind of problem with ARM SMMU translation we added "iommu.passthrough=1" to the kernel command line: with this change, the USB devices are correctly enumerated.

However, "iommu.passthrough=1" allows accessing to protected memory regions (i.e. encryption keys) and cannot be considered a valid workaround from a security perspective.

Could you propose any alternative solution ?

Thanks

Best Regards

Pier

タグ(3)
0 件の賞賛
返信
1 解決策
189件の閲覧回数
Zhiming_Liu
NXP TechSupport
NXP TechSupport

Hi @pierluigi_p 

It looks like that the PCIe-USB bridge you are using is accessing SMMU IDs other than the SID and RID allowed by the i.MX95 PCI node.

Below are the SMMU settings for the i.mx95 PCIe. i think you should figure out the actual SID and RID mapping used by the PCI11400.

			iommu-map = <0x000 &smmu 0x10 0x1>,
				    <0x100 &smmu 0x11 0x7>;
			iommu-map-mask = <0x1ff>;



Best Regards,
Zhiming

元の投稿で解決策を見る

0 件の賞賛
返信
2 返答(返信)
190件の閲覧回数
Zhiming_Liu
NXP TechSupport
NXP TechSupport

Hi @pierluigi_p 

It looks like that the PCIe-USB bridge you are using is accessing SMMU IDs other than the SID and RID allowed by the i.MX95 PCI node.

Below are the SMMU settings for the i.mx95 PCIe. i think you should figure out the actual SID and RID mapping used by the PCI11400.

			iommu-map = <0x000 &smmu 0x10 0x1>,
				    <0x100 &smmu 0x11 0x7>;
			iommu-map-mask = <0x1ff>;



Best Regards,
Zhiming

0 件の賞賛
返信
28件の閲覧回数
pierluigi_p
Senior Contributor I

Hi @Zhiming_Liu,

thanks for the suggestion.

Best Regards

Pier

0 件の賞賛
返信
%3CLINGO-SUB%20id%3D%22lingo-sub-2372049%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3ENXP%20iMX95%3A%20PCIe%E6%8E%A5%E7%B6%9A%E6%99%82%E3%81%AEARM%20SMMU%E3%81%AE%E5%95%8F%E9%A1%8C%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2372049%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3ENXP%E3%82%B5%E3%83%9D%E3%83%BC%E3%83%88%E6%A7%98%3C%2FP%3E%3CP%3E%E7%A7%81%E3%81%9F%E3%81%A1%E3%81%AF%E3%80%81%E3%82%AB%E3%83%BC%E3%83%8D%E3%83%AB6.12.49%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%A6%E3%80%81PCIe-USB%E3%83%96%E3%83%AA%E3%83%83%E3%82%B8%E8%A9%95%E4%BE%A1%E3%82%AD%E3%83%83%E3%83%88%EF%BC%88%20%3CA%20href%3D%22https%3A%2F%2Fwww.microchip.com%2Fen-us%2Fdevelopment-tool%2Fev96n38a%22%20target%3D%22_blank%22%20rel%3D%22nofollow%20noopener%20noreferrer%22%3Ehttps%3A%2F%2Fwww.microchip.com%2Fen-us%2Fdevelopment-tool%2Fev96n38a%3C%2FA%3E%20%EF%BC%89%E3%82%92NXP%20iMX95%E3%81%AB%E7%B5%B1%E5%90%88%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%80%82%3C%2FP%3E%3CP%3EPCIe%E3%83%96%E3%83%AA%E3%83%83%E3%82%B8%E3%81%AFPCIe%E5%88%97%E6%8C%99%E3%82%92%E6%AD%A3%E5%B8%B8%E3%81%AB%E5%AE%8C%E4%BA%86%E3%81%97%E3%80%81%E3%80%8Clspci%E3%80%8D%E3%82%92%E5%AE%9F%E8%A1%8C%E3%81%99%E3%82%8B%E3%81%A8%E3%81%99%E3%81%B9%E3%81%A6%E3%81%AE%E3%82%A8%E3%83%B3%E3%83%89%E3%83%9D%E3%82%A4%E3%83%B3%E3%83%88%EF%BC%88xHCI%E3%82%B3%E3%83%B3%E3%83%88%E3%83%AD%E3%83%BC%E3%83%A9%E3%80%81i2c%E3%82%B3%E3%83%B3%E3%83%88%E3%83%AD%E3%83%BC%E3%83%A9%E3%81%AA%E3%81%A9%EF%BC%89%E3%81%8C%E8%A1%A8%E7%A4%BA%E3%81%95%E3%82%8C%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%3CP%3EPCI11400%E8%A9%95%E4%BE%A1%E3%82%AD%E3%83%83%E3%83%88%E3%81%AEUSB%E3%83%9D%E3%83%BC%E3%83%88%E3%81%ABUSB%E3%83%87%E3%83%90%E3%82%A4%E3%82%B9%EF%BC%88%E3%83%95%E3%83%A9%E3%83%83%E3%82%B7%E3%83%A5%E3%83%89%E3%83%A9%E3%82%A4%E3%83%96%E3%80%81%E3%82%AD%E3%83%BC%E3%83%9C%E3%83%BC%E3%83%89%E3%81%AA%E3%81%A9%EF%BC%89%E3%82%92%E6%8E%A5%E7%B6%9A%E3%81%99%E3%82%8B%E3%81%A8%E3%80%81%E4%BB%A5%E4%B8%8B%E3%81%AE%E3%83%A1%E3%83%83%E3%82%BB%E3%83%BC%E3%82%B8%E3%81%8C%E8%A1%A8%E7%A4%BA%E3%81%95%E3%82%8C%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%3CBLOCKQUOTE%3E%3CP%3E%5B%201631.912942%5D%20arm-smmu-v3%20490d0000.iommu%3A%E3%82%A4%E3%83%99%E3%83%B3%E3%83%880x10%E3%82%92%E5%8F%97%E4%BF%A1%E3%81%97%E3%81%BE%E3%81%97%E3%81%9F%3A%3C%2FP%3E%3CP%3E%5B%201631.918618%5D%20arm-smmu-v3%20490d0000.iommu%3A0x0000001000000010%3C%2FP%3E%3CP%3E%5B%201631.924188%5D%20arm-smmu-v3%20490d0000.iommu%3A0x0000020200000000%3C%2FP%3E%3CP%3E%5B%201631.929760%5D%20arm-smmu-v3%20490d0000.iommu%3A0x0000000000000000%3C%2FP%3E%3CP%3E%5B%201631.935326%5D%20arm-smmu-v3%20490d0000.iommu%3A0x0000000000000000%3C%2FP%3E%3C%2FBLOCKQUOTE%3E%3CP%3E%E3%81%97%E3%81%8B%E3%81%97%E3%80%81%E5%AE%9F%E9%9A%9B%E3%81%AB%E3%81%AFUSB%E3%83%87%E3%83%90%E3%82%A4%E3%82%B9%E3%81%AF%E5%88%97%E6%8C%99%E3%81%95%E3%82%8C%E3%81%BE%E3%81%9B%E3%82%93%E3%80%82%3C%2FP%3E%3CP%3EARM%20SMMU%E3%81%AE%E5%A4%89%E6%8F%9B%E3%81%AB%E4%BD%95%E3%82%89%E3%81%8B%E3%81%AE%E5%95%8F%E9%A1%8C%E3%81%8C%E3%81%82%E3%82%8B%E3%81%AE%E3%81%A7%E3%81%AF%E3%81%AA%E3%81%84%E3%81%8B%E3%81%A8%E7%96%91%E3%81%84%E3%80%81%E3%82%AB%E3%83%BC%E3%83%8D%E3%83%AB%E3%81%AE%E3%82%B3%E3%83%9E%E3%83%B3%E3%83%89%E3%83%A9%E3%82%A4%E3%83%B3%E3%81%AB%E3%80%8Ciommu.passthrough%3D1%E3%80%8D%E3%82%92%E8%BF%BD%E5%8A%A0%E3%81%97%E3%81%BE%E3%81%97%E3%81%9F%E3%80%82%E3%81%93%E3%81%AE%E5%A4%89%E6%9B%B4%E3%81%AB%E3%82%88%E3%82%8A%E3%80%81USB%E3%83%87%E3%83%90%E3%82%A4%E3%82%B9%E3%81%8C%E6%AD%A3%E3%81%97%E3%81%8F%E5%88%97%E6%8C%99%E3%81%95%E3%82%8C%E3%82%8B%E3%82%88%E3%81%86%E3%81%AB%E3%81%AA%E3%82%8A%E3%81%BE%E3%81%97%E3%81%9F%E3%80%82%3C%2FP%3E%3CP%3E%E3%81%9F%E3%81%A0%E3%81%97%E3%80%81%E3%80%8Ciommu.passthrough%3D1%E3%80%8D%E4%BF%9D%E8%AD%B7%E3%81%95%E3%82%8C%E3%81%9F%E3%83%A1%E3%83%A2%E3%83%AA%E9%A0%98%E5%9F%9F%E3%81%B8%E3%81%AE%E3%82%A2%E3%82%AF%E3%82%BB%E3%82%B9%E3%82%92%E8%A8%B1%E5%8F%AF%E3%81%97%E3%81%BE%E3%81%99%EF%BC%88%E3%81%A4%E3%81%BE%E3%82%8A%E6%9A%97%E5%8F%B7%E5%8C%96%E3%82%AD%E3%83%BC%EF%BC%89%E3%81%A7%E3%81%82%E3%82%8A%E3%80%81%E3%82%BB%E3%82%AD%E3%83%A5%E3%83%AA%E3%83%86%E3%82%A3%E3%81%AE%E8%A6%B3%E7%82%B9%E3%81%8B%E3%82%89%E6%9C%89%E5%8A%B9%E3%81%AA%E5%9B%9E%E9%81%BF%E7%AD%96%E3%81%A8%E3%81%AF%E3%81%BF%E3%81%AA%E3%81%95%E3%82%8C%E3%81%BE%E3%81%9B%E3%82%93%E3%80%82%3C%2FP%3E%3CP%3E%E4%BD%95%E3%81%8B%E4%BB%A3%E6%9B%BF%E6%A1%88%E3%82%92%E6%8F%90%E6%A1%88%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%EF%BC%9F%3C%2FP%3E%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%97%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%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%3CP%3E%E6%A1%9F%E6%A9%8B%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-2372262%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%20translate%3D%22no%22%3ERe%3A%20NXP%20iMX95%3A%20ARM%20SMMU%20problem%20with%20PCIe%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-2372262%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%20%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fuser%2Fviewprofilepage%2Fuser-id%2F60868%22%20target%3D%22_blank%22%3E%40pierluigi_p%3C%2FA%3E%3C%2FP%3E%0A%3CP%3E%E3%81%8A%E4%BD%BF%E3%81%84%E3%81%AEPCIe-USB%E3%83%96%E3%83%AA%E3%83%83%E3%82%B8%E3%81%8C%E3%80%81i.MX95%20PCI%E3%83%8E%E3%83%BC%E3%83%89%E3%81%A7%E8%A8%B1%E5%8F%AF%E3%81%95%E3%82%8C%E3%81%A6%E3%81%84%E3%82%8BSID%E3%81%8A%E3%82%88%E3%81%B3RID%E4%BB%A5%E5%A4%96%E3%81%AESMMU%20ID%E3%81%AB%E3%82%A2%E3%82%AF%E3%82%BB%E3%82%B9%E3%81%97%E3%81%A6%E3%81%84%E3%82%8B%E3%82%88%E3%81%86%E3%81%A7%E3%81%99%E3%80%82%3C%2FP%3E%0A%3CP%3E%E4%BB%A5%E4%B8%8B%E3%81%AF%E3%80%81i.mx95%20PCIe%20%E3%81%AE%20SMMU%20%E8%A8%AD%E5%AE%9A%E3%81%A7%E3%81%99%E3%80%82PCI11400%E3%81%A7%E5%AE%9F%E9%9A%9B%E3%81%AB%E4%BD%BF%E7%94%A8%E3%81%95%E3%82%8C%E3%81%A6%E3%81%84%E3%82%8BSID%E3%81%A8RID%E3%81%AE%E3%83%9E%E3%83%83%E3%83%94%E3%83%B3%E3%82%B0%E3%82%92%E7%AA%81%E3%81%8D%E6%AD%A2%E3%82%81%E3%82%8B%E3%81%B9%E3%81%8D%E3%81%A0%E3%81%A8%E6%80%9D%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%0A%3CPRE%20class%3D%22lia-code-sample%20language-markup%22%3E%3CCODE%20translate%3D%22no%22%3E%09%09%09iommu-map%20%3D%20%26lt%3B0x000%20%26amp%3Bsmmu%200x10%200x1%26gt%3B%2C%0A%09%09%09%09%20%20%20%20%26lt%3B0x100%20%26amp%3Bsmmu%200x11%200x7%26gt%3B%3B%0A%09%09%09iommu-map-mask%20%3D%20%26lt%3B0x1ff%26gt%3B%3B%3C%2FCODE%3E%3C%2FPRE%3E%0A%3CP%3E%3CBR%20%2F%3E%3CBR%20%2F%3E%E3%82%88%E3%82%8D%E3%81%97%E3%81%8F%E3%81%8A%E9%A1%98%E3%81%84%E3%81%97%E3%81%BE%E3%81%99%E3%80%81%3CBR%20%2F%3E%E5%BF%97%E6%98%8E%3C%2FP%3E%3C%2FLINGO-BODY%3E