1 %default {"result":"","special":""} 2 /* 3 * 32-bit binary div/rem operation. Handles special case of op0=minint and 4 * op1=-1. 5 */ 6 /* div/rem/lit16 vA, vB, #+CCCC */ 7 /* Need A in rINST, ssssCCCC in ecx, vB in eax */ 8 movzbl rINSTbl, %eax # eax <- 000000BA 9 sarl $$4, %eax # eax <- B 10 GET_VREG %eax, %eax # eax <- vB 11 movswl 2(rPC), %ecx # ecx <- ssssCCCC 12 andb $$0xf, rINSTbl # rINST <- A 13 testl %ecx, %ecx 14 je common_errDivideByZero 15 cmpl $$-1, %ecx 16 jne .L${opcode}_continue_div 17 cmpl $$0x80000000, %eax 18 jne .L${opcode}_continue_div 19 movl $special, %eax 20 SET_VREG %eax, rINST 21 ADVANCE_PC_FETCH_AND_GOTO_NEXT 2 22 23 .L${opcode}_continue_div: 24 mov rIBASE, LOCAL0(%esp) 25 cltd 26 idivl %ecx 27 SET_VREG $result, rINST 28 mov LOCAL0(%esp), rIBASE 29 ADVANCE_PC_FETCH_AND_GOTO_NEXT 2 30