blob: b7ff6afc3caa87fd5d92d4b238a77dd8efced069 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * include/asm-s390/io.h
3 *
4 * S390 version
5 * Copyright (C) 1999 IBM Deutschland Entwicklung GmbH, IBM Corporation
6 * Author(s): Martin Schwidefsky (schwidefsky@de.ibm.com)
7 *
8 * Derived from "include/asm-i386/io.h"
9 */
10
11#ifndef _S390_IO_H
12#define _S390_IO_H
13
14#ifdef __KERNEL__
15
Linus Torvalds1da177e2005-04-16 15:20:36 -070016#include <asm/page.h>
17
18#define IO_SPACE_LIMIT 0xffffffff
19
Linus Torvalds1da177e2005-04-16 15:20:36 -070020/*
21 * Change virtual addresses to physical addresses and vv.
22 * These are pretty trivial
23 */
Adrian Bunk4448aaf2005-11-08 21:34:42 -080024static inline unsigned long virt_to_phys(volatile void * address)
Linus Torvalds1da177e2005-04-16 15:20:36 -070025{
26 unsigned long real_address;
Martin Schwidefsky94c12cc2006-09-28 16:56:43 +020027 asm volatile(
Martin Schwidefsky94c12cc2006-09-28 16:56:43 +020028 " lra %0,0(%1)\n"
Martin Schwidefsky94c12cc2006-09-28 16:56:43 +020029 " jz 0f\n"
30 " la %0,0\n"
Linus Torvalds1da177e2005-04-16 15:20:36 -070031 "0:"
Martin Schwidefsky94c12cc2006-09-28 16:56:43 +020032 : "=a" (real_address) : "a" (address) : "cc");
Linus Torvalds1da177e2005-04-16 15:20:36 -070033 return real_address;
34}
35
Adrian Bunk4448aaf2005-11-08 21:34:42 -080036static inline void * phys_to_virt(unsigned long address)
Linus Torvalds1da177e2005-04-16 15:20:36 -070037{
Martin Schwidefsky022ae412007-02-12 15:49:57 +010038 return (void *) address;
Linus Torvalds1da177e2005-04-16 15:20:36 -070039}
40
Linus Torvalds1da177e2005-04-16 15:20:36 -070041/*
42 * Convert a physical pointer to a virtual kernel pointer for /dev/mem
43 * access
44 */
45#define xlate_dev_mem_ptr(p) __va(p)
46
47/*
48 * Convert a virtual cached pointer to an uncached pointer
49 */
50#define xlate_dev_kmem_ptr(p) p
51
52#endif /* __KERNEL__ */
53
54#endif