
Unfortunately, legacy .so files for ARM don't have a correct crtbegin file. Consequently, we have to grandfather the old __dso_handle behaviour. Add some ifdefs for ARM to allow it to use the old code until we can work out a transition. Change-Id: I6a28f368267d792c94e1d985d8344023bc632f6f Author: H.J. Lu <hongjiu.lu@intel.com> Signed-off-by: Bruce Beare <bruce.j.beare@intel.com>
137 lines
3.8 KiB
ArmAsm
137 lines
3.8 KiB
ArmAsm
# bionic/arch-x86/bionic/crtbegin_static.S
|
|
#
|
|
# Copyright 2006, The Android Open Source Project
|
|
#
|
|
# Redistribution and use in source and binary forms, with or without
|
|
# modification, are permitted provided that the following conditions are met:
|
|
# * Redistributions of source code must retain the above copyright
|
|
# notice, this list of conditions and the following disclaimer.
|
|
# * Redistributions in binary form must reproduce the above copyright
|
|
# notice, this list of conditions and the following disclaimer in the
|
|
# documentation and/or other materials provided with the distribution.
|
|
# * Neither the name of Google Inc. nor the names of its contributors may
|
|
# be used to endorse or promote products derived from this software
|
|
# without specific prior written permission.
|
|
#
|
|
# THIS SOFTWARE IS PROVIDED BY Google Inc. ``AS IS'' AND ANY EXPRESS OR
|
|
# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
|
# MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
|
|
# EVENT SHALL Google Inc. BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
|
# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
|
|
# OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
|
# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
|
|
# OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
|
# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
.text
|
|
.align 4
|
|
.type _start, @function
|
|
.globl _start
|
|
|
|
# this is the small startup code that is first run when
|
|
# any executable that is statically-linked with Bionic
|
|
# runs.
|
|
#
|
|
# it's purpose is to call __libc_init with appropriate
|
|
# arguments, which are:
|
|
#
|
|
# - the address of the raw data block setup by the Linux
|
|
# kernel ELF loader
|
|
#
|
|
# - address of an "onexit" function, not used on any
|
|
# platform supported by Bionic
|
|
#
|
|
# - address of the "main" function of the program. We
|
|
# can't hard-code it in the adr pseudo instruction
|
|
# so we use a tiny trampoline that will get relocated
|
|
# by the dynamic linker before this code runs
|
|
#
|
|
# - address of the constructor list
|
|
#
|
|
_start:
|
|
mov %esp, %eax
|
|
mov $1f, %edx
|
|
pushl %edx
|
|
mov $0f, %edx
|
|
pushl %edx
|
|
mov $0, %edx
|
|
pushl %edx
|
|
pushl %eax
|
|
call __libc_init
|
|
|
|
0: jmp main
|
|
|
|
1: .long __PREINIT_ARRAY__
|
|
.long __INIT_ARRAY__
|
|
.long __FINI_ARRAY__
|
|
|
|
.section .preinit_array, "aw"
|
|
.globl __PREINIT_ARRAY__
|
|
__PREINIT_ARRAY__:
|
|
.long -1
|
|
|
|
.section .init_array, "aw"
|
|
.globl __INIT_ARRAY__
|
|
__INIT_ARRAY__:
|
|
.long -1
|
|
.long frame_dummy
|
|
|
|
.section .fini_array, "aw"
|
|
.globl __FINI_ARRAY__
|
|
__FINI_ARRAY__:
|
|
.long -1
|
|
.long __do_global_dtors_aux
|
|
|
|
.section .eh_frame,"a",@progbits
|
|
.align 4
|
|
.type __EH_FRAME_BEGIN__, @object
|
|
__EH_FRAME_BEGIN__:
|
|
.text
|
|
.p2align 4,,15
|
|
.type __do_global_dtors_aux, @function
|
|
__do_global_dtors_aux:
|
|
pushl %ebp
|
|
movl %esp, %ebp
|
|
subl $24, %esp
|
|
cmpb $0, completed.4454
|
|
jne .L4
|
|
movl $__deregister_frame_info_bases, %eax
|
|
testl %eax, %eax
|
|
je .L3
|
|
movl $__EH_FRAME_BEGIN__, (%esp)
|
|
call __deregister_frame_info_bases
|
|
.L3:
|
|
movb $1, completed.4454
|
|
.L4:
|
|
leave
|
|
ret
|
|
.text
|
|
.p2align 4,,15
|
|
.type frame_dummy, @function
|
|
frame_dummy:
|
|
pushl %ebp
|
|
movl $__register_frame_info_bases, %eax
|
|
movl %esp, %ebp
|
|
subl $24, %esp
|
|
testl %eax, %eax
|
|
je .L7
|
|
movl %ebx, 12(%esp)
|
|
movl $0, 8(%esp)
|
|
movl $object.4466, 4(%esp)
|
|
movl $__EH_FRAME_BEGIN__, (%esp)
|
|
call __register_frame_info_bases
|
|
.L7:
|
|
leave
|
|
ret
|
|
.local completed.4454
|
|
.comm completed.4454,1,1
|
|
.local object.4466
|
|
.comm object.4466,24,4
|
|
.weak __register_frame_info_bases
|
|
.weak __deregister_frame_info_bases
|
|
|
|
#include "__dso_handle.S"
|
|
#include "atexit.S"
|
|
#include "__stack_chk_fail_local.S"
|