[PATCH 3/8] Remove unused pte_offset variable

Benjamin Herrenschmidt benh at kernel.crashing.org
Wed Feb 27 19:04:51 EST 2008


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 <michael at ellerman.id.au>
> ---

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);




More information about the Linuxppc-dev mailing list