diff options
Diffstat (limited to 'arch/mips/include/asm/mach-generic')
| -rw-r--r-- | arch/mips/include/asm/mach-generic/dma-coherence.h | 14 | ||||
| -rw-r--r-- | arch/mips/include/asm/mach-generic/floppy.h | 6 | ||||
| -rw-r--r-- | arch/mips/include/asm/mach-generic/spaces.h | 8 | 
3 files changed, 17 insertions, 11 deletions
| diff --git a/arch/mips/include/asm/mach-generic/dma-coherence.h b/arch/mips/include/asm/mach-generic/dma-coherence.h index 0f8a354fd468..61addb1677e9 100644 --- a/arch/mips/include/asm/mach-generic/dma-coherence.h +++ b/arch/mips/include/asm/mach-generic/dma-coherence.h @@ -49,7 +49,19 @@ static inline int plat_dma_supported(struct device *dev, u64 mask)  static inline int plat_device_is_coherent(struct device *dev)  { -	return coherentio; +#ifdef CONFIG_DMA_PERDEV_COHERENT +	return dev->archdata.dma_coherent; +#else +	switch (coherentio) { +	default: +	case IO_COHERENCE_DEFAULT: +		return hw_coherentio; +	case IO_COHERENCE_ENABLED: +		return 1; +	case IO_COHERENCE_DISABLED: +		return 0; +	} +#endif  }  #ifndef plat_post_dma_flush diff --git a/arch/mips/include/asm/mach-generic/floppy.h b/arch/mips/include/asm/mach-generic/floppy.h index e2561d99a3fe..9ec2f6a5200b 100644 --- a/arch/mips/include/asm/mach-generic/floppy.h +++ b/arch/mips/include/asm/mach-generic/floppy.h @@ -115,11 +115,7 @@ static inline unsigned long fd_getfdaddr1(void)  static inline unsigned long fd_dma_mem_alloc(unsigned long size)  { -	unsigned long mem; - -	mem = __get_dma_pages(GFP_KERNEL, get_order(size)); - -	return mem; +	return __get_dma_pages(GFP_KERNEL, get_order(size));  }  static inline void fd_dma_mem_free(unsigned long addr, unsigned long size) diff --git a/arch/mips/include/asm/mach-generic/spaces.h b/arch/mips/include/asm/mach-generic/spaces.h index afc96ecb9004..952b0fdfda0e 100644 --- a/arch/mips/include/asm/mach-generic/spaces.h +++ b/arch/mips/include/asm/mach-generic/spaces.h @@ -12,6 +12,8 @@  #include <linux/const.h> +#include <asm/mipsregs.h> +  /*   * This gives the physical RAM offset.   */ @@ -52,11 +54,7 @@  #ifdef CONFIG_64BIT  #ifndef CAC_BASE -#ifdef CONFIG_DMA_NONCOHERENT -#define CAC_BASE		_AC(0x9800000000000000, UL) -#else -#define CAC_BASE		_AC(0xa800000000000000, UL) -#endif +#define CAC_BASE	PHYS_TO_XKPHYS(read_c0_config() & CONF_CM_CMASK, 0)  #endif  #ifndef IO_BASE |