On Thu, Jun 26, 2025 at 6:20 AM H.J. Lu <hjl.to...@gmail.com> wrote:
>
> For tcpsock_test.go in libgo tests,
>
> commit aba3b9d3a48a0703fd565f7c5f0caf604f59970b
> Author: H.J. Lu <hjl.to...@gmail.com>
> Date:   Fri May 9 07:17:07 2025 +0800
>
>     x86: Extend the remove_redundant_vector pass
>
> added an instruction:
>
> (insn 501 101 102 21 (set (reg:V2DI 234)
>         (vec_duplicate:V2DI (reg:DI 111 [ _46 ]))) "tcpsock_test.go":691:12 
> disc
> rim 1 -1
>      (nil))
>
> after
>
> (insn 101 100 501 21 (set (reg:DI 111 [ _46 ])
>         (mem:DI (reg/f:DI 110 [ _45 ]) [5 *_45+0 S8 A64])) 
> "tcpsock_test.go":691
> :12 discrim 1 99 {*movdi_internal}
>      (expr_list:REG_DEAD (reg/f:DI 110 [ _45 ])
>         (expr_list:REG_EH_REGION (const_int 1 [0x1])
>             (nil))))
>
> which resulted in
>
> (insn 101 100 501 21 (set (reg:DI 111 [ _46 ])
>         (mem:DI (reg/f:DI 110 [ _45 ]) [5 *_45+0 S8 A64])) 
> "tcpsock_test.go":691
> :12 discrim 1 99 {*movdi_internal}
>      (expr_list:REG_DEAD (reg/f:DI 110 [ _45 ])
>         (expr_list:REG_EH_REGION (const_int 1 [0x1])
>             (nil))))
> (insn 501 101 102 21 (set (reg:V2DI 234)
>         (vec_duplicate:V2DI (reg:DI 111 [ _46 ]))) "tcpsock_test.go":691:12 
> disc
> rim 1 -1
>      (nil))
>
> and caused:
>
> tcpsock_test.go: In function 'net.TestTCPBig..func2':
> tcpsock_test.go:684:28: error: in basic block 21:
>   684 |                         go func() {
>       |                            ^
> tcpsock_test.go:684:28: error: flow control insn inside a basic block
> (insn 101 100 501 21 (set (reg:DI 111 [ _46 ])
>         (mem:DI (reg/f:DI 110 [ _45 ]) [5 *_45+0 S8 A64])) 
> "tcpsock_test.go":691
> :12 discrim 1 99 {*movdi_internal}
>      (expr_list:REG_DEAD (reg/f:DI 110 [ _45 ])
>         (expr_list:REG_EH_REGION (const_int 1 [0x1])
>             (nil))))
> during RTL pass: rrvl
> tcpsock_test.go:684:28: internal compiler error: in rtl_verify_bb_insns, at 
> cfgr
> tl.cc:2834
>
> Copy the REG_EH_REGION note to the newly added instruction and split the
> block after the previous instruction.
>
> PR target/120816
> * config/i386/i386-features.cc (remove_redundant_vector_load):
> Handle REG_EH_REGION note in DEF_INSN.
>
> OK for master
+     if (note)
+       {
+          control_flow_insns.safe_push (load->def_insn);
+          add_reg_note (insn, REG_EH_REGION,
+                                 XEXP (note, 0));
+       }
I think we don't need to add_reg_not to vec_duplicate insn.

Other LGTM.
I'm wondering if emit_insn_after can be extended to handle this
situation. It looks like a general issue to me, at least we met it
several times.

>
> --
> H.J.



-- 
BR,
Hongtao

Reply via email to