riscv: Fix the bug in memory access fixup code
authorAlan Kao <alankao@andestech.com>
Tue, 8 May 2018 02:59:33 +0000 (10:59 +0800)
committerPalmer Dabbelt <palmer@sifive.com>
Mon, 4 Jun 2018 20:33:31 +0000 (13:33 -0700)
commitebcbd75e396258a5041d2b28fec02c27f65d59bb
tree3f48c0cd8ed6fc785005891225ff42169e5b7335
parent29dcea88779c856c7dc92040a0c01233263101d4
riscv: Fix the bug in memory access fixup code

A piece of fixup code is currently shared by __copy_user and
__clear_user.  It first disables the access to user-space memory
and then returns the "n" argument, which represents #(bytes not processed).
However,__copy_user's "n" is in register a2, while __clear_user's in a1,
and thus it causes errors for programs like setdomainname02 testcase in LTP.

This patch fixes this issue by separating their fixup code and returning
the right value for the kernel to handle a relative fault properly.

Signed-off-by: Alan Kao <alankao@andestech.com>
Cc: Greentime Hu <greentime@andestech.com>
Cc: Zong Li <zong@andestech.com>
Cc: Vincent Chen <vincentc@andestech.com>
Signed-off-by: Palmer Dabbelt <palmer@sifive.com>
arch/riscv/lib/uaccess.S