HEX
Server: Apache
System: Linux www 6.18.4-i1-ampere #899 SMP Thu Jan 8 10:39:05 CET 2026 aarch64
User: sws1073755998 (1073755998)
PHP: 8.1.33
Disabled: NONE
Upload Files
File: //lib/go/src/runtime/rt0_aix_ppc64.s
// Copyright 2018 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"
#include "asm_ppc64x.h"

// _rt0_ppc64_aix is a function descriptor of the entrypoint function
// __start. This name is needed by cmd/link.
DEFINE_PPC64X_FUNCDESC(_rt0_ppc64_aix, __start<>)

// The starting function must return in the loader to
// initialise some libraries, especially libthread which
// creates the main thread and adds the TLS in R13
// R19 contains a function descriptor to the loader function
// which needs to be called.
// This code is similar to the __start function in C
TEXT __start<>(SB),NOSPLIT,$-8
	XOR R0, R0
	MOVD $libc___n_pthreads(SB), R4
	MOVD 0(R4), R4
	MOVD $libc___mod_init(SB), R5
	MOVD 0(R5), R5
	MOVD 0(R19), R0
	MOVD R2, 40(R1)
	MOVD 8(R19), R2
	MOVD R18, R3
	MOVD R0, CTR
	BL (CTR) // Return to AIX loader

	// Launch rt0_go
	MOVD 40(R1), R2
	MOVD R14, R3 // argc
	MOVD R15, R4 // argv
	BL _main(SB)


DEFINE_PPC64X_FUNCDESC(main, _main)
TEXT _main(SB),NOSPLIT,$-8
	MOVD $runtime·rt0_go(SB), R12
	MOVD R12, CTR
	BR (CTR)

// Paramater save space required to cross-call into _cgo_sys_thread_create
#define PARAM_SPACE 16

TEXT _rt0_ppc64_aix_lib(SB),NOSPLIT,$-8
	// Start with standard C stack frame layout and linkage.
	MOVD	LR, R0
	MOVD	R0, 16(R1) // Save LR in caller's frame.
	MOVW	CR, R0	   // Save CR in caller's frame
	MOVD	R0, 8(R1)

	MOVDU	R1, -344-PARAM_SPACE(R1) // Allocate frame.

	// Preserve callee-save registers.
	MOVD	R14, 48+PARAM_SPACE(R1)
	MOVD	R15, 56+PARAM_SPACE(R1)
	MOVD	R16, 64+PARAM_SPACE(R1)
	MOVD	R17, 72+PARAM_SPACE(R1)
	MOVD	R18, 80+PARAM_SPACE(R1)
	MOVD	R19, 88+PARAM_SPACE(R1)
	MOVD	R20, 96+PARAM_SPACE(R1)
	MOVD	R21,104+PARAM_SPACE(R1)
	MOVD	R22, 112+PARAM_SPACE(R1)
	MOVD	R23, 120+PARAM_SPACE(R1)
	MOVD	R24, 128+PARAM_SPACE(R1)
	MOVD	R25, 136+PARAM_SPACE(R1)
	MOVD	R26, 144+PARAM_SPACE(R1)
	MOVD	R27, 152+PARAM_SPACE(R1)
	MOVD	R28, 160+PARAM_SPACE(R1)
	MOVD	R29, 168+PARAM_SPACE(R1)
	MOVD	g, 176+PARAM_SPACE(R1) // R30
	MOVD	R31, 184+PARAM_SPACE(R1)
	FMOVD	F14, 192+PARAM_SPACE(R1)
	FMOVD	F15, 200+PARAM_SPACE(R1)
	FMOVD	F16, 208+PARAM_SPACE(R1)
	FMOVD	F17, 216+PARAM_SPACE(R1)
	FMOVD	F18, 224+PARAM_SPACE(R1)
	FMOVD	F19, 232+PARAM_SPACE(R1)
	FMOVD	F20, 240+PARAM_SPACE(R1)
	FMOVD	F21, 248+PARAM_SPACE(R1)
	FMOVD	F22, 256+PARAM_SPACE(R1)
	FMOVD	F23, 264+PARAM_SPACE(R1)
	FMOVD	F24, 272+PARAM_SPACE(R1)
	FMOVD	F25, 280+PARAM_SPACE(R1)
	FMOVD	F26, 288+PARAM_SPACE(R1)
	FMOVD	F27, 296+PARAM_SPACE(R1)
	FMOVD	F28, 304+PARAM_SPACE(R1)
	FMOVD	F29, 312+PARAM_SPACE(R1)
	FMOVD	F30, 320+PARAM_SPACE(R1)
	FMOVD	F31, 328+PARAM_SPACE(R1)

	// Synchronous initialization.
	MOVD	$runtime·reginit(SB), R12
	MOVD	R12, CTR
	BL	(CTR)

	MOVBZ	runtime·isarchive(SB), R3	// Check buildmode = c-archive
	CMP		$0, R3
	BEQ		done

	MOVD	R14, _rt0_ppc64_aix_lib_argc<>(SB)
	MOVD	R15, _rt0_ppc64_aix_lib_argv<>(SB)

	MOVD	$runtime·libpreinit(SB), R12
	MOVD	R12, CTR
	BL	(CTR)

	// Create a new thread to do the runtime initialization and return.
	MOVD	_cgo_sys_thread_create(SB), R12
	CMP	$0, R12
	BEQ	nocgo
	MOVD	$_rt0_ppc64_aix_lib_go(SB), R3
	MOVD	$0, R4
	MOVD	R2, 40(R1)
	MOVD	8(R12), R2
	MOVD	(R12), R12
	MOVD	R12, CTR
	BL	(CTR)
	MOVD	40(R1), R2
	BR	done

