MOXA linux-2.6.x / linux-2.6.9-uc0 from sdlinux-moxaart.tgz
[linux-2.6.9-moxart.git] / include / asm-ia64 / sn / rw_mmr.h
blob14309d4d88f3c1804a1081410ffa7b6f212c6cd5
1 /*
2 * This file is subject to the terms and conditions of the GNU General Public
3 * License. See the file "COPYING" in the main directory of this archive
4 * for more details.
6 * Copyright (C) 2002-2003 Silicon Graphics, Inc. All Rights Reserved.
7 */
8 #ifndef _ASM_IA64_SN_RW_MMR_H
9 #define _ASM_IA64_SN_RW_MMR_H
13 * This file contains macros used to access MMR registers via
14 * uncached physical addresses.
15 * pio_phys_read_mmr - read an MMR
16 * pio_phys_write_mmr - write an MMR
17 * pio_atomic_phys_write_mmrs - atomically write 2 MMRs with psr.ic=0
18 * (interrupt collection)
20 * Addresses passed to these routines should be uncached physical addresses
21 * ie., 0x80000....
25 extern inline long
26 pio_phys_read_mmr(volatile long *mmr)
28 long val;
29 asm volatile
30 ("mov r2=psr;;"
31 "rsm psr.i | psr.dt;;"
32 "srlz.i;;"
33 "ld8.acq %0=[%1];;"
34 "mov psr.l=r2;;"
35 "srlz.i;;"
36 : "=r"(val)
37 : "r"(mmr)
38 : "r2");
39 return val;
44 extern inline void
45 pio_phys_write_mmr(volatile long *mmr, long val)
47 asm volatile
48 ("mov r2=psr;;"
49 "rsm psr.i | psr.dt;;"
50 "srlz.i;;"
51 "st8.rel [%0]=%1;;"
52 "mov psr.l=r2;;"
53 "srlz.i;;"
54 :: "r"(mmr), "r"(val)
55 : "r2", "memory");
58 extern inline void
59 pio_atomic_phys_write_mmrs(volatile long *mmr1, long val1, volatile long *mmr2, long val2)
61 asm volatile
62 ("mov r2=psr;;"
63 "rsm psr.i | psr.dt | psr.ic;;"
64 "srlz.i;;"
65 "st8.rel [%0]=%1;"
66 "st8.rel [%2]=%3;;"
67 "mov psr.l=r2;;"
68 "srlz.i;;"
69 :: "r"(mmr1), "r"(val1), "r"(mmr2), "r"(val2)
70 : "r2", "memory");
73 #endif /* _ASM_IA64_SN_RW_MMR_H */