8326983: Unused operands reported after JDK-8326135

Reviewed-by: kvn, vlivanov
This commit is contained in:
Kuai Wei 2024-03-06 17:02:05 +00:00 committed by Vladimir Kozlov
parent 9f7094079b
commit e92ecd9703
10 changed files with 27 additions and 976 deletions

View File

@ -4087,26 +4087,6 @@ operand immI_56()
interface(CONST_INTER); interface(CONST_INTER);
%} %}
operand immI_63()
%{
predicate(n->get_int() == 63);
match(ConI);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
operand immI_64()
%{
predicate(n->get_int() == 64);
match(ConI);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
operand immI_255() operand immI_255()
%{ %{
predicate(n->get_int() == 255); predicate(n->get_int() == 255);
@ -4236,28 +4216,6 @@ operand immIScale()
interface(CONST_INTER); interface(CONST_INTER);
%} %}
// 26 bit signed offset -- for pc-relative branches
operand immI26()
%{
predicate(((-(1 << 25)) <= n->get_int()) && (n->get_int() < (1 << 25)));
match(ConI);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
// 19 bit signed offset -- for pc-relative loads
operand immI19()
%{
predicate(((-(1 << 18)) <= n->get_int()) && (n->get_int() < (1 << 18)));
match(ConI);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
// 5 bit signed integer // 5 bit signed integer
operand immI5() operand immI5()
%{ %{
@ -4280,27 +4238,6 @@ operand immIU7()
interface(CONST_INTER); interface(CONST_INTER);
%} %}
// 12 bit unsigned offset -- for base plus immediate loads
operand immIU12()
%{
predicate((0 <= n->get_int()) && (n->get_int() < (1 << 12)));
match(ConI);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
operand immLU12()
%{
predicate((0 <= n->get_long()) && (n->get_long() < (1 << 12)));
match(ConL);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
// Offset for scaled or unscaled immediate loads and stores // Offset for scaled or unscaled immediate loads and stores
operand immIOffset() operand immIOffset()
%{ %{
@ -4565,17 +4502,6 @@ operand immL0()
interface(CONST_INTER); interface(CONST_INTER);
%} %}
// 64 bit unit increment
operand immL_1()
%{
predicate(n->get_long() == 1);
match(ConL);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
// 64 bit unit decrement // 64 bit unit decrement
operand immL_M1() operand immL_M1()
%{ %{
@ -4587,19 +4513,6 @@ operand immL_M1()
interface(CONST_INTER); interface(CONST_INTER);
%} %}
// 32 bit offset of pc in thread anchor
operand immL_pc_off()
%{
predicate(n->get_long() == in_bytes(JavaThread::frame_anchor_offset()) +
in_bytes(JavaFrameAnchor::last_Java_pc_offset()));
match(ConL);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
// 64 bit integer valid for add sub immediate // 64 bit integer valid for add sub immediate
operand immLAddSub() operand immLAddSub()
%{ %{
@ -4688,30 +4601,6 @@ operand immByteMapBase()
interface(CONST_INTER); interface(CONST_INTER);
%} %}
// Pointer Immediate Minus One
// this is used when we want to write the current PC to the thread anchor
operand immP_M1()
%{
predicate(n->get_ptr() == -1);
match(ConP);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
// Pointer Immediate Minus Two
// this is used when we want to write the current PC to the thread anchor
operand immP_M2()
%{
predicate(n->get_ptr() == -2);
match(ConP);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
// Float and Double operands // Float and Double operands
// Double Immediate // Double Immediate
operand immD() operand immD()
@ -4976,28 +4865,6 @@ operand iRegL_R0()
interface(REG_INTER); interface(REG_INTER);
%} %}
// Long 64 bit Register R2 only
operand iRegL_R2()
%{
constraint(ALLOC_IN_RC(r2_reg));
match(RegL);
match(iRegLNoSp);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
// Long 64 bit Register R3 only
operand iRegL_R3()
%{
constraint(ALLOC_IN_RC(r3_reg));
match(RegL);
match(iRegLNoSp);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
// Long 64 bit Register R11 only // Long 64 bit Register R11 only
operand iRegL_R11() operand iRegL_R11()
%{ %{
@ -5009,17 +4876,6 @@ operand iRegL_R11()
interface(REG_INTER); interface(REG_INTER);
%} %}
// Pointer 64 bit Register FP only
operand iRegP_FP()
%{
constraint(ALLOC_IN_RC(fp_reg));
match(RegP);
// match(iRegP);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
// Register R0 only // Register R0 only
operand iRegI_R0() operand iRegI_R0()
%{ %{
@ -5078,33 +4934,6 @@ operand iRegN()
interface(REG_INTER); interface(REG_INTER);
%} %}
operand iRegN_R0()
%{
constraint(ALLOC_IN_RC(r0_reg));
match(iRegN);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand iRegN_R2()
%{
constraint(ALLOC_IN_RC(r2_reg));
match(iRegN);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand iRegN_R3()
%{
constraint(ALLOC_IN_RC(r3_reg));
match(iRegN);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
// Integer 64 bit Register not Special // Integer 64 bit Register not Special
operand iRegNNoSp() operand iRegNNoSp()
%{ %{
@ -5255,222 +5084,6 @@ operand vRegD_V7()
interface(REG_INTER); interface(REG_INTER);
%} %}
operand vRegD_V8()
%{
constraint(ALLOC_IN_RC(v8_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand vRegD_V9()
%{
constraint(ALLOC_IN_RC(v9_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand vRegD_V10()
%{
constraint(ALLOC_IN_RC(v10_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand vRegD_V11()
%{
constraint(ALLOC_IN_RC(v11_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand vRegD_V12()
%{
constraint(ALLOC_IN_RC(v12_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand vRegD_V13()
%{
constraint(ALLOC_IN_RC(v13_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand vRegD_V14()
%{
constraint(ALLOC_IN_RC(v14_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand vRegD_V15()
%{
constraint(ALLOC_IN_RC(v15_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand vRegD_V16()
%{
constraint(ALLOC_IN_RC(v16_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand vRegD_V17()
%{
constraint(ALLOC_IN_RC(v17_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand vRegD_V18()
%{
constraint(ALLOC_IN_RC(v18_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand vRegD_V19()
%{
constraint(ALLOC_IN_RC(v19_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand vRegD_V20()
%{
constraint(ALLOC_IN_RC(v20_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand vRegD_V21()
%{
constraint(ALLOC_IN_RC(v21_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand vRegD_V22()
%{
constraint(ALLOC_IN_RC(v22_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand vRegD_V23()
%{
constraint(ALLOC_IN_RC(v23_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand vRegD_V24()
%{
constraint(ALLOC_IN_RC(v24_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand vRegD_V25()
%{
constraint(ALLOC_IN_RC(v25_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand vRegD_V26()
%{
constraint(ALLOC_IN_RC(v26_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand vRegD_V27()
%{
constraint(ALLOC_IN_RC(v27_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand vRegD_V28()
%{
constraint(ALLOC_IN_RC(v28_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand vRegD_V29()
%{
constraint(ALLOC_IN_RC(v29_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand vRegD_V30()
%{
constraint(ALLOC_IN_RC(v30_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand vRegD_V31()
%{
constraint(ALLOC_IN_RC(v31_reg));
match(RegD);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
operand pReg() operand pReg()
%{ %{
constraint(ALLOC_IN_RC(pr_reg)); constraint(ALLOC_IN_RC(pr_reg));
@ -5572,15 +5185,6 @@ operand thread_RegP(iRegP reg)
interface(REG_INTER); interface(REG_INTER);
%} %}
operand lr_RegP(iRegP reg)
%{
constraint(ALLOC_IN_RC(lr_reg)); // link_reg
match(reg);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
//----------Memory Operands---------------------------------------------------- //----------Memory Operands----------------------------------------------------
operand indirect(iRegP reg) operand indirect(iRegP reg)
@ -5655,20 +5259,6 @@ operand indIndex(iRegP reg, iRegL lreg)
%} %}
%} %}
operand indOffI(iRegP reg, immIOffset off)
%{
constraint(ALLOC_IN_RC(ptr_reg));
match(AddP reg off);
op_cost(0);
format %{ "[$reg, $off]" %}
interface(MEMORY_INTER) %{
base($reg);
index(0xffffffff);
scale(0x0);
disp($off);
%}
%}
operand indOffI1(iRegP reg, immIOffset1 off) operand indOffI1(iRegP reg, immIOffset1 off)
%{ %{
constraint(ALLOC_IN_RC(ptr_reg)); constraint(ALLOC_IN_RC(ptr_reg));
@ -5739,20 +5329,6 @@ operand indOffI16(iRegP reg, immIOffset16 off)
%} %}
%} %}
operand indOffL(iRegP reg, immLoffset off)
%{
constraint(ALLOC_IN_RC(ptr_reg));
match(AddP reg off);
op_cost(0);
format %{ "[$reg, $off]" %}
interface(MEMORY_INTER) %{
base($reg);
index(0xffffffff);
scale(0x0);
disp($off);
%}
%}
operand indOffL1(iRegP reg, immLoffset1 off) operand indOffL1(iRegP reg, immLoffset1 off)
%{ %{
constraint(ALLOC_IN_RC(ptr_reg)); constraint(ALLOC_IN_RC(ptr_reg));
@ -5929,22 +5505,6 @@ operand indOffLN(iRegN reg, immLoffset off)
%} %}
// AArch64 opto stubs need to write to the pc slot in the thread anchor
operand thread_anchor_pc(thread_RegP reg, immL_pc_off off)
%{
constraint(ALLOC_IN_RC(ptr_reg));
match(AddP reg off);
op_cost(0);
format %{ "[$reg, $off]" %}
interface(MEMORY_INTER) %{
base($reg);
index(0xffffffff);
scale(0x0);
disp($off);
%}
%}
//----------Special Memory Operands-------------------------------------------- //----------Special Memory Operands--------------------------------------------
// Stack Slot Operand - This operand is used for loading and storing temporary // Stack Slot Operand - This operand is used for loading and storing temporary
// values on the stack where a match requires a value to // values on the stack where a match requires a value to

View File

@ -1737,56 +1737,6 @@ operand immI0() %{
interface(CONST_INTER); interface(CONST_INTER);
%} %}
// Integer Immediate: the value 1
operand immI_1() %{
predicate(n->get_int() == 1);
match(ConI);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
// Integer Immediate: the value 2
operand immI_2() %{
predicate(n->get_int() == 2);
match(ConI);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
// Integer Immediate: the value 3
operand immI_3() %{
predicate(n->get_int() == 3);
match(ConI);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
// Integer Immediate: the value 4
operand immI_4() %{
predicate(n->get_int() == 4);
match(ConI);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
// Integer Immediate: the value 8
operand immI_8() %{
predicate(n->get_int() == 8);
match(ConI);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
// Int Immediate non-negative // Int Immediate non-negative
operand immU31() operand immU31()
%{ %{
@ -1917,27 +1867,6 @@ operand limmIn() %{
interface(CONST_INTER); interface(CONST_INTER);
%} %}
// Long Immediate: the value FF
operand immL_FF() %{
predicate( n->get_long() == 0xFFL );
match(ConL);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
// Long Immediate: the value FFFF
operand immL_FFFF() %{
predicate( n->get_long() == 0xFFFFL );
match(ConL);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
// Pointer Immediate: 32 or 64-bit // Pointer Immediate: 32 or 64-bit
operand immP() %{ operand immP() %{
match(ConP); match(ConP);
@ -1957,36 +1886,6 @@ operand immP0() %{
interface(CONST_INTER); interface(CONST_INTER);
%} %}
// Pointer Immediate
operand immN()
%{
match(ConN);
op_cost(10);
format %{ %}
interface(CONST_INTER);
%}
operand immNKlass()
%{
match(ConNKlass);
op_cost(10);
format %{ %}
interface(CONST_INTER);
%}
// Null Pointer Immediate
operand immN0()
%{
predicate(n->get_narrowcon() == 0);
match(ConN);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
operand immL() %{ operand immL() %{
match(ConL); match(ConL);
op_cost(40); op_cost(40);

View File

@ -501,31 +501,6 @@ operand immIRotn() %{
interface(CONST_INTER); interface(CONST_INTER);
%} %}
operand immIRotneg() %{
// if AsmOperand::is_rotated_imm() is true for this constant, it is
// a immIRot and an optimal instruction combination exists to handle the
// constant as an immIRot
predicate(!AsmOperand::is_rotated_imm(n->get_int()) && AsmOperand::is_rotated_imm(-n->get_int()));
match(ConI);
op_cost(0);
// formats are generated automatically for constants and base registers
format %{ %}
interface(CONST_INTER);
%}
// Non-negative integer immediate that is encodable using the rotation scheme,
// and that when expanded fits in 31 bits.
operand immU31Rot() %{
predicate((0 <= n->get_int()) && AsmOperand::is_rotated_imm(n->get_int()));
match(ConI);
op_cost(0);
// formats are generated automatically for constants and base registers
format %{ %}
interface(CONST_INTER);
%}
operand immPRot() %{ operand immPRot() %{
predicate(n->get_ptr() == 0 || (AsmOperand::is_rotated_imm(n->get_ptr()) && ((ConPNode*)n)->type()->reloc() == relocInfo::none)); predicate(n->get_ptr() == 0 || (AsmOperand::is_rotated_imm(n->get_ptr()) && ((ConPNode*)n)->type()->reloc() == relocInfo::none));
@ -546,15 +521,15 @@ operand immLlowRot() %{
interface(CONST_INTER); interface(CONST_INTER);
%} %}
operand immLRot2() %{ //operand immLRot2() %{
predicate(AsmOperand::is_rotated_imm((int)(n->get_long() >> 32)) && // predicate(AsmOperand::is_rotated_imm((int)(n->get_long() >> 32)) &&
AsmOperand::is_rotated_imm((int)(n->get_long()))); // AsmOperand::is_rotated_imm((int)(n->get_long())));
match(ConL); // match(ConL);
op_cost(0); // op_cost(0);
//
format %{ %} // format %{ %}
interface(CONST_INTER); // interface(CONST_INTER);
%} //%}
// Integer Immediate: 12-bit - for addressing mode // Integer Immediate: 12-bit - for addressing mode
operand immI12() %{ operand immI12() %{

View File

@ -4388,27 +4388,6 @@ operand rarg1RegL() %{
interface(REG_INTER); interface(REG_INTER);
%} %}
operand rarg2RegL() %{
constraint(ALLOC_IN_RC(rarg2_bits64_reg));
match(iRegLdst);
format %{ %}
interface(REG_INTER);
%}
operand rarg3RegL() %{
constraint(ALLOC_IN_RC(rarg3_bits64_reg));
match(iRegLdst);
format %{ %}
interface(REG_INTER);
%}
operand rarg4RegL() %{
constraint(ALLOC_IN_RC(rarg4_bits64_reg));
match(iRegLdst);
format %{ %}
interface(REG_INTER);
%}
// Pointer Destination Register // Pointer Destination Register
// See definition of reg_class bits64_reg_rw. // See definition of reg_class bits64_reg_rw.
operand iRegPdst() %{ operand iRegPdst() %{

View File

@ -2966,19 +2966,6 @@ operand immL_M1()
%} %}
// 32 bit offset of pc in thread anchor
operand immL_pc_off()
%{
predicate(n->get_long() == in_bytes(JavaThread::frame_anchor_offset()) +
in_bytes(JavaFrameAnchor::last_Java_pc_offset()));
match(ConL);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
// 64 bit integer valid for add immediate // 64 bit integer valid for add immediate
operand immLAdd() operand immLAdd()
%{ %{
@ -3186,17 +3173,6 @@ operand iRegLNoSp()
interface(REG_INTER); interface(REG_INTER);
%} %}
// Long 64 bit Register R28 only
operand iRegL_R28()
%{
constraint(ALLOC_IN_RC(r28_reg));
match(RegL);
match(iRegLNoSp);
op_cost(0);
format %{ %}
interface(REG_INTER);
%}
// Long 64 bit Register R29 only // Long 64 bit Register R29 only
operand iRegL_R29() operand iRegL_R29()
%{ %{
@ -3694,22 +3670,6 @@ operand indOffLN(iRegN reg, immLOffset off)
%} %}
%} %}
// RISCV opto stubs need to write to the pc slot in the thread anchor
operand thread_anchor_pc(javaThread_RegP reg, immL_pc_off off)
%{
constraint(ALLOC_IN_RC(ptr_reg));
match(AddP reg off);
op_cost(0);
format %{ "[$reg, $off]" %}
interface(MEMORY_INTER) %{
base($reg);
index(0xffffffff);
scale(0x0);
disp($off);
%}
%}
//----------Special Memory Operands-------------------------------------------- //----------Special Memory Operands--------------------------------------------
// Stack Slot Operand - This operand is used for loading and storing temporary // Stack Slot Operand - This operand is used for loading and storing temporary
// values on the stack where a match requires a value to // values on the stack where a match requires a value to

View File

@ -2578,24 +2578,6 @@ operand uimmI8() %{
interface(CONST_INTER); interface(CONST_INTER);
%} %}
// Integer Immediate: 6-bit
operand uimmI6() %{
predicate(Immediate::is_uimm(n->get_int(), 6));
match(ConI);
op_cost(1);
format %{ %}
interface(CONST_INTER);
%}
// Integer Immediate: 5-bit
operand uimmI5() %{
predicate(Immediate::is_uimm(n->get_int(), 5));
match(ConI);
op_cost(1);
format %{ %}
interface(CONST_INTER);
%}
// Length for SS instructions, given in DWs, // Length for SS instructions, given in DWs,
// possible range [1..512], i.e. [8..4096] Bytes // possible range [1..512], i.e. [8..4096] Bytes
// used range [1..256], i.e. [8..2048] Bytes // used range [1..256], i.e. [8..2048] Bytes
@ -2640,15 +2622,6 @@ operand immI_24() %{
interface(CONST_INTER); interface(CONST_INTER);
%} %}
// Integer Immediate: the value 255
operand immI_255() %{
predicate(n->get_int() == 255);
match(ConI);
op_cost(1);
format %{ %}
interface(CONST_INTER);
%}
// Integer Immediate: the values 32-63 // Integer Immediate: the values 32-63
operand immI_32_63() %{ operand immI_32_63() %{
predicate(n->get_int() >= 32 && n->get_int() <= 63); predicate(n->get_int() >= 32 && n->get_int() <= 63);
@ -2753,37 +2726,10 @@ operand uimmL12() %{
interface(CONST_INTER); interface(CONST_INTER);
%} %}
// Unsigned Long Immediate: 8-bit
operand uimmL8() %{
predicate(Immediate::is_uimm8(n->get_long()));
match(ConL);
op_cost(1);
format %{ %}
interface(CONST_INTER);
%}
//------------------------------------------- //-------------------------------------------
// (UN)SIGNED LONG specific values // (UN)SIGNED LONG specific values
//------------------------------------------- //-------------------------------------------
// Long Immediate: the value FF
operand immL_FF() %{
predicate(n->get_long() == 0xFFL);
match(ConL);
op_cost(1);
format %{ %}
interface(CONST_INTER);
%}
// Long Immediate: the value FFFF
operand immL_FFFF() %{
predicate(n->get_long() == 0xFFFFL);
match(ConL);
op_cost(1);
format %{ %}
interface(CONST_INTER);
%}
// Long Immediate: the value FFFFFFFF // Long Immediate: the value FFFFFFFF
operand immL_FFFFFFFF() %{ operand immL_FFFFFFFF() %{
predicate(n->get_long() == 0xFFFFFFFFL); predicate(n->get_long() == 0xFFFFFFFFL);
@ -2858,15 +2804,6 @@ operand immP() %{
interface(CONST_INTER); interface(CONST_INTER);
%} %}
// Pointer Immediate: 32-bit
operand immP32() %{
predicate(Immediate::is_uimm32(n->get_ptr()));
match(ConP);
op_cost(1);
format %{ %}
interface(CONST_INTER);
%}
// Pointer Immediate: 16-bit // Pointer Immediate: 16-bit
operand immP16() %{ operand immP16() %{
predicate(Immediate::is_uimm16(n->get_ptr())); predicate(Immediate::is_uimm16(n->get_ptr()));
@ -3166,20 +3103,6 @@ operand roddRegP() %{
interface(REG_INTER); interface(REG_INTER);
%} %}
operand lock_ptr_RegP() %{
constraint(ALLOC_IN_RC(z_lock_ptr_reg));
match(RegP);
format %{ %}
interface(REG_INTER);
%}
operand rscratch2RegP() %{
constraint(ALLOC_IN_RC(z_rscratch2_bits64_reg));
match(RegP);
format %{ %}
interface(REG_INTER);
%}
operand iRegN() %{ operand iRegN() %{
constraint(ALLOC_IN_RC(z_int_reg)); constraint(ALLOC_IN_RC(z_int_reg));
match(RegN); match(RegN);
@ -3294,14 +3217,6 @@ operand flagsReg() %{
interface(REG_INTER); interface(REG_INTER);
%} %}
// Condition Code Flag Registers for rules with result tuples
operand TD_flagsReg() %{
constraint(ALLOC_IN_RC(z_condition_reg));
match(RegFlags);
format %{ "CR" %}
interface(REG_TUPLE_DEST_INTER);
%}
operand regD() %{ operand regD() %{
constraint(ALLOC_IN_RC(z_dbl_reg)); constraint(ALLOC_IN_RC(z_dbl_reg));
match(RegD); match(RegD);
@ -3309,13 +3224,6 @@ operand regD() %{
interface(REG_INTER); interface(REG_INTER);
%} %}
operand rscratchRegD() %{
constraint(ALLOC_IN_RC(z_rscratch1_dbl_reg));
match(RegD);
format %{ %}
interface(REG_INTER);
%}
operand regF() %{ operand regF() %{
constraint(ALLOC_IN_RC(z_flt_reg)); constraint(ALLOC_IN_RC(z_flt_reg));
match(RegF); match(RegF);
@ -3323,13 +3231,6 @@ operand regF() %{
interface(REG_INTER); interface(REG_INTER);
%} %}
operand rscratchRegF() %{
constraint(ALLOC_IN_RC(z_rscratch1_flt_reg));
match(RegF);
format %{ %}
interface(REG_INTER);
%}
// Special Registers // Special Registers
// Method Register // Method Register
@ -3340,26 +3241,6 @@ operand inline_cache_regP(iRegP reg) %{
interface(REG_INTER); interface(REG_INTER);
%} %}
// Operands to remove register moves in unscaled mode.
// Match read/write registers with an EncodeP node if neither shift nor add are required.
operand iRegP2N(iRegP reg) %{
predicate(CompressedOops::shift() == 0 && _leaf->as_EncodeP()->in(0) == nullptr);
constraint(ALLOC_IN_RC(z_memory_ptr_reg));
match(EncodeP reg);
format %{ "$reg" %}
interface(REG_INTER)
%}
operand iRegN2P(iRegN reg) %{
predicate(CompressedOops::base() == nullptr && CompressedOops::shift() == 0 &&
_leaf->as_DecodeN()->in(0) == nullptr);
constraint(ALLOC_IN_RC(z_memory_ptr_reg));
match(DecodeN reg);
format %{ "$reg" %}
interface(REG_INTER)
%}
//----------Complex Operands--------------------------------------------------- //----------Complex Operands---------------------------------------------------
// Indirect Memory Reference // Indirect Memory Reference

View File

@ -99,6 +99,18 @@ static void z_store_barrier(MacroAssembler& _masm, const MachNode* node, Address
%} %}
operand no_rax_RegP()
%{
constraint(ALLOC_IN_RC(ptr_no_rax_reg));
match(RegP);
match(rbx_RegP);
match(rsi_RegP);
match(rdi_RegP);
format %{ %}
interface(REG_INTER);
%}
// Load Pointer // Load Pointer
instruct zLoadP(rRegP dst, memory mem, rFlagsReg cr) instruct zLoadP(rRegP dst, memory mem, rFlagsReg cr)
%{ %{

View File

@ -3602,64 +3602,6 @@ operand kReg()
interface(REG_INTER); interface(REG_INTER);
%} %}
operand kReg_K1()
%{
constraint(ALLOC_IN_RC(vectmask_reg_K1));
match(RegVectMask);
format %{%}
interface(REG_INTER);
%}
operand kReg_K2()
%{
constraint(ALLOC_IN_RC(vectmask_reg_K2));
match(RegVectMask);
format %{%}
interface(REG_INTER);
%}
// Special Registers
operand kReg_K3()
%{
constraint(ALLOC_IN_RC(vectmask_reg_K3));
match(RegVectMask);
format %{%}
interface(REG_INTER);
%}
operand kReg_K4()
%{
constraint(ALLOC_IN_RC(vectmask_reg_K4));
match(RegVectMask);
format %{%}
interface(REG_INTER);
%}
operand kReg_K5()
%{
constraint(ALLOC_IN_RC(vectmask_reg_K5));
match(RegVectMask);
format %{%}
interface(REG_INTER);
%}
operand kReg_K6()
%{
constraint(ALLOC_IN_RC(vectmask_reg_K6));
match(RegVectMask);
format %{%}
interface(REG_INTER);
%}
// Special Registers
operand kReg_K7()
%{
constraint(ALLOC_IN_RC(vectmask_reg_K7));
match(RegVectMask);
format %{%}
interface(REG_INTER);
%}
// Register Operands // Register Operands
// Integer Register // Integer Register
operand rRegI() %{ operand rRegI() %{
@ -3737,18 +3679,6 @@ operand eDIRegI(xRegI reg) %{
interface(REG_INTER); interface(REG_INTER);
%} %}
operand naxRegI() %{
constraint(ALLOC_IN_RC(nax_reg));
match(RegI);
match(eCXRegI);
match(eDXRegI);
match(eSIRegI);
match(eDIRegI);
format %{ %}
interface(REG_INTER);
%}
operand nadxRegI() %{ operand nadxRegI() %{
constraint(ALLOC_IN_RC(nadx_reg)); constraint(ALLOC_IN_RC(nadx_reg));
match(RegI); match(RegI);
@ -3836,31 +3766,6 @@ operand eRegP_no_EBP() %{
interface(REG_INTER); interface(REG_INTER);
%} %}
operand naxRegP() %{
constraint(ALLOC_IN_RC(nax_reg));
match(RegP);
match(eBXRegP);
match(eDXRegP);
match(eCXRegP);
match(eSIRegP);
match(eDIRegP);
format %{ %}
interface(REG_INTER);
%}
operand nabxRegP() %{
constraint(ALLOC_IN_RC(nabx_reg));
match(RegP);
match(eCXRegP);
match(eDXRegP);
match(eSIRegP);
match(eDIRegP);
format %{ %}
interface(REG_INTER);
%}
operand pRegP() %{ operand pRegP() %{
constraint(ALLOC_IN_RC(p_reg)); constraint(ALLOC_IN_RC(p_reg));
match(RegP); match(RegP);

View File

@ -2126,28 +2126,6 @@ operand immU31()
interface(CONST_INTER); interface(CONST_INTER);
%} %}
// Constant for long shifts
operand immI_32()
%{
predicate( n->get_int() == 32 );
match(ConI);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
// Constant for long shifts
operand immI_64()
%{
predicate( n->get_int() == 64 );
match(ConI);
op_cost(0);
format %{ %}
interface(CONST_INTER);
%}
// Pointer Immediate // Pointer Immediate
operand immP() operand immP()
%{ %{
@ -2302,28 +2280,6 @@ operand immL_M1()
interface(CONST_INTER); interface(CONST_INTER);
%} %}
// Long Immediate: the value 10
operand immL10()
%{
predicate(n->get_long() == 10);
match(ConL);
format %{ %}
interface(CONST_INTER);
%}
// Long immediate from 0 to 127.
// Used for a shorter form of long mul by 10.
operand immL_127()
%{
predicate(0 <= n->get_long() && n->get_long() < 0x80);
match(ConL);
op_cost(10);
format %{ %}
interface(CONST_INTER);
%}
// Long Immediate: low 32-bit mask // Long Immediate: low 32-bit mask
operand immL_32bits() operand immL_32bits()
%{ %{
@ -2458,64 +2414,6 @@ operand kReg()
interface(REG_INTER); interface(REG_INTER);
%} %}
operand kReg_K1()
%{
constraint(ALLOC_IN_RC(vectmask_reg_K1));
match(RegVectMask);
format %{%}
interface(REG_INTER);
%}
operand kReg_K2()
%{
constraint(ALLOC_IN_RC(vectmask_reg_K2));
match(RegVectMask);
format %{%}
interface(REG_INTER);
%}
// Special Registers
operand kReg_K3()
%{
constraint(ALLOC_IN_RC(vectmask_reg_K3));
match(RegVectMask);
format %{%}
interface(REG_INTER);
%}
operand kReg_K4()
%{
constraint(ALLOC_IN_RC(vectmask_reg_K4));
match(RegVectMask);
format %{%}
interface(REG_INTER);
%}
operand kReg_K5()
%{
constraint(ALLOC_IN_RC(vectmask_reg_K5));
match(RegVectMask);
format %{%}
interface(REG_INTER);
%}
operand kReg_K6()
%{
constraint(ALLOC_IN_RC(vectmask_reg_K6));
match(RegVectMask);
format %{%}
interface(REG_INTER);
%}
// Special Registers
operand kReg_K7()
%{
constraint(ALLOC_IN_RC(vectmask_reg_K7));
match(RegVectMask);
format %{%}
interface(REG_INTER);
%}
// Register Operands // Register Operands
// Integer Register // Integer Register
operand rRegI() operand rRegI()
@ -2663,18 +2561,6 @@ operand rRegN() %{
// the RBP is used as a proper frame pointer and is not included in ptr_reg. As a // the RBP is used as a proper frame pointer and is not included in ptr_reg. As a
// result, RBP is not included in the output of the instruction either. // result, RBP is not included in the output of the instruction either.
operand no_rax_RegP()
%{
constraint(ALLOC_IN_RC(ptr_no_rax_reg));
match(RegP);
match(rbx_RegP);
match(rsi_RegP);
match(rdi_RegP);
format %{ %}
interface(REG_INTER);
%}
// This operand is not allowed to use RBP even if // This operand is not allowed to use RBP even if
// RBP is not used to hold the frame pointer. // RBP is not used to hold the frame pointer.
operand no_rbp_RegP() operand no_rbp_RegP()
@ -2689,17 +2575,6 @@ operand no_rbp_RegP()
interface(REG_INTER); interface(REG_INTER);
%} %}
operand no_rax_rbx_RegP()
%{
constraint(ALLOC_IN_RC(ptr_no_rax_rbx_reg));
match(RegP);
match(rsi_RegP);
match(rdi_RegP);
format %{ %}
interface(REG_INTER);
%}
// Special Registers // Special Registers
// Return a pointer value // Return a pointer value
operand rax_RegP() operand rax_RegP()

View File

@ -720,6 +720,10 @@ public:
// check unused operands // check unused operands
bool ArchDesc::check_usage() { bool ArchDesc::check_usage() {
if (_disable_warnings) {
return true;
}
std::unordered_set<Form*> visited; std::unordered_set<Form*> visited;
MarkUsageFormClosure callback(this, &visited); MarkUsageFormClosure callback(this, &visited);
_instructions.reset(); _instructions.reset();
@ -747,11 +751,12 @@ bool ArchDesc::check_usage() {
callback.do_form_by_name("sRegL"); callback.do_form_by_name("sRegL");
// special generic vector operands only used in Matcher::pd_specialize_generic_vector_operand // special generic vector operands only used in Matcher::pd_specialize_generic_vector_operand
// x86_32 combine x86.ad and x86_32.ad, the vec*/legVec* can not be cleaned from IA32
#if defined(AARCH64) #if defined(AARCH64)
callback.do_form_by_name("vecA"); callback.do_form_by_name("vecA");
callback.do_form_by_name("vecD"); callback.do_form_by_name("vecD");
callback.do_form_by_name("vecX"); callback.do_form_by_name("vecX");
#elif defined(AMD64) #elif defined(IA32) || defined(AMD64)
callback.do_form_by_name("vecS"); callback.do_form_by_name("vecS");
callback.do_form_by_name("vecD"); callback.do_form_by_name("vecD");
callback.do_form_by_name("vecX"); callback.do_form_by_name("vecX");