Commit f912d92c authored by Bjorn Helgaas's avatar Bjorn Helgaas Committed by Linus Torvalds

[PATCH] ia64 iomap implementation

This preserves the ioreadX() == inX() semantics (same as i386), since it's
not clear that the speedup of omitting the mf.a for port operations is
worth the risk of breaking drivers.
Signed-off-by: default avatarBjorn Helgaas <bjorn.helgaas@hp.com>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent 0c8ed019
...@@ -32,7 +32,8 @@ ...@@ -32,7 +32,8 @@
*/ */
#define IO_SPACE_LIMIT 0xffffffffffffffffUL #define IO_SPACE_LIMIT 0xffffffffffffffffUL
#define MAX_IO_SPACES 16 #define MAX_IO_SPACES_BITS 4
#define MAX_IO_SPACES (1UL << MAX_IO_SPACES_BITS)
#define IO_SPACE_BITS 24 #define IO_SPACE_BITS 24
#define IO_SPACE_SIZE (1UL << IO_SPACE_BITS) #define IO_SPACE_SIZE (1UL << IO_SPACE_BITS)
...@@ -52,10 +53,24 @@ extern unsigned int num_io_spaces; ...@@ -52,10 +53,24 @@ extern unsigned int num_io_spaces;
# ifdef __KERNEL__ # ifdef __KERNEL__
/*
* All MMIO iomem cookies are in region 6; anything less is a PIO cookie:
* 0xCxxxxxxxxxxxxxxx MMIO cookie (return from ioremap)
* 0x000000001SPPPPPP PIO cookie (S=space number, P..P=port)
*
* ioread/writeX() uses the leading 1 in PIO cookies (PIO_OFFSET) to catch
* code that uses bare port numbers without the prerequisite pci_iomap().
*/
#define PIO_OFFSET (1UL << (MAX_IO_SPACES_BITS + IO_SPACE_BITS))
#define PIO_MASK (PIO_OFFSET - 1)
#define PIO_RESERVED __IA64_UNCACHED_OFFSET
#define HAVE_ARCH_PIO_SIZE
#include <asm/intrinsics.h> #include <asm/intrinsics.h>
#include <asm/machvec.h> #include <asm/machvec.h>
#include <asm/page.h> #include <asm/page.h>
#include <asm/system.h> #include <asm/system.h>
#include <asm-generic/iomap.h>
/* /*
* Change virtual addresses to physical addresses and vv. * Change virtual addresses to physical addresses and vv.
......
...@@ -19,7 +19,10 @@ ...@@ -19,7 +19,10 @@
* *
* Architectures for which this is not true can't use this generic * Architectures for which this is not true can't use this generic
* implementation and should do their own copy. * implementation and should do their own copy.
* */
#ifndef HAVE_ARCH_PIO_SIZE
/*
* We encode the physical PIO addresses (0-0xffff) into the * We encode the physical PIO addresses (0-0xffff) into the
* pointer by offsetting them with a constant (0x10000) and * pointer by offsetting them with a constant (0x10000) and
* assuming that all the low addresses are always PIO. That means * assuming that all the low addresses are always PIO. That means
...@@ -29,6 +32,7 @@ ...@@ -29,6 +32,7 @@
#define PIO_OFFSET 0x10000UL #define PIO_OFFSET 0x10000UL
#define PIO_MASK 0x0ffffUL #define PIO_MASK 0x0ffffUL
#define PIO_RESERVED 0x40000UL #define PIO_RESERVED 0x40000UL
#endif
/* /*
* Ugly macros are a way of life. * Ugly macros are a way of life.
......
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