Files
linux/arch/xtensa/include/asm
Arnd Bergmann 12700c17fc uaccess: generalize access_ok()
There are many different ways that access_ok() is defined across
architectures, but in the end, they all just compare against the
user_addr_max() value or they accept anything.

Provide one definition that works for most architectures, checking
against TASK_SIZE_MAX for user processes or skipping the check inside
of uaccess_kernel() sections.

For architectures without CONFIG_SET_FS(), this should be the fastest
check, as it comes down to a single comparison of a pointer against a
compile-time constant, while the architecture specific versions tend to
do something more complex for historic reasons or get something wrong.

Type checking for __user annotations is handled inconsistently across
architectures, but this is easily simplified as well by using an inline
function that takes a 'const void __user *' argument. A handful of
callers need an extra __user annotation for this.

Some architectures had trick to use 33-bit or 65-bit arithmetic on the
addresses to calculate the overflow, however this simpler version uses
fewer registers, which means it can produce better object code in the
end despite needing a second (statically predicted) branch.

Reviewed-by: Christoph Hellwig <hch@lst.de>
Acked-by: Mark Rutland <mark.rutland@arm.com> [arm64, asm-generic]
Acked-by: Geert Uytterhoeven <geert@linux-m68k.org>
Acked-by: Stafford Horne <shorne@gmail.com>
Acked-by: Dinh Nguyen <dinguyen@kernel.org>
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
2022-02-25 09:36:05 +01:00
..
2021-10-18 22:19:34 -07:00
2019-11-26 11:33:38 -08:00
2021-11-17 10:36:15 -05:00
2021-10-18 22:19:34 -07:00
2018-12-17 13:48:22 -08:00
2021-12-11 23:31:51 +01:00
2018-02-11 09:18:12 -08:00
2021-07-01 11:06:03 -07:00
2020-01-31 12:17:25 -08:00
2019-09-01 13:11:57 -07:00
2018-01-02 03:25:41 -08:00
2019-04-03 10:32:54 +02:00
2022-02-25 09:36:05 +01:00
2020-02-04 21:57:02 -08:00