From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (qmail 16425 invoked by alias); 26 Aug 2008 15:45:51 -0000 Received: (qmail 16412 invoked by uid 22791); 26 Aug 2008 15:45:50 -0000 X-Spam-Check-By: sourceware.org Received: from mail.codesourcery.com (HELO mail.codesourcery.com) (65.74.133.4) by sourceware.org (qpsmtpd/0.31) with ESMTP; Tue, 26 Aug 2008 15:41:29 +0000 Received: (qmail 28756 invoked from network); 26 Aug 2008 15:41:16 -0000 Received: from unknown (HELO wren.home) (paul@127.0.0.2) by mail.codesourcery.com with ESMTPA; 26 Aug 2008 15:41:16 -0000 From: Paul Brook To: gcc-patches@gcc.gnu.org Subject: Move VFP11 scheduler description Date: Tue, 26 Aug 2008 18:50:00 -0000 User-Agent: KMail/1.9.9 MIME-Version: 1.0 Content-Type: Multipart/Mixed; boundary="Boundary-00=_ZQCtI38Gjpb5XpC" Message-Id: <200808261641.13874.paul@codesourcery.com> Mailing-List: contact gcc-patches-help@gcc.gnu.org; run by ezmlm Precedence: bulk List-Id: List-Archive: List-Post: List-Help: Sender: gcc-patches-owner@gcc.gnu.org X-SW-Source: 2008-08/txt/msg01973.txt.bz2 --Boundary-00=_ZQCtI38Gjpb5XpC Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Content-Disposition: inline Content-length: 436 The attached patch moves the VFP11 scheduler description into its own file. No functional changes, just an aesthetic cleanup to separate generic VFP code from the cpu specific scheduler. Tested on arm-none-eabi Applied to svn head. Paul 2008-08-26 Paul Brook * config/arm/vfp.md: Move pipeline description for VFP11 to... * config/arm/vfp11.md: ...here. New. * config/arm/arm.md: Include vfp11.md. --Boundary-00=_ZQCtI38Gjpb5XpC Content-Type: text/x-diff; charset="us-ascii"; name="patch" Content-Transfer-Encoding: 7bit Content-Disposition: inline; filename="patch" Content-length: 7244 Index: gcc/config/arm/vfp.md =================================================================== --- gcc/config/arm/vfp.md (revision 139597) +++ gcc/config/arm/vfp.md (working copy) @@ -1,6 +1,6 @@ -;; ARM VFP coprocessor Machine Description -;; Copyright (C) 2003, 2005, 2006, 2007 Free Software Foundation, Inc. -;; Written by CodeSourcery, LLC. +;; ARM VFP instruction patterns +;; Copyright (C) 2003, 2005, 2006, 2007, 2008 Free Software Foundation, Inc. +;; Written by CodeSourcery. ;; ;; This file is part of GCC. ;; @@ -23,41 +23,6 @@ (define_constants [(VFPCC_REGNUM 127)] ) -;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; -;; Pipeline description -;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; - -(define_automaton "vfp11") - -;; There are 3 pipelines in the VFP11 unit. -;; -;; - A 8-stage FMAC pipeline (7 execute + writeback) with forward from -;; fourth stage for simple operations. -;; -;; - A 5-stage DS pipeline (4 execute + writeback) for divide/sqrt insns. -;; These insns also uses first execute stage of FMAC pipeline. -;; -;; - A 4-stage LS pipeline (execute + 2 memory + writeback) with forward from -;; second memory stage for loads. - -;; We do not model Write-After-Read hazards. -;; We do not do write scheduling with the arm core, so it is only necessary -;; to model the first stage of each pipeline -;; ??? Need to model LS pipeline properly for load/store multiple? -;; We do not model fmstat properly. This could be done by modeling pipelines -;; properly and defining an absence set between a dummy fmstat unit and all -;; other vfp units. - -(define_cpu_unit "fmac" "vfp11") - -(define_cpu_unit "ds" "vfp11") - -(define_cpu_unit "vfp_ls" "vfp11") - -(define_cpu_unit "fmstat" "vfp11") - -(exclusion_set "fmac,ds" "fmstat") - ;; The VFP "type" attributes differ from those used in the FPA model. ;; ffarith Fast floating point insns, e.g. abs, neg, cpy, cmp. ;; farith Most arithmetic insns. @@ -71,51 +36,6 @@ (define_cpu_unit "fmstat" "vfp11") ;; r_2_f Transfer arm to vfp reg. ;; f_cvt Convert floating<->integral -(define_insn_reservation "vfp_ffarith" 4 - (and (eq_attr "generic_vfp" "yes") - (eq_attr "type" "ffarith")) - "fmac") - -(define_insn_reservation "vfp_farith" 8 - (and (eq_attr "generic_vfp" "yes") - (eq_attr "type" "farith,f_cvt")) - "fmac") - -(define_insn_reservation "vfp_fmul" 9 - (and (eq_attr "generic_vfp" "yes") - (eq_attr "type" "fmul")) - "fmac*2") - -(define_insn_reservation "vfp_fdivs" 19 - (and (eq_attr "generic_vfp" "yes") - (eq_attr "type" "fdivs")) - "ds*15") - -(define_insn_reservation "vfp_fdivd" 33 - (and (eq_attr "generic_vfp" "yes") - (eq_attr "type" "fdivd")) - "fmac+ds*29") - -;; Moves to/from arm regs also use the load/store pipeline. -(define_insn_reservation "vfp_fload" 4 - (and (eq_attr "generic_vfp" "yes") - (eq_attr "type" "f_loads,f_loadd,r_2_f")) - "vfp_ls") - -(define_insn_reservation "vfp_fstore" 4 - (and (eq_attr "generic_vfp" "yes") - (eq_attr "type" "f_stores,f_stored,f_2_r")) - "vfp_ls") - -(define_insn_reservation "vfp_to_cpsr" 4 - (and (eq_attr "generic_vfp" "yes") - (eq_attr "type" "f_flag")) - "fmstat,vfp_ls*3") - -;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; -;; Insn pattern -;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; - ;; SImode moves ;; ??? For now do not allow loading constants into vfp regs. This causes ;; problems because small constants get converted into adds. Index: gcc/config/arm/arm.md =================================================================== --- gcc/config/arm/arm.md (revision 139597) +++ gcc/config/arm/arm.md (working copy) @@ -351,6 +351,7 @@ (define_attr "generic_vfp" "yes,no" (include "arm1136jfs.md") (include "cortex-a8.md") (include "cortex-r4.md") +(include "vfp11.md") ;;--------------------------------------------------------------------------- Index: gcc/config/arm/vfp11.md =================================================================== --- gcc/config/arm/vfp11.md (revision 0) +++ gcc/config/arm/vfp11.md (revision 139597) @@ -0,0 +1,93 @@ +;; ARM VFP11 pipeline description +;; Copyright (C) 2003, 2005, 2007, 2008 Free Software Foundation, Inc. +;; Written 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 2, 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 COPYING. If not, write to the Free +;; Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA +;; 02110-1301, USA. */ + +(define_automaton "vfp11") + +;; There are 3 pipelines in the VFP11 unit. +;; +;; - A 8-stage FMAC pipeline (7 execute + writeback) with forward from +;; fourth stage for simple operations. +;; +;; - A 5-stage DS pipeline (4 execute + writeback) for divide/sqrt insns. +;; These insns also uses first execute stage of FMAC pipeline. +;; +;; - A 4-stage LS pipeline (execute + 2 memory + writeback) with forward from +;; second memory stage for loads. + +;; We do not model Write-After-Read hazards. +;; We do not do write scheduling with the arm core, so it is only necessary +;; to model the first stage of each pipeline +;; ??? Need to model LS pipeline properly for load/store multiple? +;; We do not model fmstat properly. This could be done by modeling pipelines +;; properly and defining an absence set between a dummy fmstat unit and all +;; other vfp units. + +(define_cpu_unit "fmac" "vfp11") + +(define_cpu_unit "ds" "vfp11") + +(define_cpu_unit "vfp_ls" "vfp11") + +(define_cpu_unit "fmstat" "vfp11") + +(exclusion_set "fmac,ds" "fmstat") + +(define_insn_reservation "vfp_ffarith" 4 + (and (eq_attr "generic_vfp" "yes") + (eq_attr "type" "ffarith")) + "fmac") + +(define_insn_reservation "vfp_farith" 8 + (and (eq_attr "generic_vfp" "yes") + (eq_attr "type" "farith,f_cvt")) + "fmac") + +(define_insn_reservation "vfp_fmul" 9 + (and (eq_attr "generic_vfp" "yes") + (eq_attr "type" "fmul")) + "fmac*2") + +(define_insn_reservation "vfp_fdivs" 19 + (and (eq_attr "generic_vfp" "yes") + (eq_attr "type" "fdivs")) + "ds*15") + +(define_insn_reservation "vfp_fdivd" 33 + (and (eq_attr "generic_vfp" "yes") + (eq_attr "type" "fdivd")) + "fmac+ds*29") + +;; Moves to/from arm regs also use the load/store pipeline. +(define_insn_reservation "vfp_fload" 4 + (and (eq_attr "generic_vfp" "yes") + (eq_attr "type" "f_loads,f_loadd,r_2_f")) + "vfp_ls") + +(define_insn_reservation "vfp_fstore" 4 + (and (eq_attr "generic_vfp" "yes") + (eq_attr "type" "f_stores,f_stored,f_2_r")) + "vfp_ls") + +(define_insn_reservation "vfp_to_cpsr" 4 + (and (eq_attr "generic_vfp" "yes") + (eq_attr "type" "f_flag")) + "fmstat,vfp_ls*3") + --Boundary-00=_ZQCtI38Gjpb5XpC--