Commit 249cfea9 authored by Paul Mundt's avatar Paul Mundt

sh: Split out pgtable.h in to _32 and _64 variants.

Signed-off-by: default avatarPaul Mundt <lethal@linux-sh.org>
parent 2b6a8d45
/* /*
* This file is subject to the terms and conditions of the GNU General Public * arch/sh/mm/ioremap_64.c
* License. See the file "COPYING" in the main directory of this archive
* for more details.
*
* arch/sh64/mm/ioremap.c
* *
* Copyright (C) 2000, 2001 Paolo Alberelli * Copyright (C) 2000, 2001 Paolo Alberelli
* Copyright (C) 2003, 2004 Paul Mundt * Copyright (C) 2003 - 2007 Paul Mundt
* *
* Mostly derived from arch/sh/mm/ioremap.c which, in turn is mostly * Mostly derived from arch/sh/mm/ioremap.c which, in turn is mostly
* derived from arch/i386/mm/ioremap.c . * derived from arch/i386/mm/ioremap.c .
* *
* (C) Copyright 1995 1996 Linus Torvalds * (C) Copyright 1995 1996 Linus Torvalds
*
* This file is subject to the terms and conditions of the GNU General Public
* License. See the file "COPYING" in the main directory of this archive
* for more details.
*/ */
#include <linux/vmalloc.h> #include <linux/vmalloc.h>
#include <linux/ioport.h> #include <linux/ioport.h>
#include <linux/module.h> #include <linux/module.h>
#include <linux/mm.h> #include <linux/mm.h>
#include <linux/io.h> #include <linux/io.h>
#include <linux/bootmem.h>
#include <linux/proc_fs.h> #include <linux/proc_fs.h>
#include <asm/page.h> #include <asm/page.h>
#include <asm/pgalloc.h> #include <asm/pgalloc.h>
...@@ -42,7 +43,8 @@ static unsigned long shmedia_ioremap(struct resource *, u32, int); ...@@ -42,7 +43,8 @@ static unsigned long shmedia_ioremap(struct resource *, u32, int);
* have to convert them into an offset in a page-aligned mapping, but the * have to convert them into an offset in a page-aligned mapping, but the
* caller shouldn't need to know that small detail. * caller shouldn't need to know that small detail.
*/ */
void * __ioremap(unsigned long phys_addr, unsigned long size, unsigned long flags) void *__ioremap(unsigned long phys_addr, unsigned long size,
unsigned long flags)
{ {
void * addr; void * addr;
struct vm_struct * area; struct vm_struct * area;
...@@ -83,7 +85,7 @@ void * __ioremap(unsigned long phys_addr, unsigned long size, unsigned long flag ...@@ -83,7 +85,7 @@ void * __ioremap(unsigned long phys_addr, unsigned long size, unsigned long flag
} }
EXPORT_SYMBOL(__ioremap); EXPORT_SYMBOL(__ioremap);
void iounmap(void *addr) void __iounmap(void *addr)
{ {
struct vm_struct *area; struct vm_struct *area;
...@@ -96,7 +98,7 @@ void iounmap(void *addr) ...@@ -96,7 +98,7 @@ void iounmap(void *addr)
kfree(area); kfree(area);
} }
EXPORT_SYMBOL(iounmap); EXPORT_SYMBOL(__iounmap);
static struct resource shmedia_iomap = { static struct resource shmedia_iomap = {
.name = "shmedia_iomap", .name = "shmedia_iomap",
...@@ -265,6 +267,7 @@ static __init_refok void *sh64_get_page(void) ...@@ -265,6 +267,7 @@ static __init_refok void *sh64_get_page(void)
static void shmedia_mapioaddr(unsigned long pa, unsigned long va) static void shmedia_mapioaddr(unsigned long pa, unsigned long va)
{ {
pgd_t *pgdp; pgd_t *pgdp;
pud_t *pudp;
pmd_t *pmdp; pmd_t *pmdp;
pte_t *ptep, pte; pte_t *ptep, pte;
pgprot_t prot; pgprot_t prot;
...@@ -274,11 +277,17 @@ static void shmedia_mapioaddr(unsigned long pa, unsigned long va) ...@@ -274,11 +277,17 @@ static void shmedia_mapioaddr(unsigned long pa, unsigned long va)
pgdp = pgd_offset_k(va); pgdp = pgd_offset_k(va);
if (pgd_none(*pgdp) || !pgd_present(*pgdp)) { if (pgd_none(*pgdp) || !pgd_present(*pgdp)) {
pudp = (pud_t *)sh64_get_page();
set_pgd(pgdp, __pgd((unsigned long)pudp | _KERNPG_TABLE));
}
pudp = pud_offset(pgdp, va);
if (pud_none(*pudp) || !pud_present(*pudp)) {
pmdp = (pmd_t *)sh64_get_page(); pmdp = (pmd_t *)sh64_get_page();
set_pgd(pgdp, __pgd((unsigned long)pmdp | _KERNPG_TABLE)); set_pud(pudp, __pud((unsigned long)pmdp | _KERNPG_TABLE));
} }
pmdp = pmd_offset(pgdp, va); pmdp = pmd_offset(pudp, va);
if (pmd_none(*pmdp) || !pmd_present(*pmdp) ) { if (pmd_none(*pmdp) || !pmd_present(*pmdp) ) {
ptep = (pte_t *)sh64_get_page(); ptep = (pte_t *)sh64_get_page();
set_pmd(pmdp, __pmd((unsigned long)ptep + _PAGE_TABLE)); set_pmd(pmdp, __pmd((unsigned long)ptep + _PAGE_TABLE));
...@@ -302,12 +311,19 @@ static void shmedia_mapioaddr(unsigned long pa, unsigned long va) ...@@ -302,12 +311,19 @@ static void shmedia_mapioaddr(unsigned long pa, unsigned long va)
static void shmedia_unmapioaddr(unsigned long vaddr) static void shmedia_unmapioaddr(unsigned long vaddr)
{ {
pgd_t *pgdp; pgd_t *pgdp;
pud_t *pudp;
pmd_t *pmdp; pmd_t *pmdp;
pte_t *ptep; pte_t *ptep;
pgdp = pgd_offset_k(vaddr); pgdp = pgd_offset_k(vaddr);
pmdp = pmd_offset(pgdp, vaddr); if (pgd_none(*pgdp) || pgd_bad(*pgdp))
return;
pudp = pud_offset(pgdp, vaddr);
if (pud_none(*pudp) || pud_bad(*pudp))
return;
pmdp = pmd_offset(pudp, vaddr);
if (pmd_none(*pmdp) || pmd_bad(*pmdp)) if (pmd_none(*pmdp) || pmd_bad(*pmdp))
return; return;
......
...@@ -96,12 +96,18 @@ typedef struct { unsigned long long pgd; } pgd_t; ...@@ -96,12 +96,18 @@ typedef struct { unsigned long long pgd; } pgd_t;
((x).pte_low | ((unsigned long long)(x).pte_high << 32)) ((x).pte_low | ((unsigned long long)(x).pte_high << 32))
#define __pte(x) \ #define __pte(x) \
({ pte_t __pte = {(x), ((unsigned long long)(x)) >> 32}; __pte; }) ({ pte_t __pte = {(x), ((unsigned long long)(x)) >> 32}; __pte; })
#else #elif defined(CONFIG_SUPERH32)
typedef struct { unsigned long pte_low; } pte_t; typedef struct { unsigned long pte_low; } pte_t;
typedef struct { unsigned long pgprot; } pgprot_t; typedef struct { unsigned long pgprot; } pgprot_t;
typedef struct { unsigned long pgd; } pgd_t; typedef struct { unsigned long pgd; } pgd_t;
#define pte_val(x) ((x).pte_low) #define pte_val(x) ((x).pte_low)
#define __pte(x) ((pte_t) { (x) } ) #define __pte(x) ((pte_t) { (x) } )
#else
typedef struct { unsigned long long pte_low; } pte_t;
typedef struct { unsigned long pgprot; } pgprot_t;
typedef struct { unsigned long pgd; } pgd_t;
#define pte_val(x) ((x).pte_low)
#define __pte(x) ((pte_t) { (x) } )
#endif #endif
#define pgd_val(x) ((x).pgd) #define pgd_val(x) ((x).pgd)
......
This diff is collapsed.
This diff is collapsed.
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