| // Copyright 2009 The Go Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style |
| // license that can be found in the LICENSE file. |
| |
| #include "textflag.h" |
| |
| TEXT _rt0_arm_linux(SB),NOSPLIT,$-4 |
| MOVW (R13), R0 // argc |
| MOVW $4(R13), R1 // argv |
| MOVW $_rt0_arm_linux1(SB), R4 |
| B (R4) |
| |
| // When building with -buildmode=c-shared, this symbol is called when the shared |
| // library is loaded. |
| TEXT _rt0_arm_linux_lib(SB),NOSPLIT,$0 |
| B _rt0_arm_lib(SB) |
| |
| TEXT _rt0_arm_linux1(SB),NOSPLIT,$-4 |
| // We first need to detect the kernel ABI, and warn the user |
| // if the system only supports OABI. |
| // The strategy here is to call some EABI syscall to see if |
| // SIGILL is received. |
| // If you get a SIGILL here, you have the wrong kernel. |
| |
| // Save argc and argv (syscall will clobber at least R0). |
| MOVM.DB.W [R0-R1], (R13) |
| |
| // do an EABI syscall |
| MOVW $20, R7 // sys_getpid |
| SWI $0 // this will trigger SIGILL on OABI systems |
| |
| MOVM.IA.W (R13), [R0-R1] |
| B runtime·rt0_go(SB) |