riscv: lib: relax assembly constraints in hweight
rd and rs don't have to be the same. In some cases where rs needs to be saved for later usage, this will save us some mv instructions. Signed-off-by: Qingfang Deng <qingfang.deng@siflower.com.cn> Reviewed-by: Xiao Wang <xiao.w.wang@intel.com> Link: https://lore.kernel.org/r/20240527092405.134967-1-dqfext@gmail.com Signed-off-by: Palmer Dabbelt <palmer@rivosinc.com>
This commit is contained in:
parent
6ad8735994
commit
93b63f68d0
@ -26,9 +26,9 @@ static __always_inline unsigned int __arch_hweight32(unsigned int w)
|
|||||||
|
|
||||||
asm (".option push\n"
|
asm (".option push\n"
|
||||||
".option arch,+zbb\n"
|
".option arch,+zbb\n"
|
||||||
CPOPW "%0, %0\n"
|
CPOPW "%0, %1\n"
|
||||||
".option pop\n"
|
".option pop\n"
|
||||||
: "+r" (w) : :);
|
: "=r" (w) : "r" (w) :);
|
||||||
|
|
||||||
return w;
|
return w;
|
||||||
|
|
||||||
@ -57,9 +57,9 @@ static __always_inline unsigned long __arch_hweight64(__u64 w)
|
|||||||
|
|
||||||
asm (".option push\n"
|
asm (".option push\n"
|
||||||
".option arch,+zbb\n"
|
".option arch,+zbb\n"
|
||||||
"cpop %0, %0\n"
|
"cpop %0, %1\n"
|
||||||
".option pop\n"
|
".option pop\n"
|
||||||
: "+r" (w) : :);
|
: "=r" (w) : "r" (w) :);
|
||||||
|
|
||||||
return w;
|
return w;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user