diff --git a/src/hotspot/cpu/riscv/riscv_v.ad b/src/hotspot/cpu/riscv/riscv_v.ad index 098bb8e30f2..1132e46c64a 100644 --- a/src/hotspot/cpu/riscv/riscv_v.ad +++ b/src/hotspot/cpu/riscv/riscv_v.ad @@ -359,8 +359,8 @@ instruct vdivD(vReg dst, vReg src1, vReg src2) %{ // vector integer max/min instruct vmax(vReg dst, vReg src1, vReg src2) %{ - predicate(n->bottom_type()->is_vect()->element_basic_type() != T_FLOAT && - n->bottom_type()->is_vect()->element_basic_type() != T_DOUBLE); + predicate(Matcher::vector_element_basic_type(n) != T_FLOAT && + Matcher::vector_element_basic_type(n) != T_DOUBLE); match(Set dst (MaxV src1 src2)); ins_cost(VEC_COST); format %{ "vmax.vv $dst, $src1, $src2\t#@vmax" %} @@ -375,8 +375,8 @@ instruct vmax(vReg dst, vReg src1, vReg src2) %{ %} instruct vmin(vReg dst, vReg src1, vReg src2) %{ - predicate(n->bottom_type()->is_vect()->element_basic_type() != T_FLOAT && - n->bottom_type()->is_vect()->element_basic_type() != T_DOUBLE); + predicate(Matcher::vector_element_basic_type(n) != T_FLOAT && + Matcher::vector_element_basic_type(n) != T_DOUBLE); match(Set dst (MinV src1 src2)); ins_cost(VEC_COST); format %{ "vmin.vv $dst, $src1, $src2\t#@vmin" %} @@ -393,7 +393,7 @@ instruct vmin(vReg dst, vReg src1, vReg src2) %{ // vector float-point max/min instruct vmaxF(vReg dst, vReg src1, vReg src2) %{ - predicate(n->bottom_type()->is_vect()->element_basic_type() == T_FLOAT); + predicate(Matcher::vector_element_basic_type(n) == T_FLOAT); match(Set dst (MaxV src1 src2)); effect(TEMP_DEF dst); ins_cost(VEC_COST); @@ -407,7 +407,7 @@ instruct vmaxF(vReg dst, vReg src1, vReg src2) %{ %} instruct vmaxD(vReg dst, vReg src1, vReg src2) %{ - predicate(n->bottom_type()->is_vect()->element_basic_type() == T_DOUBLE); + predicate(Matcher::vector_element_basic_type(n) == T_DOUBLE); match(Set dst (MaxV src1 src2)); effect(TEMP_DEF dst); ins_cost(VEC_COST); @@ -421,7 +421,7 @@ instruct vmaxD(vReg dst, vReg src1, vReg src2) %{ %} instruct vminF(vReg dst, vReg src1, vReg src2) %{ - predicate(n->bottom_type()->is_vect()->element_basic_type() == T_FLOAT); + predicate(Matcher::vector_element_basic_type(n) == T_FLOAT); match(Set dst (MinV src1 src2)); effect(TEMP_DEF dst); ins_cost(VEC_COST); @@ -435,7 +435,7 @@ instruct vminF(vReg dst, vReg src1, vReg src2) %{ %} instruct vminD(vReg dst, vReg src1, vReg src2) %{ - predicate(n->bottom_type()->is_vect()->element_basic_type() == T_DOUBLE); + predicate(Matcher::vector_element_basic_type(n) == T_DOUBLE); match(Set dst (MinV src1 src2)); effect(TEMP_DEF dst); ins_cost(VEC_COST); @@ -1053,7 +1053,7 @@ instruct vreduce_minL(iRegLNoSp dst, iRegL src1, vReg src2, vReg tmp) %{ // vector float max reduction instruct vreduce_maxF(fRegF dst, fRegF src1, vReg src2, vReg tmp1, vReg tmp2) %{ - predicate(n->in(2)->bottom_type()->is_vect()->element_basic_type() == T_FLOAT); + predicate(Matcher::vector_element_basic_type(n->in(2)) == T_FLOAT); match(Set dst (MaxReductionV src1 src2)); ins_cost(VEC_COST); effect(TEMP_DEF dst, TEMP tmp1, TEMP tmp2); @@ -1068,7 +1068,7 @@ instruct vreduce_maxF(fRegF dst, fRegF src1, vReg src2, vReg tmp1, vReg tmp2) %{ %} instruct vreduce_maxD(fRegD dst, fRegD src1, vReg src2, vReg tmp1, vReg tmp2) %{ - predicate(n->in(2)->bottom_type()->is_vect()->element_basic_type() == T_DOUBLE); + predicate(Matcher::vector_element_basic_type(n->in(2)) == T_DOUBLE); match(Set dst (MaxReductionV src1 src2)); ins_cost(VEC_COST); effect(TEMP_DEF dst, TEMP tmp1, TEMP tmp2); @@ -1085,7 +1085,7 @@ instruct vreduce_maxD(fRegD dst, fRegD src1, vReg src2, vReg tmp1, vReg tmp2) %{ // vector float min reduction instruct vreduce_minF(fRegF dst, fRegF src1, vReg src2, vReg tmp1, vReg tmp2) %{ - predicate(n->in(2)->bottom_type()->is_vect()->element_basic_type() == T_FLOAT); + predicate(Matcher::vector_element_basic_type(n->in(2)) == T_FLOAT); match(Set dst (MinReductionV src1 src2)); ins_cost(VEC_COST); effect(TEMP_DEF dst, TEMP tmp1, TEMP tmp2); @@ -1100,7 +1100,7 @@ instruct vreduce_minF(fRegF dst, fRegF src1, vReg src2, vReg tmp1, vReg tmp2) %{ %} instruct vreduce_minD(fRegD dst, fRegD src1, vReg src2, vReg tmp1, vReg tmp2) %{ - predicate(n->in(2)->bottom_type()->is_vect()->element_basic_type() == T_DOUBLE); + predicate(Matcher::vector_element_basic_type(n->in(2)) == T_DOUBLE); match(Set dst (MinReductionV src1 src2)); ins_cost(VEC_COST); effect(TEMP_DEF dst, TEMP tmp1, TEMP tmp2); @@ -1117,7 +1117,7 @@ instruct vreduce_minD(fRegD dst, fRegD src1, vReg src2, vReg tmp1, vReg tmp2) %{ // vector Math.rint, floor, ceil instruct vroundD(vReg dst, vReg src, immI rmode) %{ - predicate(n->bottom_type()->is_vect()->element_basic_type() == T_DOUBLE); + predicate(Matcher::vector_element_basic_type(n) == T_DOUBLE); match(Set dst (RoundDoubleModeV src rmode)); format %{ "vroundD $dst, $src, $rmode" %} ins_encode %{ @@ -1672,7 +1672,7 @@ instruct vlslL_imm(vReg dst, vReg src, immI shift) %{ %} instruct vshiftcntB(vReg dst, iRegIorL2I cnt) %{ - predicate(n->bottom_type()->is_vect()->element_basic_type() == T_BYTE); + predicate(Matcher::vector_element_basic_type(n) == T_BYTE); match(Set dst (LShiftCntV cnt)); match(Set dst (RShiftCntV cnt)); format %{ "vmv.v.x $dst, $cnt\t#@vshiftcntB" %} @@ -1684,8 +1684,8 @@ instruct vshiftcntB(vReg dst, iRegIorL2I cnt) %{ %} instruct vshiftcntS(vReg dst, iRegIorL2I cnt) %{ - predicate(n->bottom_type()->is_vect()->element_basic_type() == T_SHORT || - n->bottom_type()->is_vect()->element_basic_type() == T_CHAR); + predicate(Matcher::vector_element_basic_type(n) == T_SHORT || + Matcher::vector_element_basic_type(n) == T_CHAR); match(Set dst (LShiftCntV cnt)); match(Set dst (RShiftCntV cnt)); format %{ "vmv.v.x $dst, $cnt\t#@vshiftcntS" %} @@ -1697,7 +1697,7 @@ instruct vshiftcntS(vReg dst, iRegIorL2I cnt) %{ %} instruct vshiftcntI(vReg dst, iRegIorL2I cnt) %{ - predicate(n->bottom_type()->is_vect()->element_basic_type() == T_INT); + predicate(Matcher::vector_element_basic_type(n) == T_INT); match(Set dst (LShiftCntV cnt)); match(Set dst (RShiftCntV cnt)); format %{ "vmv.v.x $dst, $cnt\t#@vshiftcntI" %} @@ -1709,7 +1709,7 @@ instruct vshiftcntI(vReg dst, iRegIorL2I cnt) %{ %} instruct vshiftcntL(vReg dst, iRegIorL2I cnt) %{ - predicate(n->bottom_type()->is_vect()->element_basic_type() == T_LONG); + predicate(Matcher::vector_element_basic_type(n) == T_LONG); match(Set dst (LShiftCntV cnt)); match(Set dst (RShiftCntV cnt)); format %{ "vmv.v.x $dst, $cnt\t#@vshiftcntL" %}