2 * linux/arch/arm26/lib/putuser.S
4 * Copyright (C) 2001 Russell King
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License version 2 as
8 * published by the Free Software Foundation.
10 * Idea from x86 version, (C) Copyright 1998 Linus Torvalds
12 * These functions have a non-standard call interface to make
13 * them more efficient, especially as they return an error
14 * value in addition to the "real" return value.
18 * Inputs: r0 contains the address
19 * r1, r2 contains the value
20 * Outputs: r0 is the error code
23 * No other registers must be altered. (see include/asm-arm/uaccess.h
24 * for specific ASM register usage).
26 * Note that ADDR_LIMIT is either 0 or 0xc0000000
27 * Note also that it is intended that __put_user_bad is not global.
29 #include <asm/asm-offsets.h>
30 #include <asm/thread_info.h>
31 #include <asm/errno.h>
38 ldr r2, [r2, #TI_ADDR_LIMIT]
42 1: cmp r0, #0x02000000
53 ldr r2, [r2, #TI_ADDR_LIMIT]
57 2: cmp r0, #0x02000000
71 ldr r2, [r2, #TI_ADDR_LIMIT]
86 ldr ip, [ip, #TI_ADDR_LIMIT]
91 5: strlst r1, [r0], #4
102 .section __ex_table, "a"
103 .long 1b, __put_user_bad
104 .long 2b, __put_user_bad
105 .long 3b, __put_user_bad
106 .long 4b, __put_user_bad
107 .long 5b, __put_user_bad
108 .long 6b, __put_user_bad