Commit ad6b9c9d authored by Will Deacon's avatar Will Deacon Committed by Russell King

ARM: 6671/1: LPAE: use phys_addr_t instead of unsigned long in outercache functions

The unsigned long datatype is not sufficient for mapping physical addresses
>= 4GB.

This patch ensures that the phys_addr_t datatype is used to represent
physical addresses when passed to the outer cache functions. Note that the
definitions in struct outer_cache_fns remain as unsigned long because there
are currently no outer cache implementations supporting physical addresses
wider than 32-bits.
Acked-by: default avatarCatalin Marinas <catalin.marinas@arm.com>
Signed-off-by: default avatarWill Deacon <will.deacon@arm.com>
Signed-off-by: default avatarRussell King <rmk+kernel@arm.linux.org.uk>
parent 29a38193
...@@ -21,6 +21,8 @@ ...@@ -21,6 +21,8 @@
#ifndef __ASM_OUTERCACHE_H #ifndef __ASM_OUTERCACHE_H
#define __ASM_OUTERCACHE_H #define __ASM_OUTERCACHE_H
#include <linux/types.h>
struct outer_cache_fns { struct outer_cache_fns {
void (*inv_range)(unsigned long, unsigned long); void (*inv_range)(unsigned long, unsigned long);
void (*clean_range)(unsigned long, unsigned long); void (*clean_range)(unsigned long, unsigned long);
...@@ -37,17 +39,17 @@ struct outer_cache_fns { ...@@ -37,17 +39,17 @@ struct outer_cache_fns {
extern struct outer_cache_fns outer_cache; extern struct outer_cache_fns outer_cache;
static inline void outer_inv_range(unsigned long start, unsigned long end) static inline void outer_inv_range(phys_addr_t start, phys_addr_t end)
{ {
if (outer_cache.inv_range) if (outer_cache.inv_range)
outer_cache.inv_range(start, end); outer_cache.inv_range(start, end);
} }
static inline void outer_clean_range(unsigned long start, unsigned long end) static inline void outer_clean_range(phys_addr_t start, phys_addr_t end)
{ {
if (outer_cache.clean_range) if (outer_cache.clean_range)
outer_cache.clean_range(start, end); outer_cache.clean_range(start, end);
} }
static inline void outer_flush_range(unsigned long start, unsigned long end) static inline void outer_flush_range(phys_addr_t start, phys_addr_t end)
{ {
if (outer_cache.flush_range) if (outer_cache.flush_range)
outer_cache.flush_range(start, end); outer_cache.flush_range(start, end);
...@@ -73,11 +75,11 @@ static inline void outer_disable(void) ...@@ -73,11 +75,11 @@ static inline void outer_disable(void)
#else #else
static inline void outer_inv_range(unsigned long start, unsigned long end) static inline void outer_inv_range(phys_addr_t start, phys_addr_t end)
{ } { }
static inline void outer_clean_range(unsigned long start, unsigned long end) static inline void outer_clean_range(phys_addr_t start, phys_addr_t end)
{ } { }
static inline void outer_flush_range(unsigned long start, unsigned long end) static inline void outer_flush_range(phys_addr_t start, phys_addr_t end)
{ } { }
static inline void outer_flush_all(void) { } static inline void outer_flush_all(void) { }
static inline void outer_inv_all(void) { } static inline void outer_inv_all(void) { }
......
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