__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef __ASM_CSKY_UACCESS_H
#define __ASM_CSKY_UACCESS_H
/*
* __put_user_fn
*/
extern int __put_user_bad(void);
#define __put_user_asm_b(x, ptr, err) \
do { \
int errcode; \
__asm__ __volatile__( \
"1: stb %1, (%2,0) \n" \
" br 3f \n" \
"2: mov %0, %3 \n" \
" br 3f \n" \
".section __ex_table, \"a\" \n" \
".align 2 \n" \
".long 1b,2b \n" \
".previous \n" \
"3: \n" \
: "=r"(err), "=r"(x), "=r"(ptr), "=r"(errcode) \
: "0"(err), "1"(x), "2"(ptr), "3"(-EFAULT) \
: "memory"); \
} while (0)
#define __put_user_asm_h(x, ptr, err) \
do { \
int errcode; \
__asm__ __volatile__( \
"1: sth %1, (%2,0) \n" \
" br 3f \n" \
"2: mov %0, %3 \n" \
" br 3f \n" \
".section __ex_table, \"a\" \n" \
".align 2 \n" \
".long 1b,2b \n" \
".previous \n" \
"3: \n" \
: "=r"(err), "=r"(x), "=r"(ptr), "=r"(errcode) \
: "0"(err), "1"(x), "2"(ptr), "3"(-EFAULT) \
: "memory"); \
} while (0)
#define __put_user_asm_w(x, ptr, err) \
do { \
int errcode; \
__asm__ __volatile__( \
"1: stw %1, (%2,0) \n" \
" br 3f \n" \
"2: mov %0, %3 \n" \
" br 3f \n" \
".section __ex_table,\"a\" \n" \
".align 2 \n" \
".long 1b, 2b \n" \
".previous \n" \
"3: \n" \
: "=r"(err), "=r"(x), "=r"(ptr), "=r"(errcode) \
: "0"(err), "1"(x), "2"(ptr), "3"(-EFAULT) \
: "memory"); \
} while (0)
#define __put_user_asm_64(x, ptr, err) \
do { \
int tmp; \
int errcode; \
\
__asm__ __volatile__( \
" ldw %3, (%1, 0) \n" \
"1: stw %3, (%2, 0) \n" \
" ldw %3, (%1, 4) \n" \
"2: stw %3, (%2, 4) \n" \
" br 4f \n" \
"3: mov %0, %4 \n" \
" br 4f \n" \
".section __ex_table, \"a\" \n" \
".align 2 \n" \
".long 1b, 3b \n" \
".long 2b, 3b \n" \
".previous \n" \
"4: \n" \
: "=r"(err), "=r"(x), "=r"(ptr), \
"=r"(tmp), "=r"(errcode) \
: "0"(err), "1"(x), "2"(ptr), "3"(0), \
"4"(-EFAULT) \
: "memory"); \
} while (0)
static inline int __put_user_fn(size_t size, void __user *ptr, void *x)
{
int retval = 0;
u32 tmp;
switch (size) {
case 1:
tmp = *(u8 *)x;
__put_user_asm_b(tmp, ptr, retval);
break;
case 2:
tmp = *(u16 *)x;
__put_user_asm_h(tmp, ptr, retval);
break;
case 4:
tmp = *(u32 *)x;
__put_user_asm_w(tmp, ptr, retval);
break;
case 8:
__put_user_asm_64(x, (u64 *)ptr, retval);
break;
}
return retval;
}
#define __put_user_fn __put_user_fn
/*
* __get_user_fn
*/
extern int __get_user_bad(void);
#define __get_user_asm_common(x, ptr, ins, err) \
do { \
int errcode; \
__asm__ __volatile__( \
"1: " ins " %1, (%4, 0) \n" \
" br 3f \n" \
"2: mov %0, %2 \n" \
" movi %1, 0 \n" \
" br 3f \n" \
".section __ex_table,\"a\" \n" \
".align 2 \n" \
".long 1b, 2b \n" \
".previous \n" \
"3: \n" \
: "=r"(err), "=r"(x), "=r"(errcode) \
: "0"(0), "r"(ptr), "2"(-EFAULT) \
: "memory"); \
} while (0)
#define __get_user_asm_64(x, ptr, err) \
do { \
int tmp; \
int errcode; \
\
__asm__ __volatile__( \
"1: ldw %3, (%2, 0) \n" \
" stw %3, (%1, 0) \n" \
"2: ldw %3, (%2, 4) \n" \
" stw %3, (%1, 4) \n" \
" br 4f \n" \
"3: mov %0, %4 \n" \
" br 4f \n" \
".section __ex_table, \"a\" \n" \
".align 2 \n" \
".long 1b, 3b \n" \
".long 2b, 3b \n" \
".previous \n" \
"4: \n" \
: "=r"(err), "=r"(x), "=r"(ptr), \
"=r"(tmp), "=r"(errcode) \
: "0"(err), "1"(x), "2"(ptr), "3"(0), \
"4"(-EFAULT) \
: "memory"); \
} while (0)
static inline int __get_user_fn(size_t size, const void __user *ptr, void *x)
{
int retval;
u32 tmp;
switch (size) {
case 1:
__get_user_asm_common(tmp, ptr, "ldb", retval);
*(u8 *)x = (u8)tmp;
break;
case 2:
__get_user_asm_common(tmp, ptr, "ldh", retval);
*(u16 *)x = (u16)tmp;
break;
case 4:
__get_user_asm_common(tmp, ptr, "ldw", retval);
*(u32 *)x = (u32)tmp;
break;
case 8:
__get_user_asm_64(x, ptr, retval);
break;
}
return retval;
}
#define __get_user_fn __get_user_fn
unsigned long raw_copy_from_user(void *to, const void *from, unsigned long n);
unsigned long raw_copy_to_user(void *to, const void *from, unsigned long n);
unsigned long __clear_user(void __user *to, unsigned long n);
#define __clear_user __clear_user
#include <asm-generic/uaccess.h>
#endif /* __ASM_CSKY_UACCESS_H */
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| Kbuild | File | 346 B | 0644 |
|
| addrspace.h | File | 231 B | 0644 |
|
| asid.h | File | 2.38 KB | 0644 |
|
| atomic.h | File | 4.26 KB | 0644 |
|
| barrier.h | File | 2.53 KB | 0644 |
|
| bitops.h | File | 1.29 KB | 0644 |
|
| bug.h | File | 565 B | 0644 |
|
| cache.h | File | 861 B | 0644 |
|
| cacheflush.h | File | 193 B | 0644 |
|
| cachetype.h | File | 174 B | 0644 |
|
| checksum.h | File | 944 B | 0644 |
|
| clocksource.h | File | 159 B | 0644 |
|
| cmpxchg.h | File | 4.16 KB | 0644 |
|
| elf.h | File | 2.66 KB | 0644 |
|
| fixmap.h | File | 747 B | 0644 |
|
| ftrace.h | File | 629 B | 0644 |
|
| futex.h | File | 2.54 KB | 0644 |
|
| highmem.h | File | 1.09 KB | 0644 |
|
| io.h | File | 1.33 KB | 0644 |
|
| irq_work.h | File | 208 B | 0644 |
|
| irqflags.h | File | 1.11 KB | 0644 |
|
| jump_label.h | File | 1.16 KB | 0644 |
|
| kprobes.h | File | 1.13 KB | 0644 |
|
| memory.h | File | 657 B | 0644 |
|
| mmu.h | File | 216 B | 0644 |
|
| mmu_context.h | File | 959 B | 0644 |
|
| page.h | File | 2.34 KB | 0644 |
|
| pci.h | File | 277 B | 0644 |
|
| perf_event.h | File | 359 B | 0644 |
|
| pgalloc.h | File | 1.61 KB | 0644 |
|
| pgtable.h | File | 6.71 KB | 0644 |
|
| probes.h | File | 554 B | 0644 |
|
| processor.h | File | 2.27 KB | 0644 |
|
| ptrace.h | File | 2.53 KB | 0644 |
|
| reg_ops.h | File | 382 B | 0644 |
|
| seccomp.h | File | 283 B | 0644 |
|
| sections.h | File | 246 B | 0644 |
|
| shmparam.h | File | 197 B | 0644 |
|
| smp.h | File | 643 B | 0644 |
|
| spinlock.h | File | 267 B | 0644 |
|
| spinlock_types.h | File | 235 B | 0644 |
|
| stackprotector.h | File | 526 B | 0644 |
|
| string.h | File | 233 B | 0644 |
|
| switch_to.h | File | 923 B | 0644 |
|
| syscall.h | File | 1.32 KB | 0644 |
|
| syscalls.h | File | 351 B | 0644 |
|
| tcm.h | File | 665 B | 0644 |
|
| thread_info.h | File | 2.74 KB | 0644 |
|
| tlb.h | File | 179 B | 0644 |
|
| tlbflush.h | File | 824 B | 0644 |
|
| traps.h | File | 1.41 KB | 0644 |
|
| uaccess.h | File | 4.86 KB | 0644 |
|
| unistd.h | File | 164 B | 0644 |
|
| uprobes.h | File | 669 B | 0644 |
|
| vdso.h | File | 724 B | 0644 |
|
| vmalloc.h | File | 90 B | 0644 |
|