aboutsummaryrefslogtreecommitdiff
path: root/src/runtime/rt0_linux_ppc64.s
diff options
context:
space:
mode:
authorPaul Murphy <murp@redhat.com>2026-01-07 13:48:53 -0600
committerPaul Murphy <murp@redhat.com>2026-01-30 08:06:41 -0800
commit35c5deb1d43b245c19059d1532929ee087e44a84 (patch)
treea0cbc862f9933c9b781b340eb8acef60d629f954 /src/runtime/rt0_linux_ppc64.s
parentafae85307206cb56851c31652bd9ae45ba60c800 (diff)
downloadgo-35c5deb1d43b245c19059d1532929ee087e44a84.tar.xz
all: switch linux-ppc64 target to ELFv2 ABI
Go is only capable of producing internally linked, static binaries on linux-ppc64. As such, binaries should run in either ELFv1 or ELFv2 ppc64 userspaces today. This opens the door to enabling cgo and external linking which will require ELFv2 support and userspace, eventually. Fixes #76244 Change-Id: I5ca15037cbe546f352e8693dcf14da51a308b8ca Reviewed-on: https://go-review.googlesource.com/c/go/+/734540 LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com> Reviewed-by: Cherry Mui <cherryyz@google.com> Reviewed-by: Dmitri Shuralyov <dmitshur@google.com>
Diffstat (limited to 'src/runtime/rt0_linux_ppc64.s')
-rw-r--r--src/runtime/rt0_linux_ppc64.s28
1 files changed, 0 insertions, 28 deletions
diff --git a/src/runtime/rt0_linux_ppc64.s b/src/runtime/rt0_linux_ppc64.s
deleted file mode 100644
index f527170ed2..0000000000
--- a/src/runtime/rt0_linux_ppc64.s
+++ /dev/null
@@ -1,28 +0,0 @@
-// Copyright 2016 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"
-
-DEFINE_PPC64X_FUNCDESC(_rt0_ppc64_linux, _main<>)
-DEFINE_PPC64X_FUNCDESC(main, _main<>)
-
-TEXT _main<>(SB),NOSPLIT,$-8
- // In a statically linked binary, the stack contains argc,
- // argv as argc string pointers followed by a NULL, envv as a
- // sequence of string pointers followed by a NULL, and auxv.
- // There is no TLS base pointer.
- //
- // TODO(austin): Support ABI v1 dynamic linking entry point
- XOR R0, R0 // Note, newer kernels may not always set R0 to 0.
- MOVD $runtime·rt0_go(SB), R12
- MOVD R12, CTR
- MOVBZ runtime·iscgo(SB), R5
- CMP R5, $0
- BEQ nocgo
- BR (CTR)
-nocgo:
- MOVD 0(R1), R3 // argc
- ADD $8, R1, R4 // argv
- BR (CTR)