Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 11124
b: refs/heads/master
c: c3455b0
h: refs/heads/master
v: v3
  • Loading branch information
Maciej W. Rozycki authored and Ralf Baechle committed Oct 29, 2005
1 parent 66ceb24 commit 4d5c26f
Show file tree
Hide file tree
Showing 6 changed files with 87 additions and 16 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: c134a5ecdb8f4aee09feca0d4d395915e752fcb8
refs/heads/master: c3455b0efc2b5b1bdc755602f77ce7f43725bf61
2 changes: 1 addition & 1 deletion trunk/arch/mips/au1000/common/setup.c
Original file line number Diff line number Diff line change
Expand Up @@ -155,7 +155,7 @@ void __init plat_setup(void)

#if defined(CONFIG_64BIT_PHYS_ADDR)
/* This routine should be valid for all Au1x based boards */
phys_t fixup_bigphys_addr(phys_t phys_addr, phys_t size)
phys_t __fixup_bigphys_addr(phys_t phys_addr, phys_t size)
{
u32 start, end;

Expand Down
15 changes: 3 additions & 12 deletions trunk/arch/mips/mm/ioremap.c
Original file line number Diff line number Diff line change
Expand Up @@ -101,15 +101,6 @@ static int remap_area_pages(unsigned long address, phys_t phys_addr,
return error;
}

/*
* Allow physical addresses to be fixed up to help 36 bit peripherals.
*/
phys_t __attribute__ ((weak))
fixup_bigphys_addr(phys_t phys_addr, phys_t size)
{
return phys_addr;
}

/*
* Generic mapping function (not visible outside):
*/
Expand All @@ -126,7 +117,7 @@ fixup_bigphys_addr(phys_t phys_addr, phys_t size)

#define IS_LOW512(addr) (!((phys_t)(addr) & (phys_t) ~0x1fffffffULL))

void * __ioremap(phys_t phys_addr, phys_t size, unsigned long flags)
void __iomem * __ioremap(phys_t phys_addr, phys_t size, unsigned long flags)
{
struct vm_struct * area;
unsigned long offset;
Expand All @@ -146,7 +137,7 @@ void * __ioremap(phys_t phys_addr, phys_t size, unsigned long flags)
*/
if (IS_LOW512(phys_addr) && IS_LOW512(last_addr) &&
flags == _CACHE_UNCACHED)
return (void *) CKSEG1ADDR(phys_addr);
return (void __iomem *) CKSEG1ADDR(phys_addr);

/*
* Don't allow anybody to remap normal RAM that we're using..
Expand Down Expand Up @@ -182,7 +173,7 @@ void * __ioremap(phys_t phys_addr, phys_t size, unsigned long flags)
return NULL;
}

return (void *) (offset + (char *)addr);
return (void __iomem *) (offset + (char *)addr);
}

#define IS_KSEG1(addr) (((unsigned long)(addr) & ~0x1fffffffUL) == CKSEG1)
Expand Down
31 changes: 29 additions & 2 deletions trunk/include/asm-mips/io.h
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@
#include <asm/processor.h>
#include <asm/string.h>

#include <ioremap.h>
#include <mangle-port.h>

/*
Expand Down Expand Up @@ -209,6 +210,8 @@ extern void __iounmap(volatile void __iomem *addr);
static inline void __iomem * __ioremap_mode(phys_t offset, unsigned long size,
unsigned long flags)
{
#define __IS_LOW512(addr) (!((phys_t)(addr) & (phys_t) ~0x1fffffffULL))

if (cpu_has_64bit_addresses) {
u64 base = UNCAC_BASE;

Expand All @@ -219,9 +222,29 @@ static inline void __iomem * __ioremap_mode(phys_t offset, unsigned long size,
if (flags == _CACHE_UNCACHED)
base = (u64) IO_BASE;
return (void __iomem *) (unsigned long) (base + offset);
} else if (__builtin_constant_p(offset) &&
__builtin_constant_p(size) && __builtin_constant_p(flags)) {
phys_t phys_addr, last_addr;

phys_addr = fixup_bigphys_addr(offset, size);

/* Don't allow wraparound or zero size. */
last_addr = phys_addr + size - 1;
if (!size || last_addr < phys_addr)
return NULL;

/*
* Map uncached objects in the low 512MB of address
* space using KSEG1.
*/
if (__IS_LOW512(phys_addr) && __IS_LOW512(last_addr) &&
flags == _CACHE_UNCACHED)
return (void __iomem *)CKSEG1ADDR(phys_addr);
}

return __ioremap(offset, size, flags);

#undef __IS_LOW512
}

/*
Expand Down Expand Up @@ -273,12 +296,16 @@ static inline void __iomem * __ioremap_mode(phys_t offset, unsigned long size,

static inline void iounmap(volatile void __iomem *addr)
{
if (cpu_has_64bit_addresses)
#define __IS_KSEG1(addr) (((unsigned long)(addr) & ~0x1fffffffUL) == CKSEG1)

if (cpu_has_64bit_addresses ||
(__builtin_constant_p(addr) && __IS_KSEG1(addr)))
return;

__iounmap(addr);
}

#undef __IS_KSEG1
}

#define __BUILD_MEMORY_SINGLE(pfx, bwlq, type, irq) \
\
Expand Down
30 changes: 30 additions & 0 deletions trunk/include/asm-mips/mach-au1x00/ioremap.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
/*
* include/asm-mips/mach-au1x00/ioremap.h
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version
* 2 of the License, or (at your option) any later version.
*/
#ifndef __ASM_MACH_AU1X00_IOREMAP_H
#define __ASM_MACH_AU1X00_IOREMAP_H

#include <linux/config.h>
#include <linux/types.h>

#ifndef CONFIG_64BIT_PHYS_ADDR
static inline phys_t __fixup_bigphys_addr(phys_t phys_addr, phys_t size)
{
return phys_addr;
}
#endif

/*
* Allow physical addresses to be fixed up to help 36-bit peripherals.
*/
static inline phys_t fixup_bigphys_addr(phys_t phys_addr, phys_t size)
{
return __fixup_bigphys_addr(phys_addr, size);
}

#endif /* __ASM_MACH_AU1X00_IOREMAP_H */
23 changes: 23 additions & 0 deletions trunk/include/asm-mips/mach-generic/ioremap.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
/*
* include/asm-mips/mach-generic/ioremap.h
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version
* 2 of the License, or (at your option) any later version.
*/
#ifndef __ASM_MACH_GENERIC_IOREMAP_H
#define __ASM_MACH_GENERIC_IOREMAP_H

#include <linux/types.h>

/*
* Allow physical addresses to be fixed up to help peripherals located
* outside the low 32-bit range -- generic pass-through version.
*/
static inline phys_t fixup_bigphys_addr(phys_t phys_addr, phys_t size)
{
return phys_addr;
}

#endif /* __ASM_MACH_GENERIC_IOREMAP_H */

0 comments on commit 4d5c26f

Please sign in to comment.