277 } 278 279 280 void LIRGenerator::cmp_reg_mem(LIR_Condition condition, LIR_Opr reg, LIR_Opr base, int disp, BasicType type, CodeEmitInfo* info) { 281 LIR_Opr o7opr = FrameMap::O7_opr; 282 __ load(new LIR_Address(base, disp, type), o7opr, info); 283 __ cmp(condition, reg, o7opr); 284 } 285 286 287 void LIRGenerator::cmp_reg_mem(LIR_Condition condition, LIR_Opr reg, LIR_Opr base, LIR_Opr disp, BasicType type, CodeEmitInfo* info) { 288 LIR_Opr o7opr = FrameMap::O7_opr; 289 __ load(new LIR_Address(base, disp, type), o7opr, info); 290 __ cmp(condition, reg, o7opr); 291 } 292 293 294 bool LIRGenerator::strength_reduce_multiply(LIR_Opr left, int c, LIR_Opr result, LIR_Opr tmp) { 295 assert(left != result, "should be different registers"); 296 if (is_power_of_2(c + 1)) { 297 __ shift_left(left, log2_intptr(c + 1), result); 298 __ sub(result, left, result); 299 return true; 300 } else if (is_power_of_2(c - 1)) { 301 __ shift_left(left, log2_intptr(c - 1), result); 302 __ add(result, left, result); 303 return true; 304 } 305 return false; 306 } 307 308 309 void LIRGenerator::store_stack_parameter (LIR_Opr item, ByteSize offset_from_sp) { 310 BasicType t = item->type(); 311 LIR_Opr sp_opr = FrameMap::SP_opr; 312 if ((t == T_LONG || t == T_DOUBLE) && 313 ((in_bytes(offset_from_sp) - STACK_BIAS) % 8 != 0)) { 314 __ unaligned_move(item, new LIR_Address(sp_opr, in_bytes(offset_from_sp), t)); 315 } else { 316 __ move(item, new LIR_Address(sp_opr, in_bytes(offset_from_sp), t)); 317 } 318 } 319 320 //---------------------------------------------------------------------- 321 // visitor functions | 277 } 278 279 280 void LIRGenerator::cmp_reg_mem(LIR_Condition condition, LIR_Opr reg, LIR_Opr base, int disp, BasicType type, CodeEmitInfo* info) { 281 LIR_Opr o7opr = FrameMap::O7_opr; 282 __ load(new LIR_Address(base, disp, type), o7opr, info); 283 __ cmp(condition, reg, o7opr); 284 } 285 286 287 void LIRGenerator::cmp_reg_mem(LIR_Condition condition, LIR_Opr reg, LIR_Opr base, LIR_Opr disp, BasicType type, CodeEmitInfo* info) { 288 LIR_Opr o7opr = FrameMap::O7_opr; 289 __ load(new LIR_Address(base, disp, type), o7opr, info); 290 __ cmp(condition, reg, o7opr); 291 } 292 293 294 bool LIRGenerator::strength_reduce_multiply(LIR_Opr left, int c, LIR_Opr result, LIR_Opr tmp) { 295 assert(left != result, "should be different registers"); 296 if (is_power_of_2(c + 1)) { 297 __ shift_left(left, log2_int(c + 1), result); 298 __ sub(result, left, result); 299 return true; 300 } else if (is_power_of_2(c - 1)) { 301 __ shift_left(left, log2_int(c - 1), result); 302 __ add(result, left, result); 303 return true; 304 } 305 return false; 306 } 307 308 309 void LIRGenerator::store_stack_parameter (LIR_Opr item, ByteSize offset_from_sp) { 310 BasicType t = item->type(); 311 LIR_Opr sp_opr = FrameMap::SP_opr; 312 if ((t == T_LONG || t == T_DOUBLE) && 313 ((in_bytes(offset_from_sp) - STACK_BIAS) % 8 != 0)) { 314 __ unaligned_move(item, new LIR_Address(sp_opr, in_bytes(offset_from_sp), t)); 315 } else { 316 __ move(item, new LIR_Address(sp_opr, in_bytes(offset_from_sp), t)); 317 } 318 } 319 320 //---------------------------------------------------------------------- 321 // visitor functions |