Merge tag 'v3.5-rc6' into irqdomain/next
[deliverable/linux.git] / arch / sh / include / asm / uaccess_64.h
CommitLineData
a23ba435
PM
1#ifndef __ASM_SH_UACCESS_64_H
2#define __ASM_SH_UACCESS_64_H
1da177e4
LT
3
4/*
a23ba435 5 * include/asm-sh/uaccess_64.h
1da177e4
LT
6 *
7 * Copyright (C) 2000, 2001 Paolo Alberelli
8 * Copyright (C) 2003, 2004 Paul Mundt
9 *
10 * User space memory access functions
11 *
12 * Copyright (C) 1999 Niibe Yutaka
13 *
14 * Based on:
15 * MIPS implementation version 1.15 by
16 * Copyright (C) 1996, 1997, 1998 by Ralf Baechle
17 * and i386 version.
18 *
a23ba435
PM
19 * This file is subject to the terms and conditions of the GNU General Public
20 * License. See the file "COPYING" in the main directory of this archive
21 * for more details.
1da177e4 22 */
1da177e4
LT
23
24#define __get_user_size(x,ptr,size,retval) \
25do { \
26 retval = 0; \
27 switch (size) { \
28 case 1: \
88856d67
PM
29 retval = __get_user_asm_b((void *)&x, \
30 (long)ptr); \
1da177e4
LT
31 break; \
32 case 2: \
88856d67
PM
33 retval = __get_user_asm_w((void *)&x, \
34 (long)ptr); \
1da177e4
LT
35 break; \
36 case 4: \
88856d67
PM
37 retval = __get_user_asm_l((void *)&x, \
38 (long)ptr); \
1da177e4
LT
39 break; \
40 case 8: \
88856d67
PM
41 retval = __get_user_asm_q((void *)&x, \
42 (long)ptr); \
1da177e4
LT
43 break; \
44 default: \
45 __get_user_unknown(); \
46 break; \
47 } \
48} while (0)
49
1da177e4
LT
50extern long __get_user_asm_b(void *, long);
51extern long __get_user_asm_w(void *, long);
52extern long __get_user_asm_l(void *, long);
53extern long __get_user_asm_q(void *, long);
54extern void __get_user_unknown(void);
55
56#define __put_user_size(x,ptr,size,retval) \
57do { \
58 retval = 0; \
59 switch (size) { \
60 case 1: \
88856d67
PM
61 retval = __put_user_asm_b((void *)&x, \
62 (long)ptr); \
1da177e4
LT
63 break; \
64 case 2: \
88856d67
PM
65 retval = __put_user_asm_w((void *)&x, \
66 (long)ptr); \
1da177e4
LT
67 break; \
68 case 4: \
88856d67
PM
69 retval = __put_user_asm_l((void *)&x, \
70 (long)ptr); \
1da177e4
LT
71 break; \
72 case 8: \
88856d67
PM
73 retval = __put_user_asm_q((void *)&x, \
74 (long)ptr); \
1da177e4
LT
75 break; \
76 default: \
77 __put_user_unknown(); \
78 } \
79} while (0)
80
1da177e4
LT
81extern long __put_user_asm_b(void *, long);
82extern long __put_user_asm_w(void *, long);
83extern long __put_user_asm_l(void *, long);
84extern long __put_user_asm_q(void *, long);
85extern void __put_user_unknown(void);
86
a23ba435 87#endif /* __ASM_SH_UACCESS_64_H */
This page took 0.593392 seconds and 5 git commands to generate.