1. 18 Oct, 2016 1 commit
    • jcmvbkbc's avatar
      xtensa: add HW FPU sequences for DIV/SQRT/RECIP/RSQRT · 2b7e7fc4
      jcmvbkbc authored
      Use new FPU instruction sequences documented in the ISA book to
      implement __divsf3, __divdf3, __recipsf2, __recipdf2, __rsqrtsf2,
      __rsqrtdf2 and __ieee754_sqrtf and __ieee754_sqrt.
      2016-10-18  Ding-Kai Chen  <dkchen@cadence.com>
      	* config/xtensa/ieee754-df.S (__recipdf2, __rsqrtdf2,
      	__ieee754_sqrt): New functions.
      	(__divdf3): Add implementation with new FPU instructions under
      	#if XCHAL_HAVE_DFP_DIV.
      	* config/xtensa/ieee754-sf.S (__recipsf2, __rsqrtsf2,
      	__ieee754_sqrtf): New functions.
      	(__divsf3): Add implementation with new FPU instructions under
      	#if XCHAL_HAVE_FP_DIV.
      	* config/xtensa/t-xtensa (LIB1ASMFUNCS): Add _sqrtf, _recipsf2
      	_rsqrtsf2, _sqrt, _recipdf2 and _rsqrtdf2.
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@241312 138bc75d-0d04-0410-961f-82ee72b054a4
  2. 17 Feb, 2016 1 commit
    • jcmvbkbc's avatar
      xtensa: fix libgcc build with --text-section-literals · 1fa780ac
      jcmvbkbc authored
      Functions __muldf3_aux, __divdf3_aux, __mulsf3_aux and __divsf3_aux
      don't start with leaf_entry, so they need explicit .literal_position,
      otherwise libgcc build fails in the presence of --text-section-literals.
      2016-02-17  Max Filippov  <jcmvbkbc@gmail.com>
      	* config/xtensa/ieee754-df.S (__muldf3_aux, __divdf3_aux): Add
      	.literal_position before the function.
      	* config/xtensa/ieee754-sf.S (__mulsf3_aux, __divsf3_aux):
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@233505 138bc75d-0d04-0410-961f-82ee72b054a4
  3. 04 Jan, 2016 1 commit
  4. 05 Jan, 2015 1 commit
  5. 02 Jan, 2014 1 commit
  6. 04 Feb, 2013 1 commit
  7. 02 Nov, 2011 1 commit
    • ro's avatar
      Move libgcc1 to toplevel libgcc · 9213d2eb
      ro authored
      	* Makefile.in (LIB1ASMSRC): Don't export.
      	(libgcc.mvars): Don't emit LIB1ASMFUNCS, LIB1ASMSRC.
      	* config/arm/arm.c: Update lib1funcs.asm filename.
      	* config/arm/linux-eabi.h: Likewise.
      	* config/arm/bpabi-v6m.S, config/arm/bpabi.S,
      	config/arm/ieee754-df.S, config/arm/ieee754-sf.S: Move to
      	* config/arm/lib1funcs.asm: Move to ../libgcc/config/arm/lib1funcs.S.
      	* config/arm/t-arm (LIB1ASMSRC, LIB1ASMFUNCS): Remove.
      	* config/arm/t-arm-elf (LIB1ASMFUNCS): Remove.
      	* config/arm/t-bpabi: Likewise.
      	* config/arm/t-linux (LIB1ASMSRC, LIB1ASMFUNCS): Remove.
      	* config/arm/t-linux-eabi (LIB1ASMFUNCS): Remove.
      	* config/arm/t-strongarm-elf: Likewise.
      	* config/arm/t-symbian: Likewise.
      	* config/arm/t-vxworks: Likewise.
      	* config/arm/t-wince-pe: Likewise.
      	* config/avr/libgcc.S: Move to ../libgcc/config/avr.
      	* config/avr/t-avr (LIB1ASMSRC, LIB1ASMFUNCS): Remove.
      	* config/bfin/lib1funcs.asm: Move to
      	* config/bfin/t-bfin: Remove.
      	* config/bfin/t-bfin-elf (LIB1ASMSRC, LIB1ASMFUNCS): Remove.
      	* config/bfin/t-bfin-linux: Likewise.
      	* config/bfin/t-bfin-uclinux: Likewise.
      	* config/c6x/lib1funcs.asm: Move to
      	* config/c6x/t-c6x-elf (LIB1ASMSRC, LIB1ASMFUNCS): Remove.
      	* config/fr30/lib1funcs.asm: Move to
      	* config/fr30/t-fr30 (LIB1ASMSRC, LIB1ASMFUNCS): Remove.
      	* config/frv/lib1funcs.asm: Move to
      	* config/frv/t-frv (CROSS_LIBGCC1, LIB1ASMSRC, LIB1ASMFUNCS): Remove.
      	* config/h8300/fixunssfsi.c: Update lib1funcs.asm filename.
      	* config/h8300/lib1funcs.asm: Move to
      	* config/h8300/t-h8300 (LIB1ASMSRC, LIB1ASMFUNCS): Remove.
      	* config/i386/cygwin.asm: Move to ../libgcc/config/i386/cygwin.S.
      	* config/i386/t-cygming (LIB1ASMSRC, LIB1ASMFUNCS): Remove.
      	* config/i386/t-interix: Likewise.
      	* config/ia64/lib1funcs.asm: Move to
      	* config/ia64/t-hpux (LIB1ASMFUNCS, LIBGCC1_TEST): Remove.
      	* config/ia64/t-ia64 (LIB1ASMSRC, LIB1ASMFUNCS): Remove.
      	* config/iq2000/t-iq2000 (LIBGCC1, CROSS_LIBGCC1): Remove.
      	* config/m32c/m32c.c: Update m32c-lib1.S filename.
      	* config/m32c/m32c-lib1.S: Move to ../libgcc/config/m32c/lib1funcs.S.
      	* config/m32c/t-m32c (LIB1ASMSRC, LIB1ASMFUNCS): Remove.
      	* config/m32r/t-linux (CROSS_LIBGCC1, LIBGCC1, LIBGCC1_TEST): Remove.
      	* config/m68k/lb1sf68.asm: Move to ../libgcc/config/m68k/lb1sf68.S.
      	* config/m68k/t-floatlib (LIB1ASMSRC, LIB1ASMFUNCS): New file.
      	* config/mcore/lib1.asm: Move to ../libgcc/config/mcore/lib1funcs.S.
      	* config/mcore/t-mcore (LIB1ASMSRC, LIB1ASMFUNCS): Remove.
      	* config/mep/mep-lib1.asm: Move to ../libgcc/config/mep/lib1funcs.S.
      	* config/mep/t-mep (LIB1ASMSRC, LIB1ASMFUNCS): Remove.
      	* config/mips/mips16.S: Move to ../libgcc/config/mips.
      	* config/mips/t-libgcc-mips16: Remove.
      	* config/mips/t-sr71k (LIBGCC1, CROSS_LIBGCC1): Remove.
      	* config/pa/milli64.S: Move to ../libgcc/config/pa.
      	* config/pa/t-linux (LIB1ASMFUNCS, LIB1ASMSRC): Remove.
      	* config/pa/t-linux64: Likewise.
      	* config/picochip/libgccExtras/fake_libgcc.asm: Move to
      	* config/picochip/t-picochip (LIB1ASMFUNCS, LIB1ASMSRC): Remove.
      	* config/sh/lib1funcs.asm: Move to ../libgcc/config/sh/lib1funcs.S.
      	* config/sh/lib1funcs.h: Move to ../libgcc/config/sh.
      	* config/sh/sh.h: Update lib1funcs.asm filename.
      	* config/sh/t-linux (LIB1ASMFUNCS_CACHE): Remove.
      	* config/sh/t-netbsd: Likewise.
      	* config/sh/t-sh64 (LIB1ASMFUNCS): Remove.
      	* config/sparc/lb1spc.asm: Move to ../libgcc/config/sparc/lb1spc.S.
      	* config/sparc/lb1spl.asm: Remove.
      	* config/sparc/t-elf (LIB1ASMSRC, LIB1ASMFUNCS): Remove.
      	* config/sparc/t-leon: Likewise.
      	* config/spu/t-spu-elf (LIBGCC1, CROSS_LIBGCC1): Remove.
      	* config/v850/lib1funcs.asm: Move to ../libgcc/config/v850/lib1funcs.S.
      	* config/v850/t-v850 (LIB1ASMSRC, LIB1ASMFUNCS): Remove
      	* config/vax/lib1funcs.asm: Move to ../libgcc/config/vax/lib1funcs.S.
      	* config/vax/t-linux: Remove.
      	* config/xtensa/ieee754-df.S, config/xtensa/ieee754-sf.S: Move to
      	* config/xtensa/lib1funcs.asm: Move to
      	* config/xtensa/t-xtensa (LIB1ASMSRC, LIB1ASMFUNCS): Remove.
      	* config.gcc (bfin*-rtems*): Remove bfin/t-bfin from tmake_file.
      	(bfin*-*): Likewise.
      	(mips64*-*-linux*, mipsisa64*-*-linux*): Remove
      	mips/t-libgcc-mips16 from tmake_file.
      	(mips*-*-linux*): Likewise.
      	(mips*-sde-elf*): Likewise.
      	(mipsisa32-*-elf*, mipsisa32el-*-elf*, mipsisa32r2-*-elf*)
      	(mipsisa32r2el-*-elf*, mipsisa64-*-elf*, mipsisa64el-*-elf*)
      	(mipsisa64r2-*-elf*, mipsisa64r2el-*-elf*): Likewise.
      	(mipsisa64sb1-*-elf*, mipsisa64sb1el-*-elf*): Likewise.
      	(mips-*-elf*, mipsel-*-elf*): Likewise.
      	(mips64-*-elf*, mips64el-*-elf*): Likewise.
      	(mips64orion-*-elf*, mips64orionel-*-elf*): Likewise.
      	(mips*-*-rtems*): Likewise.
      	(mipstx39-*-elf*, mipstx39el-*-elf*): Likewise.
      	(vax-*-linux*): Remove vax/t-linux from tmake_file.
      	* Makefile.in ($(lib1asmfuncs-o), $(lib1asmfuncs-s-o)): Use
      	$(srcdir) to refer to $(LIB1ASMSRC).
      	Use $<.
      	* config/arm/bpabi-v6m.S, config/arm/bpabi.S,
      	config/arm/ieee754-df.S, config/arm/ieee754-sf.S,
      	config/arm/lib1funcs.S: New files.
      	* config/arm/libunwind.S [!__symbian__]: Use lib1funcs.S.
      	* config/arm/t-arm: New file.
      	* config/arm/t-bpabi (LIB1ASMFUNCS): Set.
      	* config/arm/t-elf, config/arm/t-linux, config/arm/t-linux-eabi,
      	config/arm/t-strongarm-elf: New files.
      	* config/arm/t-symbian (LIB1ASMFUNCS): Set.
      	* config/arm/t-vxworks, config/arm/t-wince-pe: New files.
      	* config/avr/lib1funcs.S: New file.
      	* config/avr/t-avr (LIB1ASMSRC, LIB1ASMFUNCS): Set.
      	* config/bfin/lib1funcs.S, config/bfin/t-bfin: New files.
      	* config/c6x/lib1funcs.S: New file.
      	* config/c6x/t-elf (LIB1ASMSRC, LIB1ASMFUNCS): Set.
      	* config/fr30/lib1funcs.S, config/fr30/t-fr30: New files.
      	* config/frv/lib1funcs.S: New file.
      	* config/frv/t-frv (LIB1ASMSRC, LIB1ASMFUNCS): Set.
      	* config/h8300/lib1funcs.S, config/h8300/t-h8300: New files.
      	* config/i386/cygwin.S, config/i386/t-chkstk: New files.
      	* config/ia64/__divxf3.asm: Rename to ...
      	* config/ia64/__divxf3.S: ... this.
      	Adapt lib1funcs.asm filename.
      	* config/ia64/_fixtfdi.asm: Rename to ...
      	* config/ia64/_fixtfdi.S: ... this.
      	Adapt lib1funcs.asm filename.
      	* config/ia64/_fixunstfdi.asm: Rename to ...
      	* config/ia64/_fixunstfdi.S: ... this.
      	Adapt lib1funcs.asm filename.
      	* config/ia64/_floatditf.asm: Rename to ...
      	* config/ia64/_floatditf.S: ... this.
      	Adapt lib1funcs.asm filename.
      	* config/ia64/lib1funcs.S: New file.
      	* config/ia64/t-hpux (LIB1ASMFUNCS): Set.
      	* config/ia64/t-ia64 (LIB1ASMSRC, LIB1ASMFUNCS): Set.
      	* config/ia64/t-softfp-compat (libgcc1-tf-compats): Adapt suffix.
      	* config/m32c/lib1funcs.S, config/m32c/t-m32c: New files.
      	* config/m68k/lb1sf68.S, config/m68k/t-floatlib: New files.
      	* config/mcore/lib1funcs.S, config/mcore/t-mcore: New files.
      	* config/mep/lib1funcs.S: New file.
      	* config/mep/t-mep (LIB1ASMSRC, LIB1ASMFUNCS): Set.
      	* config/mips/mips16.S: New file.
      	* config/mips/t-mips16 (LIB1ASMSRC, LIB1ASMFUNCS): Set.
      	* config/pa/milli64.S: New file.
      	* config/pa/t-linux, config/pa/t-linux64: New files.
      	* config/picochip/lib1funcs.S: New file.
      	* config/picochip/t-picochip (LIB1ASMSRC, LIB1ASMFUNCS): Set.
      	* config/sh/lib1funcs.S, config/sh/lib1funcs.h: New files.
      	* config/sh/t-linux (LIB1ASMFUNCS_CACHE): Set.
      	* config/sh/t-netbsd: New file.
      	* config/sh/t-sh (LIB1ASMSRC, LIB1ASMFUNCS, LIB1ASMFUNCS_CACHE): Set.
      	Use $(srcdir) to refer to lib1funcs.S, adapt filename.
      	* config/sh/t-sh64: New file.
      	* config/sparc/lb1spc.S: New file.
      	* config/sparc/t-softmul (LIB1ASMSRC): Adapt sparc/lb1spc.asm
      	* config/v850/lib1funcs.S, config/v850/t-v850: New files.
      	* config/vax/lib1funcs.S, config/vax/t-linux: New files.
      	* config/xtensa/ieee754-df.S, config/xtensa/ieee754-sf.S,
      	config/xtensa/lib1funcs.S: New files.
      	* config/xtensa/t-xtensa (LIB1ASMSRC, LIB1ASMFUNCS): Set.
      	* config.host (arm-wrs-vxworks): Add arm/t-arm, arm/t-vxworks to
      	(arm*-*-freebsd*): Add arm/t-arm, arm/t-strongarm-elf to tmake_file.
      	(arm*-*-netbsdelf*): Add arm/t-arm to tmake_file.
      	(arm*-*-linux*): Likewise.
      	Add arm/t-elf, arm/t-bpabi, arm/t-linux-eabi to tmake_file for
      	arm*-*-linux-*eabi, add arm/t-linux otherwise.
      	(arm*-*-uclinux*): Add arm/t-arm, arm/t-elf to tmake_file.
      	(arm*-*-ecos-elf): Likewise.
      	(arm*-*-eabi*, arm*-*-symbianelf*): Likewise.
      	(arm*-*-rtems*): Likewise.
      	(arm*-*-elf): Likewise.
      	(arm*-wince-pe*): Add arm/t-arm, arm/t-wince-pe to tmake_file.
      	(avr-*-rtems*): Add to tmake_file, add avr/t-avr.
      	(bfin*-elf*): Add bfin/t-bfin to tmake_file.
      	(bfin*-uclinux*): Likewise.
      	(bfin*-linux-uclibc*): Likewise.
      	(bfin*-rtems*): Likewise.
      	(bfin*-*): Likewise.
      	(fido-*-elf): Merge into m68k-*-elf*.
      	(fr30-*-elf)): Add fr30/t-fr30 to tmake_file.
      	(frv-*-*linux*): Add frv/t-frv to tmake_file.
      	(h8300-*-rtems*): Add h8300/t-h8300 to tmake_file.
      	(h8300-*-elf*): Likewise.
      	(hppa*64*-*-linux*): Add pa/t-linux, pa/t-linux64 to tmake_file.
      	(hppa*-*-linux*): Add pa/t-linux to tmake_file.
      	(i[34567]86-*-cygwin*): Add i386/t-chkstk to tmake_file.
      	(i[34567]86-*-mingw*): Likewise.
      	(x86_64-*-mingw*): Likewise.
      	(i[34567]86-*-interix3*): Likewise.
      	(ia64*-*-hpux*): Add ia64/t-ia64, ia64/t-hpux to tmake_file.
      	(ia64-hp-*vms*): Add ia64/t-ia64 to tmake_file.
      	(m68k-*-elf*): Also handle fido-*-elf.
      	Add m68k/t-floatlib to tmake_file.
      	(m68k-*-uclinux*): Add m68k/t-floatlib to tmake_file.
      	(m68k-*-linux*): Likewise.
      	(m68k-*-rtems*): Likewise.
      	(mcore-*-elf): Add mcore/t-mcore to tmake_file.
      	(sh-*-elf*, sh[12346l]*-*-elf*): Add sh/t-sh64 to tmake_file for
      	(sh-*-linux*, sh[2346lbe]*-*-linux*): Add sh/t-sh to tmake_file.
      	Add sh/t-sh64 to tmake_file for sh64*-*-linux*.
      	(sh-*-netbsdelf*, shl*-*-netbsdelf*, sh5-*-netbsd*)
      	(sh5l*-*-netbsd*, sh64-*-netbsd*, sh64l*-*-netbsd*): Add sh/t-sh,
      	sh/t-netbsd to tmake_file.
      	Add sh/t-sh64 to tmake_file for sh5*-*-netbsd*, sh64*-netbsd*.
      	(sh-*-rtems*): Add sh/t-sh to tmake_file.
      	(sh-wrs-vxworks): Likewise.
      	(sparc-*-linux*): Add sparc/t-softmul to tmake_file except for
      	(v850*-*-*): Add v850/t-v850 to tmake_file.
      	(vax-*-linux*): Add vax/t-linux to tmake_file.
      	(m32c-*-elf*, m32c-*-rtems*): Add m32c/t-m32c to tmake_file.
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@180773 138bc75d-0d04-0410-961f-82ee72b054a4
  8. 09 Apr, 2009 1 commit
  9. 20 Dec, 2007 1 commit
    • bwilson's avatar
      * config/xtensa/xtensa.md (fix_return_addr): Remove. · 57ffde16
      bwilson authored
      	* config/xtensa/xtensa-protos.h (xtensa_initialize_trampoline): New.
      	(xtensa_trampoline_template): New.
      	* config/xtensa/xtensa.c (MIN_FRAME_SIZE): Moved here from xtensa.h.
      	(xtensa_return_addr): Expand to standard Xtensa insns instead of
      	fix_return_addr.  Get high bits from a local label.
      	(xtensa_trampoline_template): New function with code moved from
      	TRAMPOLINE_TEMPLATE in xtensa.h.  Use L32R instead of CALL0 except
      	when using CONST16 or absolute-mode literals.
      	(xtensa_initialize_trampoline): New function with code moved from
      	INITIALIZE_TRAMPOLINE in xtensa.h.  Use different offsets depending
      	on which trampoline version is used.
      	* config/xtensa/lib2funcs.S (TRAMPOLINE_SIZE): Add comment.
      	* config/xtensa/xtensa.h (TARGET_ABSOLUTE_LITERALS): Define.
      	(MIN_FRAME_SIZE): Moved to xtensa.c.
      	(TRAMPOLINE_TEMPLATE): Use xtensa_trampoline_template.
      	(TRAMPOLINE_SIZE): Two versions of the trampoline have different sizes.
      	(INITIALIZE_TRAMPOLINE): Use xtensa_initialize_trampoline.
      	* config/xtensa/ieee754-df.S (XCHAL_NO_MUL): Define.
      	(__muldf3): Use CALL12 instead of CALL0 to invoke .Lmul_mulsi3
      	helper when not using the CALL0 ABI.  Change .Lmul_mulsi3 to match.
      	* config/xtensa/lib1funcs.asm (__umulsidi3): Likewise.
      	* config/xtensa/ieee754-sf.S (__mulsf3): Likewise.
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@131108 138bc75d-0d04-0410-961f-82ee72b054a4
  10. 01 Apr, 2006 1 commit
  11. 16 Jan, 2006 1 commit
  12. 09 Jan, 2006 1 commit
    • bwilson's avatar
      include: · 367a6058
      bwilson authored
      	* xtensa-config.h (XCHAL_HAVE_MUL32_HIGH): Define.
      	* config/xtensa/ieee754-df.S: New file.
      	* config/xtensa/ieee754-sf.S: New file.
      	* config/xtensa/t-xtensa (LIB2FUNCS_EXTRA): Remove fp-bit.c & dp-bit.c.
      	(LIB1ASMFUNCS): Add SFmode and DFmode floating-point functions.
      	* config/xtensa/lib1funcs.asm: Include ieee754-df.S and ieee754-sf.S.
      git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@109518 138bc75d-0d04-0410-961f-82ee72b054a4