http://gcc.gnu.org/bugzilla/show_bug.cgi?id=55006



--- Comment #14 from Steven Bosscher <steven at gcc dot gnu.org> 2012-12-05 
12:32:24 UTC ---

Nothing new here, just yet another invalid REG_EQUAL note:



The webizer tries to split r51 in this insn:



;; basic block 4, loop depth 0, count 0, freq 7100, maybe hot

;;  prev block 3, next block 5, flags: (REACHABLE, RTL, MODIFIED)

;;  pred:       2 [71.0%]

;; bb 4 artificial_defs: { }

;; bb 4 artificial_uses: { u20(11){ }u21(15){ }u22(32){ }u23(34){ }}

;; lr  in        11 [%r11] 15 [%r15] 32 [%ap] 34 [%fp] 55

;; lr  use       11 [%r11] 15 [%r15] 32 [%ap] 34 [%fp] 55

;; lr  def       48 50

;; live  in      11 [%r11] 15 [%r15] 32 [%ap] 34 [%fp] 55

;; live  gen     48 50

;; live  kill

(code_label 38 6 37 4 4 "" [1 uses])

(note 37 38 58 4 [bb 4] NOTE_INSN_BASIC_BLOCK)

(insn 58 37 5 4 (set (reg:SI 50 [ D.1400 ])

        (reg:SI 55 [ D.1400 ])) 67 {*movsi_zarch}

     (expr_list:REG_EQUAL (mem:SI (plus:DI (reg/v/f:DI 51 [ line ])

                (const_int 12 [0xc])) [4 line_4(D)->sv_flags+0 S4 A32])

        (nil)))



Web oldreg=51 newreg=56

Updating insn 58 (51->56)



But r51 is not live on entry to bb4, and not defined in bb4 before insn58, so

it's a REG_EQUAL use of a dead register.



The sole DEF or r51 is a parameter load, and r55 is set almost immediately

after it:



(note 7 0 2 2 [bb 2] NOTE_INSN_BASIC_BLOCK)

(insn 2 7 3 2 (set (reg/v/f:DI 51 [ line ])

        (reg:DI 2 %r2 [ line ])) t.c:25 63 {*movdi_64}

     (nil))

(note 3 2 9 2 NOTE_INSN_FUNCTION_BEG)

(insn 9 3 10 2 (set (mem/f/c:DI (symbol_ref:DI ("PL_linestr") [flags 0x40] 

<var_decl 0x3fff74f65f0 PL_linestr>) [2 PL_linestr+0 S8 A64])

        (reg/v/f:DI 51 [ line ])) t.c:28 63 {*movdi_64}

     (nil))

(insn 10 9 11 2 (set (reg:SI 55 [ D.1400 ])

        (mem:SI (plus:DI (reg/v/f:DI 51 [ line ])

                (const_int 12 [0xc])) [4 line_4(D)->sv_flags+0 S4 A32])) t.c:29

67 {*movsi_zarch}

     (nil))



r51 dies in in insn 10.

Reply via email to