> So it's going to check if V2SF can be tied to DI and V4QI with SI. I > suspect those are going to fail for RISC-V as those aren't tieable.
Yes, you are right. Different REG_CLASS are not allowed to be tieable in RISC-V. static bool riscv_modes_tieable_p (machine_mode mode1, machine_mode mode2) { /* We don't allow different REG_CLASS modes tieable since it will cause ICE in register allocation (RA). E.g. V2SI and DI are not tieable. */ if (riscv_v_ext_mode_p (mode1) != riscv_v_ext_mode_p (mode2)) return false; return (mode1 == mode2 || !(GET_MODE_CLASS (mode1) == MODE_FLOAT && GET_MODE_CLASS (mode2) == MODE_FLOAT)); } Pan -----Original Message----- From: Jeff Law <jeffreya...@gmail.com> Sent: Thursday, February 29, 2024 1:33 AM To: Li, Pan2 <pan2...@intel.com>; gcc-patches@gcc.gnu.org Cc: juzhe.zh...@rivai.ai; kito.ch...@gmail.com; richard.guent...@gmail.com; Wang, Yanzhang <yanzhang.w...@intel.com>; rdapp....@gmail.com; Liu, Hongtao <hongtao....@intel.com> Subject: Re: [PATCH v2] DSE: Bugfix ICE after allow vector type in get_stored_val On 2/27/24 21:51, Li, Pan2 wrote: >> if (!targetm.modes_tieable_p (src_int_mode, src_mode)) >> return NULL_RTX; >> if (!targetm.modes_tieable_p (int_mode, mode)) >> return NULL_RTX; > > Yes, will return NULL_RTX for in the first if, given src_int_mode is E_DImode > while src_mode is > E_V2SFmode and mode is E_V4QImode. The extract_low_bits convert the modes > E_V2SFmode/E_V4QImode > to E_DImode/E_SImode in advance before tieable checking, validate_subreg and > gen_lowpart. > > Not sure if my understanding is correct but looks extract_low_bits cannot > take care of vector modes > up to a point because vector modes are always untieable to its' int mode, and > then return NULL_RTX. Well, the code tries to turn the vector mode into a suitable integer mode via int_mode_for_mode. That takes a mode, including vector modes and tries to find an integer mode of the exact same size. So it's going to check if V2SF can be tied to DI and V4QI with SI. I suspect those are going to fail for RISC-V as those aren't tieable. Jeff