// SPDX-License-Identifier: GPL-2.0 // Copyright (C) 2005-2017 Andes Technology Corporation #include <linux/linkage.h> #include <asm/assembler.h> #include <asm/errno.h> .macro lbi1 dst, addr, adj USER( lbi.bi, \dst, [\addr], \adj) .endm .macro sbi1 src, addr, adj sbi.bi \src, [\addr], \adj .endm .macro lmw1 start_reg, addr, end_reg USER( lmw.bim, \start_reg, [\addr], \end_reg) .endm .macro smw1 start_reg, addr, end_reg smw.bim \start_reg, [\addr], \end_reg .endm /* Prototype: int __arch_copy_from_user(void *to, const char *from, size_t n) * Purpose : copy a block from user memory to kernel memory * Params : to - kernel memory * : from - user memory * : n - number of bytes to copy * Returns : Number of bytes NOT copied. */ .text ENTRY(__arch_copy_from_user) add $r5, $r0, $r2 #include "copy_template.S" move $r0, $r2 ret .section .fixup,"ax" .align 2 9001: sub $r0, $r5, $r0 ret .previous ENDPROC(__arch_copy_from_user)