Commit c6da12a8 authored by Bob Breuer's avatar Bob Breuer Committed by Linus Torvalds

[PATCH] sparc32: fix for HyperSPARC DMA errors

I found a solution for the HyperSPARC DMA problems in 2.6.  This allows my
SS20 with HyperSPARCs to boot to single user.  It's not efficient, but I
hope it points out whats needed for a proper fix.  Seems that the iotlb
entries need to flushed to ram or uncached since the iommu changes between
2.5.60 and 2.5.70.

The second part seems to be needed to allow consistent sbus dma mappings to
be cached on HyperSPARC.  I have also tested this change on 2.4.27 with no
noticeable difference.
Acked-by: default avatarWilliam Irwin <wli@holomorphy.com>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent 89141e47
...@@ -173,6 +173,7 @@ static u32 iommu_get_one(struct page *page, int npages, struct sbus_bus *sbus) ...@@ -173,6 +173,7 @@ static u32 iommu_get_one(struct page *page, int npages, struct sbus_bus *sbus)
} }
iommu_viking_flush_iotlb(iopte0, npages); iommu_viking_flush_iotlb(iopte0, npages);
flush_cache_all(); // hack to fix dma errors with hypersparc
return busa0; return busa0;
} }
......
...@@ -1463,6 +1463,7 @@ static void __init poke_hypersparc(void) ...@@ -1463,6 +1463,7 @@ static void __init poke_hypersparc(void)
static void __init init_hypersparc(void) static void __init init_hypersparc(void)
{ {
srmmu_name = "ROSS HyperSparc"; srmmu_name = "ROSS HyperSparc";
srmmu_modtype = HyperSparc;
init_vac_layout(); init_vac_layout();
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment