^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 1) /* SPDX-License-Identifier: GPL-2.0 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 2) .globl getcc
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 3) .type getcc,#function
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 4) getcc:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 5) ldx [%o0 + PT_V9_TSTATE], %o1
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 6) srlx %o1, 32, %o1
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 7) and %o1, 0xf, %o1
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 8) retl
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 9) stx %o1, [%o0 + PT_V9_G1]
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 10) .size getcc,.-getcc
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 11)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 12) .globl setcc
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 13) .type setcc,#function
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 14) setcc:
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 15) ldx [%o0 + PT_V9_TSTATE], %o1
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 16) ldx [%o0 + PT_V9_G1], %o2
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 17) or %g0, %ulo(TSTATE_ICC), %o3
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 18) sllx %o3, 32, %o3
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 19) andn %o1, %o3, %o1
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 20) sllx %o2, 32, %o2
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 21) and %o2, %o3, %o2
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 22) or %o1, %o2, %o1
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 23) retl
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 24) stx %o1, [%o0 + PT_V9_TSTATE]
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 25) .size setcc,.-setcc