Mercurial > hg > CbC > CbC_gcc
view gcc/config/arm/cortex-m4-fpu.md @ 90:99e7b6776dd1
implemeted __rectype expression. add CbC-exanples/fact-rectype.s
author | Nobuyasu Oshiro <dimolto@cr.ie.u-ryukyu.ac.jp> |
---|---|
date | Sun, 25 Dec 2011 04:04:42 +0900 |
parents | 561a7518be6b |
children | 04ced10e8804 |
line wrap: on
line source
;; ARM Cortex-M4 FPU pipeline description ;; Copyright (C) 2010 Free Software Foundation, Inc. ;; Contributed by CodeSourcery. ;; ;; This file is part of GCC. ;; ;; GCC is free software; you can redistribute it and/or modify it ;; under the terms of the GNU General Public License as published by ;; the Free Software Foundation; either version 3, or (at your option) ;; any later version. ;; ;; GCC is distributed in the hope that it will be useful, but ;; WITHOUT ANY WARRANTY; without even the implied warranty of ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ;; General Public License for more details. ;; ;; You should have received a copy of the GNU General Public License ;; along with GCC; see the file COPYING3. If not see ;; <http://www.gnu.org/licenses/>. ;; Use an artifial unit to model FPU. (define_cpu_unit "cortex_m4_v" "cortex_m4") (define_reservation "cortex_m4_ex_v" "cortex_m4_ex+cortex_m4_v") ;; Integer instructions following VDIV or VSQRT complete out-of-order. (define_insn_reservation "cortex_m4_fdivs" 15 (and (eq_attr "tune" "cortexm4") (eq_attr "type" "fdivs")) "cortex_m4_ex_v,cortex_m4_v*13") (define_insn_reservation "cortex_m4_vmov_1" 1 (and (eq_attr "tune" "cortexm4") (eq_attr "type" "fcpys,fconsts")) "cortex_m4_ex_v") (define_insn_reservation "cortex_m4_vmov_2" 2 (and (eq_attr "tune" "cortexm4") (eq_attr "type" "f_2_r,r_2_f")) "cortex_m4_ex_v*2") (define_insn_reservation "cortex_m4_fmuls" 2 (and (eq_attr "tune" "cortexm4") (eq_attr "type" "fmuls")) "cortex_m4_ex_v") (define_insn_reservation "cortex_m4_fmacs" 4 (and (eq_attr "tune" "cortexm4") (eq_attr "type" "fmacs")) "cortex_m4_ex_v*3") (define_insn_reservation "cortex_m4_ffariths" 1 (and (eq_attr "tune" "cortexm4") (eq_attr "type" "ffariths")) "cortex_m4_ex_v") (define_insn_reservation "cortex_m4_fadds" 2 (and (eq_attr "tune" "cortexm4") (eq_attr "type" "fadds")) "cortex_m4_ex_v") (define_insn_reservation "cortex_m4_fcmps" 1 (and (eq_attr "tune" "cortexm4") (eq_attr "type" "fcmps")) "cortex_m4_ex_v") (define_insn_reservation "cortex_m4_f_flag" 1 (and (eq_attr "tune" "cortexm4") (eq_attr "type" "f_flag")) "cortex_m4_ex_v") (define_insn_reservation "cortex_m4_f_cvt" 2 (and (eq_attr "tune" "cortexm4") (eq_attr "type" "f_cvt")) "cortex_m4_ex_v") (define_insn_reservation "cortex_m4_f_load" 2 (and (eq_attr "tune" "cortexm4") (eq_attr "type" "f_loads")) "cortex_m4_ex_v*2") (define_insn_reservation "cortex_m4_f_store" 2 (and (eq_attr "tune" "cortexm4") (eq_attr "type" "f_stores")) "cortex_m4_ex_v*2") (define_insn_reservation "cortex_m4_f_loadd" 3 (and (eq_attr "tune" "cortexm4") (eq_attr "type" "f_loadd")) "cortex_m4_ex_v*3") (define_insn_reservation "cortex_m4_f_stored" 3 (and (eq_attr "tune" "cortexm4") (eq_attr "type" "f_stored")) "cortex_m4_ex_v*3") ;; MAC instructions consume their addend one cycle later. If the result ;; of an arithmetic instruction is consumed as the addend of the following ;; MAC instruction, the latency can be decreased by one. (define_bypass 1 "cortex_m4_fadds,cortex_m4_fmuls,cortex_m4_f_cvt" "cortex_m4_fmacs" "arm_no_early_mul_dep") (define_bypass 3 "cortex_m4_fmacs" "cortex_m4_fmacs" "arm_no_early_mul_dep") (define_bypass 14 "cortex_m4_fdivs" "cortex_m4_fmacs" "arm_no_early_mul_dep")