blob: 27216d317991af2bc7d212731855a5bb2b12e37e [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
Michael Holzheub2a68c22012-05-09 16:27:36 +020041void *xlate_dev_mem_ptr(unsigned long phys);
42void unxlate_dev_mem_ptr(unsigned long phys, void *addr);
Linus Torvalds1da177e2005-04-16 15:20:36 -070043
44/*
45 * Convert a virtual cached pointer to an uncached pointer
46 */
47#define xlate_dev_kmem_ptr(p) p
48
49#endif /* __KERNEL__ */
50
51#endif