mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-16 05:56:45 +07:00
6a0abce4c4
Update license to use SPDX-License-Identifier instead of verbose license text. Link: http://lkml.kernel.org/r/87ftvccszx.wl-kuninori.morimoto.gx@renesas.com Signed-off-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com> Reviewed-by: Simon Horman <horms+renesas@verge.net.au> Cc: Rich Felker <dalias@libc.org> Cc: Yoshinori Sato <ysato@users.sourceforge.jp> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
86 lines
2.1 KiB
C
86 lines
2.1 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef __ASM_SH_UACCESS_64_H
|
|
#define __ASM_SH_UACCESS_64_H
|
|
|
|
/*
|
|
* include/asm-sh/uaccess_64.h
|
|
*
|
|
* Copyright (C) 2000, 2001 Paolo Alberelli
|
|
* Copyright (C) 2003, 2004 Paul Mundt
|
|
*
|
|
* User space memory access functions
|
|
*
|
|
* Copyright (C) 1999 Niibe Yutaka
|
|
*
|
|
* Based on:
|
|
* MIPS implementation version 1.15 by
|
|
* Copyright (C) 1996, 1997, 1998 by Ralf Baechle
|
|
* and i386 version.
|
|
*/
|
|
|
|
#define __get_user_size(x,ptr,size,retval) \
|
|
do { \
|
|
retval = 0; \
|
|
x = 0; \
|
|
switch (size) { \
|
|
case 1: \
|
|
retval = __get_user_asm_b((void *)&x, \
|
|
(long)ptr); \
|
|
break; \
|
|
case 2: \
|
|
retval = __get_user_asm_w((void *)&x, \
|
|
(long)ptr); \
|
|
break; \
|
|
case 4: \
|
|
retval = __get_user_asm_l((void *)&x, \
|
|
(long)ptr); \
|
|
break; \
|
|
case 8: \
|
|
retval = __get_user_asm_q((void *)&x, \
|
|
(long)ptr); \
|
|
break; \
|
|
default: \
|
|
__get_user_unknown(); \
|
|
break; \
|
|
} \
|
|
} while (0)
|
|
|
|
extern long __get_user_asm_b(void *, long);
|
|
extern long __get_user_asm_w(void *, long);
|
|
extern long __get_user_asm_l(void *, long);
|
|
extern long __get_user_asm_q(void *, long);
|
|
extern void __get_user_unknown(void);
|
|
|
|
#define __put_user_size(x,ptr,size,retval) \
|
|
do { \
|
|
retval = 0; \
|
|
switch (size) { \
|
|
case 1: \
|
|
retval = __put_user_asm_b((void *)&x, \
|
|
(__force long)ptr); \
|
|
break; \
|
|
case 2: \
|
|
retval = __put_user_asm_w((void *)&x, \
|
|
(__force long)ptr); \
|
|
break; \
|
|
case 4: \
|
|
retval = __put_user_asm_l((void *)&x, \
|
|
(__force long)ptr); \
|
|
break; \
|
|
case 8: \
|
|
retval = __put_user_asm_q((void *)&x, \
|
|
(__force long)ptr); \
|
|
break; \
|
|
default: \
|
|
__put_user_unknown(); \
|
|
} \
|
|
} while (0)
|
|
|
|
extern long __put_user_asm_b(void *, long);
|
|
extern long __put_user_asm_w(void *, long);
|
|
extern long __put_user_asm_l(void *, long);
|
|
extern long __put_user_asm_q(void *, long);
|
|
extern void __put_user_unknown(void);
|
|
|
|
#endif /* __ASM_SH_UACCESS_64_H */
|