rs6000 (SAVE_INLINE_VRS, [...]): Define.
gcc/
* config/rs6000/rs6000 (SAVE_INLINE_VRS, REST_INLINE_VRS,
V_SAVE_INLINE, SAVRES_LR, SAVRES_SAVE, SAVRES_REG,
SAVRES_GPR, SAVRES_FPR, SAVRES_VR): Define.
(no_global_regs_above): Delete.
(no_global_regs): New function.
(rs6000_savres_strategy): Handle vector regs. Use proper lr_save_p
value for load multiple test.
(savres_routine_syms): Increase size.
(rs6000_savres_routine_name, rs6000_savres_routine_sym,
ptr_regno_for_savres, rs6000_emit_savres_rtx): Pass in int selector
rather than a number of boolean flags. Update all callers.
(rs6000_savres_routine_name): Generate vector save/restore names.
(rs6000_savres_routine_sym): Handle vector regs. Delete forward decl.
(ptr_regno_for_savres, rs6000_emit_savres_rtx): Likewise.
(rs6000_emit_prologue): Delete saving_FPRs_inline, saving_GPRs_inline
and using_store_multiple. Expand uses. Don't always use r11 as
frame reg when needed for out-of-line saves. Set up initial offset
for out-of-line vector saves when buying stack frame. Handle pointer
reg setup for out-of-line fp save. Emit call to out-of-line vector
save function. Choose r11 or r12 for vrsave reg when available for
better scheduling.
(rs6000_output_function_prologue): Don't emit .extern for ELF.
(rs6000_emit_epilogue): Choose a better frame reg when restoring
from back-chain to suit out-of-line vector restore functions. Emit
call to out-of-line vector restore function. Adjust register used
for cr restore. Tweak pointer register setup for gpr restore.
* config/rs6000/rs6000.h (FIRST_SAVED_GP_REGNO): Take into account
FIXED_R13.
* config/rs6000/sysv4.h (FP_SAVE_INLINE, GP_SAVE_INLINE): Simplify.
(V_SAVE_INLINE): Define.
* config/rs6000/altivec.md (save_vregs_*, restore_vregs_*): New insns.
libgcc/
* config/rs6000/crtsavevr.S: New file.
* config/rs6000/crtrestvr.S: New file.
* config/rs6000/t-savresfgpr: Build the above.
* config/rs6000/t-netbsd: Likewise.
From-SVN: r186800
2012-04-25 04:32:56 +02:00
|
|
|
/* Routines for restoring vector registers.
|
|
|
|
|
2017-01-01 13:07:43 +01:00
|
|
|
Copyright (C) 2012-2017 Free Software Foundation, Inc.
|
rs6000 (SAVE_INLINE_VRS, [...]): Define.
gcc/
* config/rs6000/rs6000 (SAVE_INLINE_VRS, REST_INLINE_VRS,
V_SAVE_INLINE, SAVRES_LR, SAVRES_SAVE, SAVRES_REG,
SAVRES_GPR, SAVRES_FPR, SAVRES_VR): Define.
(no_global_regs_above): Delete.
(no_global_regs): New function.
(rs6000_savres_strategy): Handle vector regs. Use proper lr_save_p
value for load multiple test.
(savres_routine_syms): Increase size.
(rs6000_savres_routine_name, rs6000_savres_routine_sym,
ptr_regno_for_savres, rs6000_emit_savres_rtx): Pass in int selector
rather than a number of boolean flags. Update all callers.
(rs6000_savres_routine_name): Generate vector save/restore names.
(rs6000_savres_routine_sym): Handle vector regs. Delete forward decl.
(ptr_regno_for_savres, rs6000_emit_savres_rtx): Likewise.
(rs6000_emit_prologue): Delete saving_FPRs_inline, saving_GPRs_inline
and using_store_multiple. Expand uses. Don't always use r11 as
frame reg when needed for out-of-line saves. Set up initial offset
for out-of-line vector saves when buying stack frame. Handle pointer
reg setup for out-of-line fp save. Emit call to out-of-line vector
save function. Choose r11 or r12 for vrsave reg when available for
better scheduling.
(rs6000_output_function_prologue): Don't emit .extern for ELF.
(rs6000_emit_epilogue): Choose a better frame reg when restoring
from back-chain to suit out-of-line vector restore functions. Emit
call to out-of-line vector restore function. Adjust register used
for cr restore. Tweak pointer register setup for gpr restore.
* config/rs6000/rs6000.h (FIRST_SAVED_GP_REGNO): Take into account
FIXED_R13.
* config/rs6000/sysv4.h (FP_SAVE_INLINE, GP_SAVE_INLINE): Simplify.
(V_SAVE_INLINE): Define.
* config/rs6000/altivec.md (save_vregs_*, restore_vregs_*): New insns.
libgcc/
* config/rs6000/crtsavevr.S: New file.
* config/rs6000/crtrestvr.S: New file.
* config/rs6000/t-savresfgpr: Build the above.
* config/rs6000/t-netbsd: Likewise.
From-SVN: r186800
2012-04-25 04:32:56 +02:00
|
|
|
Written by Alan Modra, IBM
|
|
|
|
|
|
|
|
This file 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.
|
|
|
|
|
|
|
|
This file 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.
|
|
|
|
|
|
|
|
Under Section 7 of GPL version 3, you are granted additional
|
|
|
|
permissions described in the GCC Runtime Library Exception, version
|
|
|
|
3.1, as published by the Free Software Foundation.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License and
|
|
|
|
a copy of the GCC Runtime Library Exception along with this program;
|
|
|
|
see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
|
|
|
|
<http://www.gnu.org/licenses/>. */
|
|
|
|
|
|
|
|
/* On PowerPC64 Linux, these functions are provided by the linker. */
|
|
|
|
#ifndef __powerpc64__
|
|
|
|
|
|
|
|
#undef __ALTIVEC__
|
|
|
|
#define __ALTIVEC__ 1
|
|
|
|
#include "ppc-asm.h"
|
|
|
|
|
|
|
|
/* Called with r0 pointing just beyond the end of the vector save area. */
|
|
|
|
|
2017-03-10 20:29:48 +01:00
|
|
|
.machine altivec
|
rs6000 (SAVE_INLINE_VRS, [...]): Define.
gcc/
* config/rs6000/rs6000 (SAVE_INLINE_VRS, REST_INLINE_VRS,
V_SAVE_INLINE, SAVRES_LR, SAVRES_SAVE, SAVRES_REG,
SAVRES_GPR, SAVRES_FPR, SAVRES_VR): Define.
(no_global_regs_above): Delete.
(no_global_regs): New function.
(rs6000_savres_strategy): Handle vector regs. Use proper lr_save_p
value for load multiple test.
(savres_routine_syms): Increase size.
(rs6000_savres_routine_name, rs6000_savres_routine_sym,
ptr_regno_for_savres, rs6000_emit_savres_rtx): Pass in int selector
rather than a number of boolean flags. Update all callers.
(rs6000_savres_routine_name): Generate vector save/restore names.
(rs6000_savres_routine_sym): Handle vector regs. Delete forward decl.
(ptr_regno_for_savres, rs6000_emit_savres_rtx): Likewise.
(rs6000_emit_prologue): Delete saving_FPRs_inline, saving_GPRs_inline
and using_store_multiple. Expand uses. Don't always use r11 as
frame reg when needed for out-of-line saves. Set up initial offset
for out-of-line vector saves when buying stack frame. Handle pointer
reg setup for out-of-line fp save. Emit call to out-of-line vector
save function. Choose r11 or r12 for vrsave reg when available for
better scheduling.
(rs6000_output_function_prologue): Don't emit .extern for ELF.
(rs6000_emit_epilogue): Choose a better frame reg when restoring
from back-chain to suit out-of-line vector restore functions. Emit
call to out-of-line vector restore function. Adjust register used
for cr restore. Tweak pointer register setup for gpr restore.
* config/rs6000/rs6000.h (FIRST_SAVED_GP_REGNO): Take into account
FIXED_R13.
* config/rs6000/sysv4.h (FP_SAVE_INLINE, GP_SAVE_INLINE): Simplify.
(V_SAVE_INLINE): Define.
* config/rs6000/altivec.md (save_vregs_*, restore_vregs_*): New insns.
libgcc/
* config/rs6000/crtsavevr.S: New file.
* config/rs6000/crtrestvr.S: New file.
* config/rs6000/t-savresfgpr: Build the above.
* config/rs6000/t-netbsd: Likewise.
From-SVN: r186800
2012-04-25 04:32:56 +02:00
|
|
|
.section ".text"
|
|
|
|
CFI_STARTPROC
|
|
|
|
HIDDEN_FUNC(_restvr_20)
|
|
|
|
li r11,-192
|
|
|
|
lvx v20,r11,r0
|
|
|
|
HIDDEN_FUNC(_restvr_21)
|
|
|
|
li r11,-176
|
|
|
|
lvx v21,r11,r0
|
|
|
|
HIDDEN_FUNC(_restvr_22)
|
|
|
|
li r11,-160
|
|
|
|
lvx v22,r11,r0
|
|
|
|
HIDDEN_FUNC(_restvr_23)
|
|
|
|
li r11,-144
|
|
|
|
lvx v23,r11,r0
|
|
|
|
HIDDEN_FUNC(_restvr_24)
|
|
|
|
li r11,-128
|
|
|
|
lvx v24,r11,r0
|
|
|
|
HIDDEN_FUNC(_restvr_25)
|
|
|
|
li r11,-112
|
|
|
|
lvx v25,r11,r0
|
|
|
|
HIDDEN_FUNC(_restvr_26)
|
|
|
|
li r11,-96
|
|
|
|
lvx v26,r11,r0
|
|
|
|
HIDDEN_FUNC(_restvr_27)
|
|
|
|
li r11,-80
|
|
|
|
lvx v27,r11,r0
|
|
|
|
HIDDEN_FUNC(_restvr_28)
|
|
|
|
li r11,-64
|
|
|
|
lvx v28,r11,r0
|
|
|
|
HIDDEN_FUNC(_restvr_29)
|
|
|
|
li r11,-48
|
|
|
|
lvx v29,r11,r0
|
|
|
|
HIDDEN_FUNC(_restvr_30)
|
|
|
|
li r11,-32
|
|
|
|
lvx v30,r11,r0
|
|
|
|
HIDDEN_FUNC(_restvr_31)
|
|
|
|
li r11,-16
|
|
|
|
lvx v31,r11,r0
|
|
|
|
blr
|
|
|
|
FUNC_END(_restvr_31)
|
|
|
|
FUNC_END(_restvr_30)
|
|
|
|
FUNC_END(_restvr_29)
|
|
|
|
FUNC_END(_restvr_28)
|
|
|
|
FUNC_END(_restvr_27)
|
|
|
|
FUNC_END(_restvr_26)
|
|
|
|
FUNC_END(_restvr_25)
|
|
|
|
FUNC_END(_restvr_24)
|
|
|
|
FUNC_END(_restvr_23)
|
|
|
|
FUNC_END(_restvr_22)
|
|
|
|
FUNC_END(_restvr_21)
|
|
|
|
FUNC_END(_restvr_20)
|
|
|
|
CFI_ENDPROC
|
|
|
|
|
|
|
|
#endif
|