[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PATCH 2/6] system/physmem: IOMMU: Invoke the translate_size functio
|
From: |
Peter Xu |
|
Subject: |
Re: [PATCH 2/6] system/physmem: IOMMU: Invoke the translate_size function if it is implemented |
|
Date: |
Wed, 25 Oct 2023 11:14:42 -0400 |
On Wed, Oct 25, 2023 at 01:14:26PM +0800, Ethan Chen wrote:
> Signed-off-by: Ethan Chen <ethan84@andestech.com>
> ---
> system/physmem.c | 9 +++++++--
> 1 file changed, 7 insertions(+), 2 deletions(-)
>
> diff --git a/system/physmem.c b/system/physmem.c
> index fc2b0fee01..53b6ab735c 100644
> --- a/system/physmem.c
> +++ b/system/physmem.c
> @@ -432,8 +432,13 @@ static MemoryRegionSection
> address_space_translate_iommu(IOMMUMemoryRegion *iomm
> iommu_idx = imrc->attrs_to_index(iommu_mr, attrs);
> }
>
> - iotlb = imrc->translate(iommu_mr, addr, is_write ?
> - IOMMU_WO : IOMMU_RO, iommu_idx);
> + if (imrc->translate_size) {
> + iotlb = imrc->translate_size(iommu_mr, addr, *plen_out, is_write
> ?
> + IOMMU_WO : IOMMU_RO, iommu_idx);
> + } else {
> + iotlb = imrc->translate(iommu_mr, addr, is_write ?
> + IOMMU_WO : IOMMU_RO, iommu_idx);
> + }
Currently the translation size is encoded in iotlb.addr_mask. Can riscv do
the same?
For example, lookup addr in match_entry_md() ranges, report size back into
iotlb.addr_mask, rather than enforcing *plen_out range always resides in
one translation only.
IMHO it's actually legal if *plen_out covers more than one IOMMU
translations. QEMU memory core should have taken care of that by
separately translate the ranges and apply RW on top. With current proposal
of translate_size() I think it'll fail instead, which is not wanted.
Thanks,
--
Peter Xu
- [PATCH 0/6] Support RISC-V IOPMP, Ethan Chen, 2023/10/25
- [PATCH 4/6] Add RISC-V IOPMP support, Ethan Chen, 2023/10/25
- [PATCH 2/6] system/physmem: IOMMU: Invoke the translate_size function if it is implemented, Ethan Chen, 2023/10/25
- Re: [PATCH 2/6] system/physmem: IOMMU: Invoke the translate_size function if it is implemented,
Peter Xu <=
- Re: [PATCH 2/6] system/physmem: IOMMU: Invoke the translate_size function if it is implemented, Ethan Chen, 2023/10/26
- Re: [PATCH 2/6] system/physmem: IOMMU: Invoke the translate_size function if it is implemented, Peter Xu, 2023/10/27
- Re: [PATCH 2/6] system/physmem: IOMMU: Invoke the translate_size function if it is implemented, Peter Xu, 2023/10/27
- Re: [PATCH 2/6] system/physmem: IOMMU: Invoke the translate_size function if it is implemented, Ethan Chen, 2023/10/30
- Re: [PATCH 2/6] system/physmem: IOMMU: Invoke the translate_size function if it is implemented, Peter Xu, 2023/10/30
- Re: [PATCH 2/6] system/physmem: IOMMU: Invoke the translate_size function if it is implemented, Ethan Chen, 2023/10/31
[PATCH 3/6] exec/memattrs: Add iopmp source id to MemTxAttrs, Ethan Chen, 2023/10/25
[PATCH 5/6] hw/dma: Add Andes ATCDMAC300 support, Ethan Chen, 2023/10/25