aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKaz Kojima <kkojima@gcc.gnu.org>2014-09-29 23:13:32 +0000
committerKaz Kojima <kkojima@gcc.gnu.org>2014-09-29 23:13:32 +0000
commit150dfa34a384bbc247a42989704bf96a9cdae8ad (patch)
tree2bbfc28f4613bd6408cd86f15e06660e93d14a5e
parente76340be8fecb0b441e3c7040703e63f40b890cb (diff)
downloadgcc-150dfa34a384bbc247a42989704bf96a9cdae8ad.zip
gcc-150dfa34a384bbc247a42989704bf96a9cdae8ad.tar.gz
gcc-150dfa34a384bbc247a42989704bf96a9cdae8ad.tar.bz2
sh.md: Use define_c_enum for "unspec" and "unspecv".
* config/sh/sh.md: Use define_c_enum for "unspec" and "unspecv". From-SVN: r215698
-rw-r--r--gcc/ChangeLog4
-rw-r--r--gcc/config/sh/sh.md116
2 files changed, 62 insertions, 58 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index adfe96d..3000eeb 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,7 @@
+2014-09-29 Kaz Kojima <kkojima@gcc.gnu.org>
+
+ * config/sh/sh.md: Use define_c_enum for "unspec" and "unspecv".
+
2014-09-29 Eric Botcazou <ebotcazou@adacore.com>
* tree-vrp.c (get_single_symbol): New function.
diff --git a/gcc/config/sh/sh.md b/gcc/config/sh/sh.md
index 4bee5ca..d6248fd 100644
--- a/gcc/config/sh/sh.md
+++ b/gcc/config/sh/sh.md
@@ -109,73 +109,73 @@
(TR2_REG 130)
(XD0_REG 136)
+])
+(define_c_enum "unspec" [
;; These are used with unspec.
- (UNSPEC_COMPACT_ARGS 0)
- (UNSPEC_MOVA 1)
- (UNSPEC_CASESI 2)
- (UNSPEC_DATALABEL 3)
- (UNSPEC_BBR 4)
- (UNSPEC_SFUNC 5)
- (UNSPEC_PIC 6)
- (UNSPEC_GOT 7)
- (UNSPEC_GOTOFF 8)
- (UNSPEC_PLT 9)
- (UNSPEC_CALLER 10)
- (UNSPEC_GOTPLT 11)
- (UNSPEC_ICACHE 12)
- (UNSPEC_INIT_TRAMP 13)
- (UNSPEC_FCOSA 14)
- (UNSPEC_FSRRA 15)
- (UNSPEC_FSINA 16)
- (UNSPEC_NSB 17)
- (UNSPEC_ALLOCO 18)
- (UNSPEC_TLSGD 20)
- (UNSPEC_TLSLDM 21)
- (UNSPEC_TLSIE 22)
- (UNSPEC_DTPOFF 23)
- (UNSPEC_GOTTPOFF 24)
- (UNSPEC_TPOFF 25)
- (UNSPEC_RA 26)
- (UNSPEC_DIV_INV_M0 30)
- (UNSPEC_DIV_INV_M1 31)
- (UNSPEC_DIV_INV_M2 32)
- (UNSPEC_DIV_INV_M3 33)
- (UNSPEC_DIV_INV20 34)
- (UNSPEC_DIV_INV_TABLE 37)
- (UNSPEC_ASHIFTRT 35)
- (UNSPEC_THUNK 36)
- (UNSPEC_CHKADD 38)
- (UNSPEC_SP_SET 40)
- (UNSPEC_SP_TEST 41)
- (UNSPEC_MOVUA 42)
-
+ UNSPEC_COMPACT_ARGS
+ UNSPEC_MOVA
+ UNSPEC_CASESI
+ UNSPEC_DATALABEL
+ UNSPEC_BBR
+ UNSPEC_SFUNC
+ UNSPEC_PIC
+ UNSPEC_GOT
+ UNSPEC_GOTOFF
+ UNSPEC_PLT
+ UNSPEC_CALLER
+ UNSPEC_GOTPLT
+ UNSPEC_ICACHE
+ UNSPEC_INIT_TRAMP
+ UNSPEC_FCOSA
+ UNSPEC_FSRRA
+ UNSPEC_FSINA
+ UNSPEC_NSB
+ UNSPEC_ALLOCO
+ UNSPEC_TLSGD
+ UNSPEC_TLSLDM
+ UNSPEC_TLSIE
+ UNSPEC_DTPOFF
+ UNSPEC_GOTTPOFF
+ UNSPEC_TPOFF
+ UNSPEC_RA
+ UNSPEC_DIV_INV_M0
+ UNSPEC_DIV_INV_M1
+ UNSPEC_DIV_INV_M2
+ UNSPEC_DIV_INV_M3
+ UNSPEC_DIV_INV20
+ UNSPEC_DIV_INV_TABLE
+ UNSPEC_ASHIFTRT
+ UNSPEC_THUNK
+ UNSPEC_CHKADD
+ UNSPEC_SP_SET
+ UNSPEC_SP_TEST
+ UNSPEC_MOVUA
;; (unspec [VAL SHIFT] UNSPEC_EXTRACT_S16) computes (short) (VAL >> SHIFT).
;; UNSPEC_EXTRACT_U16 is the unsigned equivalent.
- (UNSPEC_EXTRACT_S16 43)
- (UNSPEC_EXTRACT_U16 44)
-
+ UNSPEC_EXTRACT_S16
+ UNSPEC_EXTRACT_U16
;; (unspec [TARGET ANCHOR] UNSPEC_SYMOFF) == TARGET - ANCHOR.
- (UNSPEC_SYMOFF 45)
-
+ UNSPEC_SYMOFF
;; (unspec [OFFSET ANCHOR] UNSPEC_PCREL_SYMOFF) == OFFSET - (ANCHOR - .).
- (UNSPEC_PCREL_SYMOFF 46)
-
+ UNSPEC_PCREL_SYMOFF
;; Misc builtins
- (UNSPEC_BUILTIN_STRLEN 47)
+ UNSPEC_BUILTIN_STRLEN
+])
+(define_c_enum "unspecv" [
;; These are used with unspec_volatile.
- (UNSPECV_BLOCKAGE 0)
- (UNSPECV_ALIGN 1)
- (UNSPECV_CONST2 2)
- (UNSPECV_CONST4 4)
- (UNSPECV_CONST8 6)
- (UNSPECV_WINDOW_END 10)
- (UNSPECV_CONST_END 11)
- (UNSPECV_EH_RETURN 12)
- (UNSPECV_GBR 13)
- (UNSPECV_SP_SWITCH_B 14)
- (UNSPECV_SP_SWITCH_E 15)
+ UNSPECV_BLOCKAGE
+ UNSPECV_ALIGN
+ UNSPECV_CONST2
+ UNSPECV_CONST4
+ UNSPECV_CONST8
+ UNSPECV_WINDOW_END
+ UNSPECV_CONST_END
+ UNSPECV_EH_RETURN
+ UNSPECV_GBR
+ UNSPECV_SP_SWITCH_B
+ UNSPECV_SP_SWITCH_E
])
;; -------------------------------------------------------------------------