X7ROOT File Manager
Current Path:
/opt/golang/1.19.4/src/cmd/link/internal/ld
opt
/
golang
/
1.19.4
/
src
/
cmd
/
link
/
internal
/
ld
/
📁
..
📄
ar.go
(5.38 KB)
📄
asmb.go
(5.21 KB)
📄
config.go
(7.54 KB)
📄
data.go
(89.78 KB)
📄
data_test.go
(2.32 KB)
📄
deadcode.go
(15.66 KB)
📄
deadcode_test.go
(1.34 KB)
📄
decodesym.go
(9.98 KB)
📄
dwarf.go
(72.83 KB)
📄
dwarf_test.go
(46.02 KB)
📄
elf.go
(59.18 KB)
📄
elf_test.go
(2.75 KB)
📄
errors.go
(1.91 KB)
📄
execarchive.go
(901 B)
📄
execarchive_noexec.go
(343 B)
📄
fallocate_test.go
(1.64 KB)
📄
go.go
(11.84 KB)
📄
go_test.go
(2.68 KB)
📄
heap.go
(960 B)
📄
heap_test.go
(1.87 KB)
📄
issue33808_test.go
(792 B)
📄
ld.go
(8.08 KB)
📄
ld_test.go
(8.16 KB)
📄
lib.go
(76.84 KB)
📄
link.go
(5.13 KB)
📄
macho.go
(43.02 KB)
📄
macho_combine_dwarf.go
(13.11 KB)
📄
main.go
(14.01 KB)
📄
nooptcgolink_test.go
(738 B)
📄
outbuf.go
(8.05 KB)
📄
outbuf_darwin.go
(1.48 KB)
📄
outbuf_linux.go
(304 B)
📄
outbuf_mmap.go
(1.51 KB)
📄
outbuf_nofallocate.go
(342 B)
📄
outbuf_nommap.go
(805 B)
📄
outbuf_notdarwin.go
(292 B)
📄
outbuf_test.go
(2.21 KB)
📄
outbuf_windows.go
(2.28 KB)
📄
pcln.go
(28.96 KB)
📄
pe.go
(45.98 KB)
📄
stackcheck.go
(11.86 KB)
📄
stackcheck_test.go
(2.26 KB)
📄
sym.go
(3.89 KB)
📄
symtab.go
(29.49 KB)
📄
target.go
(3.77 KB)
📁
testdata
📄
typelink.go
(1.87 KB)
📄
util.go
(2.46 KB)
📄
xcoff.go
(51.88 KB)
Editing: target.go
// Copyright 2020 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. package ld import ( "cmd/internal/objabi" "cmd/internal/sys" "encoding/binary" ) // Target holds the configuration we're building for. type Target struct { Arch *sys.Arch HeadType objabi.HeadType LinkMode LinkMode BuildMode BuildMode linkShared bool canUsePlugins bool IsELF bool } // // Target type functions // func (t *Target) IsExe() bool { return t.BuildMode == BuildModeExe } func (t *Target) IsShared() bool { return t.BuildMode == BuildModeShared } func (t *Target) IsPlugin() bool { return t.BuildMode == BuildModePlugin } func (t *Target) IsInternal() bool { return t.LinkMode == LinkInternal } func (t *Target) IsExternal() bool { return t.LinkMode == LinkExternal } func (t *Target) IsPIE() bool { return t.BuildMode == BuildModePIE } func (t *Target) IsSharedGoLink() bool { return t.linkShared } func (t *Target) CanUsePlugins() bool { return t.canUsePlugins } func (t *Target) IsElf() bool { t.mustSetHeadType() return t.IsELF } func (t *Target) IsDynlinkingGo() bool { return t.IsShared() || t.IsSharedGoLink() || t.IsPlugin() || t.CanUsePlugins() } // UseRelro reports whether to make use of "read only relocations" aka // relro. func (t *Target) UseRelro() bool { switch t.BuildMode { case BuildModeCArchive, BuildModeCShared, BuildModeShared, BuildModePIE, BuildModePlugin: return t.IsELF || t.HeadType == objabi.Haix || t.HeadType == objabi.Hdarwin default: if t.HeadType == objabi.Hdarwin && t.IsARM64() { // On darwin/ARM64, everything is PIE. return true } return t.linkShared || (t.HeadType == objabi.Haix && t.LinkMode == LinkExternal) } } // // Processor functions // func (t *Target) Is386() bool { return t.Arch.Family == sys.I386 } func (t *Target) IsARM() bool { return t.Arch.Family == sys.ARM } func (t *Target) IsARM64() bool { return t.Arch.Family == sys.ARM64 } func (t *Target) IsAMD64() bool { return t.Arch.Family == sys.AMD64 } func (t *Target) IsMIPS() bool { return t.Arch.Family == sys.MIPS } func (t *Target) IsMIPS64() bool { return t.Arch.Family == sys.MIPS64 } func (t *Target) IsLOONG64() bool { return t.Arch.Family == sys.Loong64 } func (t *Target) IsPPC64() bool { return t.Arch.Family == sys.PPC64 } func (t *Target) IsRISCV64() bool { return t.Arch.Family == sys.RISCV64 } func (t *Target) IsS390X() bool { return t.Arch.Family == sys.S390X } func (t *Target) IsWasm() bool { return t.Arch.Family == sys.Wasm } // // OS Functions // func (t *Target) IsLinux() bool { t.mustSetHeadType() return t.HeadType == objabi.Hlinux } func (t *Target) IsDarwin() bool { t.mustSetHeadType() return t.HeadType == objabi.Hdarwin } func (t *Target) IsWindows() bool { t.mustSetHeadType() return t.HeadType == objabi.Hwindows } func (t *Target) IsPlan9() bool { t.mustSetHeadType() return t.HeadType == objabi.Hplan9 } func (t *Target) IsAIX() bool { t.mustSetHeadType() return t.HeadType == objabi.Haix } func (t *Target) IsSolaris() bool { t.mustSetHeadType() return t.HeadType == objabi.Hsolaris } func (t *Target) IsNetbsd() bool { t.mustSetHeadType() return t.HeadType == objabi.Hnetbsd } func (t *Target) IsOpenbsd() bool { t.mustSetHeadType() return t.HeadType == objabi.Hopenbsd } func (t *Target) mustSetHeadType() { if t.HeadType == objabi.Hunknown { panic("HeadType is not set") } } // // MISC // func (t *Target) IsBigEndian() bool { return t.Arch.ByteOrder == binary.BigEndian } func (t *Target) UsesLibc() bool { t.mustSetHeadType() switch t.HeadType { case objabi.Haix, objabi.Hdarwin, objabi.Hopenbsd, objabi.Hsolaris, objabi.Hwindows: // platforms where we use libc for syscalls. return true } return false }
Upload File
Create Folder