nocgo:
	MOVD	$0x800000, R12					   // stacksize = 8192KB
	MOVD	R12, 8(R1)
	MOVD	$_rt0_ppc64_aix_lib_go(SB), R12
	MOVD	R12, 16(R1)
	MOVD	$runtime·newosproc0(SB),R12
	MOVD	R12, CTR
	BL	(CTR)

done:
	// Restore saved registers.
	MOVD	48+PARAM_SPACE(R1), R14
	MOVD	56+PARAM_SPACE(R1), R15
	MOVD	64+PARAM_SPACE(R1), R16
	MOVD	72+PARAM_SPACE(R1), R17
	MOVD	80+PARAM_SPACE(R1), R18
	MOVD	88+PARAM_SPACE(R1), R19
	MOVD	96+PARAM_SPACE(R1), R20
	MOVD	104+PARAM_SPACE(R1), R21
	MOVD	112+PARAM_SPACE(R1), R22
	MOVD	120+PARAM_SPACE(R1), R23
	MOVD	128+PARAM_SPACE(R1), R24
	MOVD	136+PARAM_SPACE(R1), R25
	MOVD	144+PARAM_SPACE(R1), R26
	MOVD	152+PARAM_SPACE(R1), R27
	MOVD	160+PARAM_SPACE(R1), R28
	MOVD	168+PARAM_SPACE(R1), R29
	MOVD	176+PARAM_SPACE(R1), g // R30
	MOVD	184+PARAM_SPACE(R1), R31
	FMOVD	196+PARAM_SPACE(R1), F14
	FMOVD	200+PARAM_SPACE(R1), F15
	FMOVD	208+PARAM_SPACE(R1), F16
	FMOVD	216+PARAM_SPACE(R1), F17
	FMOVD	224+PARAM_SPACE(R1), F18
	FMOVD	232+PARAM_SPACE(R1), F19
	FMOVD	240+PARAM_SPACE(R1), F20
	FMOVD	248+PARAM_SPACE(R1), F21
	FMOVD	256+PARAM_SPACE(R1), F22
	FMOVD	264+PARAM_SPACE(R1), F23
	FMOVD	272+PARAM_SPACE(R1), F24
	FMOVD	280+PARAM_SPACE(R1), F25
	FMOVD	288+PARAM_SPACE(R1), F26
	FMOVD	296+PARAM_SPACE(R1), F27
	FMOVD	304+PARAM_SPACE(R1), F28
	FMOVD	312+PARAM_SPACE(R1), F29
	FMOVD	320+PARAM_SPACE(R1), F30
	FMOVD	328+PARAM_SPACE(R1), F31

	ADD	$344+PARAM_SPACE, R1

	MOVD	8(R1), R0
	MOVFL	R0, $0xff
	MOVD	16(R1), R0
	MOVD	R0, LR
	RET

DEFINE_PPC64X_FUNCDESC(_rt0_ppc64_aix_lib_go, __rt0_ppc64_aix_lib_go)

TEXT __rt0_ppc64_aix_lib_go(SB),NOSPLIT,$0
	MOVD	_rt0_ppc64_aix_lib_argc<>(SB), R3
	MOVD	_rt0_ppc64_aix_lib_argv<>(SB), R4
	MOVD	$runtime·rt0_go(SB), R12
	MOVD	R12, CTR
	BR	(CTR)

DATA _rt0_ppc64_aix_lib_argc<>(SB)/8, $0
GLOBL _rt0_ppc64_aix_lib_argc<>(SB),NOPTR, $8
DATA _rt0_ppc64_aix_lib_argv<>(SB)/8, $0
GLOBL _rt0_ppc64_aix_lib_argv<>(SB),NOPTR, $8