]> git.ipfire.org Git - thirdparty/gcc.git/commit
LoongArch: Implement C[LT]Z_DEFINED_VALUE_AT_ZERO
authorLi Wei <liwei@loongson.cn>
Fri, 17 Nov 2023 02:38:02 +0000 (10:38 +0800)
committerLulu Cheng <chenglulu@loongson.cn>
Fri, 17 Nov 2023 08:39:08 +0000 (16:39 +0800)
commit5c8cb429762062f851a56801f021d81f4ecfe3d9
treea26e9423b2188ee1b097c24c1548a3c07082a096
parent1bcb7fe60544bba8b88028f9ffa062336d399664
LoongArch: Implement C[LT]Z_DEFINED_VALUE_AT_ZERO

The LoongArch has defined ctz and clz on the backend, but if we want GCC
do CTZ transformation optimization in forwprop2 pass, GCC need to know
the value of c[lt]z at zero, which may be beneficial for some test cases
(like spec2017 deepsjeng_r).

After implementing the macro, we test dynamic instruction count on
deepsjeng_r:
- before 1688423249186
- after  1660311215745 (1.66% reduction)

gcc/ChangeLog:

* config/loongarch/loongarch.h (CLZ_DEFINED_VALUE_AT_ZERO):
Implement.
(CTZ_DEFINED_VALUE_AT_ZERO): Same.

gcc/testsuite/ChangeLog:

* gcc.dg/pr90838.c: add clz/ctz test support on LoongArch.
gcc/config/loongarch/loongarch.h
gcc/testsuite/gcc.dg/pr90838.c