annotate gcc/config/riscv/peephole.md @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children 84e7813d76e9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 ;; Peephole optimizations for RISC-V for GNU compiler.
kono
parents:
diff changeset
2 ;; Copyright (C) 2011-2017 Free Software Foundation, Inc.
kono
parents:
diff changeset
3 ;; Contributed by Andrew Waterman (andrew@sifive.com).
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 ;; This file is part of GCC.
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 ;; GCC is free software; you can redistribute it and/or modify
kono
parents:
diff changeset
8 ;; it under the terms of the GNU General Public License as published by
kono
parents:
diff changeset
9 ;; the Free Software Foundation; either version 3, or (at your option)
kono
parents:
diff changeset
10 ;; any later version.
kono
parents:
diff changeset
11
kono
parents:
diff changeset
12 ;; GCC is distributed in the hope that it will be useful,
kono
parents:
diff changeset
13 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
kono
parents:
diff changeset
14 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
kono
parents:
diff changeset
15 ;; GNU General Public License for more details.
kono
parents:
diff changeset
16
kono
parents:
diff changeset
17 ;; You should have received a copy of the GNU General Public License
kono
parents:
diff changeset
18 ;; along with GCC; see the file COPYING3. If not see
kono
parents:
diff changeset
19 ;; <http://www.gnu.org/licenses/>.
kono
parents:
diff changeset
20
kono
parents:
diff changeset
21 ;; Simplify (unsigned long)(unsigned int)a << const
kono
parents:
diff changeset
22 (define_peephole2
kono
parents:
diff changeset
23 [(set (match_operand:DI 0 "register_operand")
kono
parents:
diff changeset
24 (ashift:DI (match_operand:DI 1 "register_operand")
kono
parents:
diff changeset
25 (match_operand 2 "const_int_operand")))
kono
parents:
diff changeset
26 (set (match_operand:DI 3 "register_operand")
kono
parents:
diff changeset
27 (lshiftrt:DI (match_dup 0) (match_dup 2)))
kono
parents:
diff changeset
28 (set (match_operand:DI 4 "register_operand")
kono
parents:
diff changeset
29 (ashift:DI (match_dup 3) (match_operand 5 "const_int_operand")))]
kono
parents:
diff changeset
30 "TARGET_64BIT
kono
parents:
diff changeset
31 && INTVAL (operands[5]) < INTVAL (operands[2])
kono
parents:
diff changeset
32 && (REGNO (operands[3]) == REGNO (operands[4])
kono
parents:
diff changeset
33 || peep2_reg_dead_p (3, operands[3]))"
kono
parents:
diff changeset
34 [(set (match_dup 0)
kono
parents:
diff changeset
35 (ashift:DI (match_dup 1) (match_dup 2)))
kono
parents:
diff changeset
36 (set (match_dup 4)
kono
parents:
diff changeset
37 (lshiftrt:DI (match_dup 0) (match_operand 5)))]
kono
parents:
diff changeset
38 {
kono
parents:
diff changeset
39 operands[5] = GEN_INT (INTVAL (operands[2]) - INTVAL (operands[5]));
kono
parents:
diff changeset
40 })