liyujie
2025-08-28 d9927380ed7c8366f762049be9f3fee225860833
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
// 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|NOFRAME,$0
   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|NOFRAME,$0
   // 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)