blob: 0051407cad603a9ef4127470fc98b31ff5ae8413 [file] [log] [blame]
Serguei Katkov6cbe0812016-03-01 16:10:48 +06001/*
2 * Generic one-operand compare-and-branch operation. Provide a "revcmp"
3 * fragment that specifies the *reverse* comparison to perform, e.g.
4 * for "if-le" you would use "gt".
5 *
6 * for: if-eqz, if-nez, if-ltz, if-gez, if-gtz, if-lez
7 */
8 /* if-cmp vAA, +BBBB */
9 cmpl $$0, VREG_ADDRESS(rINSTq) # compare (vA, 0)
Serguei Katkovc8705a72016-02-26 13:00:40 +060010 movl $$2, rINST # assume branch not taken
Serguei Katkov6cbe0812016-03-01 16:10:48 +060011 j${revcmp} 1f
Serguei Katkovc8705a72016-02-26 13:00:40 +060012 movswq 2(rPC), rINSTq # fetch signed displacement
Serguei Katkov6cbe0812016-03-01 16:10:48 +0600131:
Serguei Katkovc8705a72016-02-26 13:00:40 +060014 MTERP_PROFILE_BRANCH
15 addq rINSTq, rINSTq # rINSTq <- AA * 2
16 leaq (rPC, rINSTq), rPC
Serguei Katkov6cbe0812016-03-01 16:10:48 +060017 FETCH_INST
Serguei Katkovc8705a72016-02-26 13:00:40 +060018 jle MterpCheckSuspendAndContinue # AA * 2 <= 0 => suspend check
Serguei Katkov6cbe0812016-03-01 16:10:48 +060019 GOTO_NEXT