Home | History | Annotate | Line # | Download | only in xtensa
      1 # End of .init and .fini sections.
      2 # Copyright (C) 2003-2024 Free Software Foundation, Inc.
      3 #
      4 # This file is free software; you can redistribute it and/or modify it
      5 # under the terms of the GNU General Public License as published by
      6 # the Free Software Foundation; either version 3, or (at your option)
      7 # any later version.
      8 #
      9 # GCC is distributed in the hope that it will be useful, but WITHOUT ANY
     10 # WARRANTY; without even the implied warranty of MERCHANTABILITY or
     11 # FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
     12 # for more details.
     13 #
     14 # Under Section 7 of GPL version 3, you are granted additional
     15 # permissions described in the GCC Runtime Library Exception, version
     16 # 3.1, as published by the Free Software Foundation.
     17 #
     18 # You should have received a copy of the GNU General Public License and
     19 # a copy of the GCC Runtime Library Exception along with this program;
     20 # see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
     21 # <http://www.gnu.org/licenses/>.
     22 
     23 
     24 # This file just makes sure that the .fini and .init sections do in
     25 # fact return.  Users may put any desired instructions in those sections.
     26 # This file is the last thing linked into any executable.
     27 
     28 #include "xtensa-config-builtin.h"
     29 
     30 /* An executable stack is *not* required for these functions.  */
     31 #if defined(__ELF__) && defined(__linux__)
     32 .section .note.GNU-stack,"",%progbits
     33 .previous
     34 #endif
     35 
     36 	.section .init
     37 #if XCHAL_HAVE_WINDOWED && !__XTENSA_CALL0_ABI__
     38 	retw
     39 #else
     40 	l32i	a0, sp, 0
     41 	addi	sp, sp, 32
     42 	ret
     43 #endif
     44 
     45 	.section .fini
     46 #if XCHAL_HAVE_WINDOWED && !__XTENSA_CALL0_ABI__
     47 	retw
     48 #else
     49 	l32i	a0, sp, 0
     50 	addi	sp, sp, 32
     51 	ret
     52 #endif
     53