linux/arch/mips/powertv/asic
David VomLehn ca36c36b78 MIPS: PowerTV: Use O(1) algorthm for phys_to_dma/dma_to_phys
Replace phys_to_dma()/dma_to_phys() looping algorithm with an O(1) algorithm
The approach taken is inspired by the sparse memory implementation: take a
certain number of high-order bits off the address them, use this as an
index into a table containing an offset to the desired address and add
it to the original value. There is a table for mapping physical addresses
to DMA addresses and another one for the reverse mapping. The table sizes
depend on how fine-grained the mappings need to be; Coarser granularity
less to smaller tables.  On a processor with 32-bit physical and DMA
addresses, with 4 MIB granularity, memory usage is two 2048-byte arrays.
Each 32-byte cache line thus covers 64 MiB of address space.

Also, renames phys_to_bus() to phys_to_dma() and bus_to_phys() to
dma_to_phys() to align with kernel usage.

[Ralf: Fixed silly build breakage due to stackoverflow warning caused by
huge array on stack.]

Signed-off-by: David VomLehn <dvomlehn@cisco.com>
To: linux-mips@linux-mips.org
Patchwork: https://patchwork.linux-mips.org/patch/1257/
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
2010-08-05 13:25:40 +01:00
..
asic_devices.c MIPS: PowerTV: Use O(1) algorthm for phys_to_dma/dma_to_phys 2010-08-05 13:25:40 +01:00
asic_int.c include cleanup: Update gfp.h and slab.h includes to prepare for breaking implicit slab.h inclusion from percpu.h 2010-03-30 22:02:32 +09:00
asic-calliope.c MIPS: PowerTV: Streamline access to platform device registers 2010-01-28 00:03:31 +01:00
asic-cronus.c MIPS: PowerTV: Streamline access to platform device registers 2010-01-28 00:03:31 +01:00
asic-zeus.c MIPS: PowerTV: Streamline access to platform device registers 2010-01-28 00:03:31 +01:00
irq_asic.c
Kconfig
Makefile
prealloc-calliope.c MIPS: Clean up tables for bootmem allocation 2010-05-21 21:31:17 +01:00
prealloc-cronus.c MIPS: Clean up tables for bootmem allocation 2010-05-21 21:31:17 +01:00
prealloc-cronuslite.c MIPS: Clean up tables for bootmem allocation 2010-05-21 21:31:17 +01:00
prealloc-zeus.c MIPS: Clean up tables for bootmem allocation 2010-05-21 21:31:17 +01:00
prealloc.h MIPS: Clean up tables for bootmem allocation 2010-05-21 21:31:17 +01:00