Loading arch/sparc/kernel/ebus.c +1 −0 Original line number Original line Diff line number Diff line Loading @@ -238,6 +238,7 @@ void __init fill_ebus_device(struct device_node *dp, struct linux_ebus_device *d sd = &dev->ofdev.dev.archdata; sd = &dev->ofdev.dev.archdata; sd->prom_node = dp; sd->prom_node = dp; sd->op = &dev->ofdev; sd->op = &dev->ofdev; sd->iommu = dev->bus->ofdev.dev.parent->archdata.iommu; dev->ofdev.node = dp; dev->ofdev.node = dp; dev->ofdev.dev.parent = &dev->bus->ofdev.dev; dev->ofdev.dev.parent = &dev->bus->ofdev.dev; Loading arch/sparc/mm/io-unit.c +9 −9 Original line number Original line Diff line number Diff line Loading @@ -66,7 +66,7 @@ iounit_init(int sbi_node, int io_node, struct sbus_bus *sbus) } } if(!xpt) panic("Cannot map External Page Table."); if(!xpt) panic("Cannot map External Page Table."); sbus->iommu = (struct iommu_struct *)iounit; sbus->ofdev.dev.archdata.iommu = iounit; iounit->page_table = xpt; iounit->page_table = xpt; spin_lock_init(&iounit->lock); spin_lock_init(&iounit->lock); Loading Loading @@ -127,7 +127,7 @@ nexti: scan = find_next_zero_bit(iounit->bmap, limit, scan); static __u32 iounit_get_scsi_one(char *vaddr, unsigned long len, struct sbus_bus *sbus) static __u32 iounit_get_scsi_one(char *vaddr, unsigned long len, struct sbus_bus *sbus) { { unsigned long ret, flags; unsigned long ret, flags; struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu; struct iounit_struct *iounit = sbus->ofdev.dev.archdata.iommu; spin_lock_irqsave(&iounit->lock, flags); spin_lock_irqsave(&iounit->lock, flags); ret = iounit_get_area(iounit, (unsigned long)vaddr, len); ret = iounit_get_area(iounit, (unsigned long)vaddr, len); Loading @@ -138,7 +138,7 @@ static __u32 iounit_get_scsi_one(char *vaddr, unsigned long len, struct sbus_bus static void iounit_get_scsi_sgl(struct scatterlist *sg, int sz, struct sbus_bus *sbus) static void iounit_get_scsi_sgl(struct scatterlist *sg, int sz, struct sbus_bus *sbus) { { unsigned long flags; unsigned long flags; struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu; struct iounit_struct *iounit = sbus->ofdev.dev.archdata.iommu; /* FIXME: Cache some resolved pages - often several sg entries are to the same page */ /* FIXME: Cache some resolved pages - often several sg entries are to the same page */ spin_lock_irqsave(&iounit->lock, flags); spin_lock_irqsave(&iounit->lock, flags); Loading @@ -153,7 +153,7 @@ static void iounit_get_scsi_sgl(struct scatterlist *sg, int sz, struct sbus_bus static void iounit_release_scsi_one(__u32 vaddr, unsigned long len, struct sbus_bus *sbus) static void iounit_release_scsi_one(__u32 vaddr, unsigned long len, struct sbus_bus *sbus) { { unsigned long flags; unsigned long flags; struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu; struct iounit_struct *iounit = sbus->ofdev.dev.archdata.iommu; spin_lock_irqsave(&iounit->lock, flags); spin_lock_irqsave(&iounit->lock, flags); len = ((vaddr & ~PAGE_MASK) + len + (PAGE_SIZE-1)) >> PAGE_SHIFT; len = ((vaddr & ~PAGE_MASK) + len + (PAGE_SIZE-1)) >> PAGE_SHIFT; Loading @@ -168,7 +168,7 @@ static void iounit_release_scsi_sgl(struct scatterlist *sg, int sz, struct sbus_ { { unsigned long flags; unsigned long flags; unsigned long vaddr, len; unsigned long vaddr, len; struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu; struct iounit_struct *iounit = sbus->ofdev.dev.archdata.iommu; spin_lock_irqsave(&iounit->lock, flags); spin_lock_irqsave(&iounit->lock, flags); while (sz != 0) { while (sz != 0) { Loading Loading @@ -211,7 +211,7 @@ static int iounit_map_dma_area(dma_addr_t *pba, unsigned long va, __u32 addr, in i = ((addr - IOUNIT_DMA_BASE) >> PAGE_SHIFT); i = ((addr - IOUNIT_DMA_BASE) >> PAGE_SHIFT); for_each_sbus(sbus) { for_each_sbus(sbus) { struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu; struct iounit_struct *iounit = sbus->ofdev.dev.archdata.iommu; iopte = (iopte_t *)(iounit->page_table + i); iopte = (iopte_t *)(iounit->page_table + i); *iopte = MKIOPTE(__pa(page)); *iopte = MKIOPTE(__pa(page)); Loading @@ -235,7 +235,7 @@ static void iounit_unmap_dma_area(unsigned long addr, int len) static struct page *iounit_translate_dvma(unsigned long addr) static struct page *iounit_translate_dvma(unsigned long addr) { { struct sbus_bus *sbus = sbus_root; /* They are all the same */ struct sbus_bus *sbus = sbus_root; /* They are all the same */ struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu; struct iounit_struct *iounit = sbus->ofdev.dev.archdata.iommu; int i; int i; iopte_t *iopte; iopte_t *iopte; Loading Loading @@ -279,7 +279,7 @@ __u32 iounit_map_dma_init(struct sbus_bus *sbus, int size) unsigned long rotor, scan, limit; unsigned long rotor, scan, limit; unsigned long flags; unsigned long flags; __u32 ret; __u32 ret; struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu; struct iounit_struct *iounit = sbus->ofdev.dev.archdata.iommu; npages = (size + (PAGE_SIZE-1)) >> PAGE_SHIFT; npages = (size + (PAGE_SIZE-1)) >> PAGE_SHIFT; i = 0x0213; i = 0x0213; Loading Loading @@ -315,7 +315,7 @@ nexti: scan = find_next_zero_bit(iounit->bmap, limit, scan); __u32 iounit_map_dma_page(__u32 vaddr, void *addr, struct sbus_bus *sbus) __u32 iounit_map_dma_page(__u32 vaddr, void *addr, struct sbus_bus *sbus) { { int scan = (vaddr - IOUNIT_DMA_BASE) >> PAGE_SHIFT; int scan = (vaddr - IOUNIT_DMA_BASE) >> PAGE_SHIFT; struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu; struct iounit_struct *iounit = sbus->ofdev.dev.archdata.iommu; iounit->page_table[scan] = MKIOPTE(__pa(((unsigned long)addr) & PAGE_MASK)); iounit->page_table[scan] = MKIOPTE(__pa(((unsigned long)addr) & PAGE_MASK)); return vaddr + (((unsigned long)addr) & ~PAGE_MASK); return vaddr + (((unsigned long)addr) & ~PAGE_MASK); Loading arch/sparc/mm/iommu.c +6 −6 Original line number Original line Diff line number Diff line Loading @@ -132,7 +132,7 @@ iommu_init(int iommund, struct sbus_bus *sbus) impl, vers, iommu->page_table, impl, vers, iommu->page_table, (int)(IOMMU_NPTES*sizeof(iopte_t)), (int)IOMMU_NPTES); (int)(IOMMU_NPTES*sizeof(iopte_t)), (int)IOMMU_NPTES); sbus->iommu = iommu; sbus->ofdev.dev.archdata.iommu = iommu; } } /* This begs to be btfixup-ed by srmmu. */ /* This begs to be btfixup-ed by srmmu. */ Loading Loading @@ -166,7 +166,7 @@ static void iommu_flush_iotlb(iopte_t *iopte, unsigned int niopte) static u32 iommu_get_one(struct page *page, int npages, struct sbus_bus *sbus) static u32 iommu_get_one(struct page *page, int npages, struct sbus_bus *sbus) { { struct iommu_struct *iommu = sbus->iommu; struct iommu_struct *iommu = sbus->ofdev.dev.archdata.iommu; int ioptex; int ioptex; iopte_t *iopte, *iopte0; iopte_t *iopte, *iopte0; unsigned int busa, busa0; unsigned int busa, busa0; Loading Loading @@ -291,7 +291,7 @@ static void iommu_get_scsi_sgl_pflush(struct scatterlist *sg, int sz, struct sbu static void iommu_release_one(u32 busa, int npages, struct sbus_bus *sbus) static void iommu_release_one(u32 busa, int npages, struct sbus_bus *sbus) { { struct iommu_struct *iommu = sbus->iommu; struct iommu_struct *iommu = sbus->ofdev.dev.archdata.iommu; int ioptex; int ioptex; int i; int i; Loading Loading @@ -334,7 +334,7 @@ static int iommu_map_dma_area(dma_addr_t *pba, unsigned long va, unsigned long addr, int len) unsigned long addr, int len) { { unsigned long page, end; unsigned long page, end; struct iommu_struct *iommu = sbus_root->iommu; struct iommu_struct *iommu = sbus_root->ofdev.dev.archdata.iommu; iopte_t *iopte = iommu->page_table; iopte_t *iopte = iommu->page_table; iopte_t *first; iopte_t *first; int ioptex; int ioptex; Loading Loading @@ -399,7 +399,7 @@ static int iommu_map_dma_area(dma_addr_t *pba, unsigned long va, static void iommu_unmap_dma_area(unsigned long busa, int len) static void iommu_unmap_dma_area(unsigned long busa, int len) { { struct iommu_struct *iommu = sbus_root->iommu; struct iommu_struct *iommu = sbus_root->ofdev.dev.archdata.iommu; iopte_t *iopte = iommu->page_table; iopte_t *iopte = iommu->page_table; unsigned long end; unsigned long end; int ioptex = (busa - iommu->start) >> PAGE_SHIFT; int ioptex = (busa - iommu->start) >> PAGE_SHIFT; Loading @@ -420,7 +420,7 @@ static void iommu_unmap_dma_area(unsigned long busa, int len) static struct page *iommu_translate_dvma(unsigned long busa) static struct page *iommu_translate_dvma(unsigned long busa) { { struct iommu_struct *iommu = sbus_root->iommu; struct iommu_struct *iommu = sbus_root->ofdev.dev.archdata.iommu; iopte_t *iopte = iommu->page_table; iopte_t *iopte = iommu->page_table; iopte += ((busa - iommu->start) >> PAGE_SHIFT); iopte += ((busa - iommu->start) >> PAGE_SHIFT); Loading include/asm-sparc/sbus.h +0 −1 Original line number Original line Diff line number Diff line Loading @@ -68,7 +68,6 @@ struct sbus_dev { /* This struct describes the SBus(s) found on this machine. */ /* This struct describes the SBus(s) found on this machine. */ struct sbus_bus { struct sbus_bus { struct of_device ofdev; struct of_device ofdev; void *iommu; /* Opaque IOMMU cookie */ struct sbus_dev *devices; /* Link to devices on this SBus */ struct sbus_dev *devices; /* Link to devices on this SBus */ struct sbus_bus *next; /* next SBus, if more than one SBus */ struct sbus_bus *next; /* next SBus, if more than one SBus */ int prom_node; /* PROM device tree node for this SBus */ int prom_node; /* PROM device tree node for this SBus */ Loading Loading
arch/sparc/kernel/ebus.c +1 −0 Original line number Original line Diff line number Diff line Loading @@ -238,6 +238,7 @@ void __init fill_ebus_device(struct device_node *dp, struct linux_ebus_device *d sd = &dev->ofdev.dev.archdata; sd = &dev->ofdev.dev.archdata; sd->prom_node = dp; sd->prom_node = dp; sd->op = &dev->ofdev; sd->op = &dev->ofdev; sd->iommu = dev->bus->ofdev.dev.parent->archdata.iommu; dev->ofdev.node = dp; dev->ofdev.node = dp; dev->ofdev.dev.parent = &dev->bus->ofdev.dev; dev->ofdev.dev.parent = &dev->bus->ofdev.dev; Loading
arch/sparc/mm/io-unit.c +9 −9 Original line number Original line Diff line number Diff line Loading @@ -66,7 +66,7 @@ iounit_init(int sbi_node, int io_node, struct sbus_bus *sbus) } } if(!xpt) panic("Cannot map External Page Table."); if(!xpt) panic("Cannot map External Page Table."); sbus->iommu = (struct iommu_struct *)iounit; sbus->ofdev.dev.archdata.iommu = iounit; iounit->page_table = xpt; iounit->page_table = xpt; spin_lock_init(&iounit->lock); spin_lock_init(&iounit->lock); Loading Loading @@ -127,7 +127,7 @@ nexti: scan = find_next_zero_bit(iounit->bmap, limit, scan); static __u32 iounit_get_scsi_one(char *vaddr, unsigned long len, struct sbus_bus *sbus) static __u32 iounit_get_scsi_one(char *vaddr, unsigned long len, struct sbus_bus *sbus) { { unsigned long ret, flags; unsigned long ret, flags; struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu; struct iounit_struct *iounit = sbus->ofdev.dev.archdata.iommu; spin_lock_irqsave(&iounit->lock, flags); spin_lock_irqsave(&iounit->lock, flags); ret = iounit_get_area(iounit, (unsigned long)vaddr, len); ret = iounit_get_area(iounit, (unsigned long)vaddr, len); Loading @@ -138,7 +138,7 @@ static __u32 iounit_get_scsi_one(char *vaddr, unsigned long len, struct sbus_bus static void iounit_get_scsi_sgl(struct scatterlist *sg, int sz, struct sbus_bus *sbus) static void iounit_get_scsi_sgl(struct scatterlist *sg, int sz, struct sbus_bus *sbus) { { unsigned long flags; unsigned long flags; struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu; struct iounit_struct *iounit = sbus->ofdev.dev.archdata.iommu; /* FIXME: Cache some resolved pages - often several sg entries are to the same page */ /* FIXME: Cache some resolved pages - often several sg entries are to the same page */ spin_lock_irqsave(&iounit->lock, flags); spin_lock_irqsave(&iounit->lock, flags); Loading @@ -153,7 +153,7 @@ static void iounit_get_scsi_sgl(struct scatterlist *sg, int sz, struct sbus_bus static void iounit_release_scsi_one(__u32 vaddr, unsigned long len, struct sbus_bus *sbus) static void iounit_release_scsi_one(__u32 vaddr, unsigned long len, struct sbus_bus *sbus) { { unsigned long flags; unsigned long flags; struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu; struct iounit_struct *iounit = sbus->ofdev.dev.archdata.iommu; spin_lock_irqsave(&iounit->lock, flags); spin_lock_irqsave(&iounit->lock, flags); len = ((vaddr & ~PAGE_MASK) + len + (PAGE_SIZE-1)) >> PAGE_SHIFT; len = ((vaddr & ~PAGE_MASK) + len + (PAGE_SIZE-1)) >> PAGE_SHIFT; Loading @@ -168,7 +168,7 @@ static void iounit_release_scsi_sgl(struct scatterlist *sg, int sz, struct sbus_ { { unsigned long flags; unsigned long flags; unsigned long vaddr, len; unsigned long vaddr, len; struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu; struct iounit_struct *iounit = sbus->ofdev.dev.archdata.iommu; spin_lock_irqsave(&iounit->lock, flags); spin_lock_irqsave(&iounit->lock, flags); while (sz != 0) { while (sz != 0) { Loading Loading @@ -211,7 +211,7 @@ static int iounit_map_dma_area(dma_addr_t *pba, unsigned long va, __u32 addr, in i = ((addr - IOUNIT_DMA_BASE) >> PAGE_SHIFT); i = ((addr - IOUNIT_DMA_BASE) >> PAGE_SHIFT); for_each_sbus(sbus) { for_each_sbus(sbus) { struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu; struct iounit_struct *iounit = sbus->ofdev.dev.archdata.iommu; iopte = (iopte_t *)(iounit->page_table + i); iopte = (iopte_t *)(iounit->page_table + i); *iopte = MKIOPTE(__pa(page)); *iopte = MKIOPTE(__pa(page)); Loading @@ -235,7 +235,7 @@ static void iounit_unmap_dma_area(unsigned long addr, int len) static struct page *iounit_translate_dvma(unsigned long addr) static struct page *iounit_translate_dvma(unsigned long addr) { { struct sbus_bus *sbus = sbus_root; /* They are all the same */ struct sbus_bus *sbus = sbus_root; /* They are all the same */ struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu; struct iounit_struct *iounit = sbus->ofdev.dev.archdata.iommu; int i; int i; iopte_t *iopte; iopte_t *iopte; Loading Loading @@ -279,7 +279,7 @@ __u32 iounit_map_dma_init(struct sbus_bus *sbus, int size) unsigned long rotor, scan, limit; unsigned long rotor, scan, limit; unsigned long flags; unsigned long flags; __u32 ret; __u32 ret; struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu; struct iounit_struct *iounit = sbus->ofdev.dev.archdata.iommu; npages = (size + (PAGE_SIZE-1)) >> PAGE_SHIFT; npages = (size + (PAGE_SIZE-1)) >> PAGE_SHIFT; i = 0x0213; i = 0x0213; Loading Loading @@ -315,7 +315,7 @@ nexti: scan = find_next_zero_bit(iounit->bmap, limit, scan); __u32 iounit_map_dma_page(__u32 vaddr, void *addr, struct sbus_bus *sbus) __u32 iounit_map_dma_page(__u32 vaddr, void *addr, struct sbus_bus *sbus) { { int scan = (vaddr - IOUNIT_DMA_BASE) >> PAGE_SHIFT; int scan = (vaddr - IOUNIT_DMA_BASE) >> PAGE_SHIFT; struct iounit_struct *iounit = (struct iounit_struct *)sbus->iommu; struct iounit_struct *iounit = sbus->ofdev.dev.archdata.iommu; iounit->page_table[scan] = MKIOPTE(__pa(((unsigned long)addr) & PAGE_MASK)); iounit->page_table[scan] = MKIOPTE(__pa(((unsigned long)addr) & PAGE_MASK)); return vaddr + (((unsigned long)addr) & ~PAGE_MASK); return vaddr + (((unsigned long)addr) & ~PAGE_MASK); Loading
arch/sparc/mm/iommu.c +6 −6 Original line number Original line Diff line number Diff line Loading @@ -132,7 +132,7 @@ iommu_init(int iommund, struct sbus_bus *sbus) impl, vers, iommu->page_table, impl, vers, iommu->page_table, (int)(IOMMU_NPTES*sizeof(iopte_t)), (int)IOMMU_NPTES); (int)(IOMMU_NPTES*sizeof(iopte_t)), (int)IOMMU_NPTES); sbus->iommu = iommu; sbus->ofdev.dev.archdata.iommu = iommu; } } /* This begs to be btfixup-ed by srmmu. */ /* This begs to be btfixup-ed by srmmu. */ Loading Loading @@ -166,7 +166,7 @@ static void iommu_flush_iotlb(iopte_t *iopte, unsigned int niopte) static u32 iommu_get_one(struct page *page, int npages, struct sbus_bus *sbus) static u32 iommu_get_one(struct page *page, int npages, struct sbus_bus *sbus) { { struct iommu_struct *iommu = sbus->iommu; struct iommu_struct *iommu = sbus->ofdev.dev.archdata.iommu; int ioptex; int ioptex; iopte_t *iopte, *iopte0; iopte_t *iopte, *iopte0; unsigned int busa, busa0; unsigned int busa, busa0; Loading Loading @@ -291,7 +291,7 @@ static void iommu_get_scsi_sgl_pflush(struct scatterlist *sg, int sz, struct sbu static void iommu_release_one(u32 busa, int npages, struct sbus_bus *sbus) static void iommu_release_one(u32 busa, int npages, struct sbus_bus *sbus) { { struct iommu_struct *iommu = sbus->iommu; struct iommu_struct *iommu = sbus->ofdev.dev.archdata.iommu; int ioptex; int ioptex; int i; int i; Loading Loading @@ -334,7 +334,7 @@ static int iommu_map_dma_area(dma_addr_t *pba, unsigned long va, unsigned long addr, int len) unsigned long addr, int len) { { unsigned long page, end; unsigned long page, end; struct iommu_struct *iommu = sbus_root->iommu; struct iommu_struct *iommu = sbus_root->ofdev.dev.archdata.iommu; iopte_t *iopte = iommu->page_table; iopte_t *iopte = iommu->page_table; iopte_t *first; iopte_t *first; int ioptex; int ioptex; Loading Loading @@ -399,7 +399,7 @@ static int iommu_map_dma_area(dma_addr_t *pba, unsigned long va, static void iommu_unmap_dma_area(unsigned long busa, int len) static void iommu_unmap_dma_area(unsigned long busa, int len) { { struct iommu_struct *iommu = sbus_root->iommu; struct iommu_struct *iommu = sbus_root->ofdev.dev.archdata.iommu; iopte_t *iopte = iommu->page_table; iopte_t *iopte = iommu->page_table; unsigned long end; unsigned long end; int ioptex = (busa - iommu->start) >> PAGE_SHIFT; int ioptex = (busa - iommu->start) >> PAGE_SHIFT; Loading @@ -420,7 +420,7 @@ static void iommu_unmap_dma_area(unsigned long busa, int len) static struct page *iommu_translate_dvma(unsigned long busa) static struct page *iommu_translate_dvma(unsigned long busa) { { struct iommu_struct *iommu = sbus_root->iommu; struct iommu_struct *iommu = sbus_root->ofdev.dev.archdata.iommu; iopte_t *iopte = iommu->page_table; iopte_t *iopte = iommu->page_table; iopte += ((busa - iommu->start) >> PAGE_SHIFT); iopte += ((busa - iommu->start) >> PAGE_SHIFT); Loading
include/asm-sparc/sbus.h +0 −1 Original line number Original line Diff line number Diff line Loading @@ -68,7 +68,6 @@ struct sbus_dev { /* This struct describes the SBus(s) found on this machine. */ /* This struct describes the SBus(s) found on this machine. */ struct sbus_bus { struct sbus_bus { struct of_device ofdev; struct of_device ofdev; void *iommu; /* Opaque IOMMU cookie */ struct sbus_dev *devices; /* Link to devices on this SBus */ struct sbus_dev *devices; /* Link to devices on this SBus */ struct sbus_bus *next; /* next SBus, if more than one SBus */ struct sbus_bus *next; /* next SBus, if more than one SBus */ int prom_node; /* PROM device tree node for this SBus */ int prom_node; /* PROM device tree node for this SBus */ Loading