On Wed, 2008-02-27 at 18:28 +1100, Michael Ellerman wrote:
> The cell IOMMU code no longer needs to save the pte_offset variable
> separately, it is incorporated into tbl->it_offset.
> 
> Signed-off-by: Michael Ellerman <[EMAIL PROTECTED]>
> ---

Do this work on spider ?

There is a subtle difference with spider is that the 0x80000000 you give
to devices disappears when reaching the iommu (so isn't to be catered
in the iommu offset).

It's a bit like the offset you have to add to the direct mapping on
axon, in fact (the 0x8000060000000000 or so ...)

Ben.

>  arch/powerpc/platforms/cell/iommu.c |    5 +----
>  1 files changed, 1 insertions(+), 4 deletions(-)
> 
> diff --git a/arch/powerpc/platforms/cell/iommu.c 
> b/arch/powerpc/platforms/cell/iommu.c
> index 4e75919..555d264 100644
> --- a/arch/powerpc/platforms/cell/iommu.c
> +++ b/arch/powerpc/platforms/cell/iommu.c
> @@ -123,7 +123,6 @@ struct iommu_window {
>       struct cbe_iommu *iommu;
>       unsigned long offset;
>       unsigned long size;
> -     unsigned long pte_offset;
>       unsigned int ioid;
>       struct iommu_table table;
>  };
> @@ -475,13 +474,11 @@ cell_iommu_setup_window(struct cbe_iommu *iommu, struct 
> device_node *np,
>       window->size = size;
>       window->ioid = ioid;
>       window->iommu = iommu;
> -     window->pte_offset = pte_offset;
>  
>       window->table.it_blocksize = 16;
>       window->table.it_base = (unsigned long)iommu->ptab;
>       window->table.it_index = iommu->nid;
> -     window->table.it_offset = (offset >> IOMMU_PAGE_SHIFT) +
> -             window->pte_offset;
> +     window->table.it_offset = (offset >> IOMMU_PAGE_SHIFT) + pte_offset;
>       window->table.it_size = size >> IOMMU_PAGE_SHIFT;
>  
>       iommu_init_table(&window->table, iommu->nid);

_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@ozlabs.org
https://ozlabs.org/mailman/listinfo/linuxppc-dev

Reply via email to