Conversation
|
Thanks for working on this :) I haven't had a chance to look at the |
|
Is this ready for review? Currently it's marked as draft still. (No worries if that's intentional, just want to be sure you're not waiting on review.) |
|
I still need to write some test for it. I have been busy with some other things, so I'll send those over as soon as I can. Feel free to take a look if you want. |
|
@nicholasbishop I am trying to write some test for this, but I cant seem to get a protocol handle. I went into the uefi shell of the qemu vm, and the IoMmu driver image is present: dh -p 4e939de9-d948-4b0f-88ed-e6e1ce517c1e -v
Handle dump by protocol '4E939DE9-D948-4B0F-88ED-E6E1CE517C1E'
Shell> dh -p 03c4e603-ac28-11d3-9a2d-0090273fc14d -v
Handle dump by protocol 'PXEBaseCode'
Shell> dh 28 -v
28: 3ECF0C18
ImageDevicePath(3ECF2A98)
Fv(7CB8BDC9-F8EB-4F34-AAEA-3EE4AF6516A1)/FvFile(8657015B-EA43-440D-949A-AF3BE365C0FC)
LoadedImage(3ECF20C0)
Name..........: IoMmuDxeSo I am assuming the driver is failing to find hardware. I have tried a few different things, different EDK2 builds and followed the virtio instructions here, but nothing has worked. Ik it worked on hardware, so if you have any ideas on how to get qemu setup for IoMmu please let me know. |
Thanks for trying to find a solution! Is there any update here? Have you tried to add an IOMMU to the QEMU VM? Perhaps one is needed so that the protocol will be installed one some handles ( |
|
Any update here @PelleKrab ? If not, I'm in favor of closing the PR for now. |
No significant progress yet. I've been working on this here and there. Right now, I'm building a custom OVMF image to see if that forces the xtask VM to recognize the IOMMU drivers. I'm not sure if there’s wider interest in that approach, but I'm giving it a try since no other QEMU environment configs seem to help. I'm fine with closing the issue for now, and I can reopen it if I find a solution. |
Thanks! Good luck with your investigations. We are very happy for every contribution and feel free to reopen / open a new one as soon as you have a solution. For good project hygiene, we aim for short-living PRs (less than 3 months best) |
|
very cool! regarding ovmf-prebuilt I think @nicholasbishop is the expert - from my side it is looking good |
|
@phip1611 Everything is working now! Could you reopen this and take a look? |
|
Please rebase / solve the conflict and remove all |
…o be IOMMU capable
|
The x86_64 CI jobs now require QEMU 9+ because they use |
|
thanks for working on that! @nicholasbishop any idea why this fails? |
This PR adds the IoMmu Protocol to
uefi-rs, enabling easy DMA (Direct Memory Access) for devices. This is a draft to get some initial feedback before writinguefi-rstests. It is already working in my internal project. The main areas I would like feedback on are:unmap()andfree_buffer()?free_buffer_raw()andunmap_raw()be made public?General Implementation:
ref:
#1723