trunk/src/emu/cpu/drcbec.c
| r17687 | r17688 | |
| 982 | 982 | case MAKE_OPCODE_SHORT(OP_CMP, 4, 1): // CMP src1,src2[,f] |
| 983 | 983 | temp32 = PARAM0 - PARAM1; |
| 984 | 984 | flags = FLAGS32_NZCV_SUB(temp32, PARAM0, PARAM1); |
| 985 | // printf("CMP: %08x - %08x = flags %x\n", PARAM0, PARAM1, flags); |
| 985 | 986 | break; |
| 986 | 987 | |
| 987 | 988 | case MAKE_OPCODE_SHORT(OP_MULU, 4, 0): // MULU dst,edst,src1,src2[,f] |
| r17687 | r17688 | |
| 1120 | 1121 | case MAKE_OPCODE_SHORT(OP_SHL, 4, 1): |
| 1121 | 1122 | shift = PARAM2 & 31; |
| 1122 | 1123 | temp32 = PARAM1 << shift; |
| 1123 | | flags = FLAGS32_NZ(temp32); |
| 1124 | | if (shift != 0) flags |= ((PARAM1 << (shift - 1)) >> 31) & FLAG_C; |
| 1124 | if (shift != 0) |
| 1125 | { |
| 1126 | flags = FLAGS32_NZ(temp32); |
| 1127 | flags |= ((PARAM1 << (shift - 1)) >> 31) & FLAG_C; |
| 1128 | } |
| 1125 | 1129 | PARAM0 = temp32; |
| 1126 | 1130 | break; |
| 1127 | 1131 | |
| r17687 | r17688 | |
| 1132 | 1136 | case MAKE_OPCODE_SHORT(OP_SHR, 4, 1): |
| 1133 | 1137 | shift = PARAM2 & 31; |
| 1134 | 1138 | temp32 = PARAM1 >> shift; |
| 1135 | | flags = FLAGS32_NZ(temp32); |
| 1136 | | if (shift != 0) flags |= (PARAM1 >> (shift - 1)) & FLAG_C; |
| 1139 | if (shift != 0) |
| 1140 | { |
| 1141 | flags = FLAGS32_NZ(temp32); |
| 1142 | flags |= (PARAM1 >> (shift - 1)) & FLAG_C; |
| 1143 | } |
| 1137 | 1144 | PARAM0 = temp32; |
| 1138 | 1145 | break; |
| 1139 | 1146 | |
| r17687 | r17688 | |
| 1144 | 1151 | case MAKE_OPCODE_SHORT(OP_SAR, 4, 1): |
| 1145 | 1152 | shift = PARAM2 & 31; |
| 1146 | 1153 | temp32 = (INT32)PARAM1 >> shift; |
| 1147 | | flags = FLAGS32_NZ(temp32); |
| 1148 | | if (shift != 0) flags |= (PARAM1 >> (shift - 1)) & FLAG_C; |
| 1154 | if (shift != 0) |
| 1155 | { |
| 1156 | flags = FLAGS32_NZ(temp32); |
| 1157 | flags |= (PARAM1 >> (shift - 1)) & FLAG_C; |
| 1158 | } |
| 1149 | 1159 | PARAM0 = temp32; |
| 1150 | 1160 | break; |
| 1151 | 1161 | |
| r17687 | r17688 | |
| 1157 | 1167 | case MAKE_OPCODE_SHORT(OP_ROL, 4, 1): |
| 1158 | 1168 | shift = PARAM2 & 31; |
| 1159 | 1169 | temp32 = (PARAM1 << shift) | (PARAM1 >> ((32 - shift) & 31)); |
| 1160 | | flags = FLAGS32_NZ(temp32); |
| 1161 | | if (shift != 0) flags |= ((PARAM1 << (shift - 1)) >> 31) & FLAG_C; |
| 1170 | if (shift != 0) |
| 1171 | { |
| 1172 | flags = FLAGS32_NZ(temp32); |
| 1173 | flags |= ((PARAM1 << (shift - 1)) >> 31) & FLAG_C; |
| 1174 | } |
| 1162 | 1175 | PARAM0 = temp32; |
| 1163 | 1176 | break; |
| 1164 | 1177 | |