Commit 3bcb481a authored by Michael Hudson-Doyle's avatar Michael Hudson-Doyle

cmd/link: rename AttrHidden to AttrNotInSymbolTable

I want to move the SHIDDEN type bit into Attribute, but AttrHidden is already
there and means something completely different, so rename it. (I'll give the
SHIDDEN bit a better name when it moves too).

Change-Id: I075403d9542b7626d4c1f6db9094329c4181aad3
Reviewed-on: https://go-review.googlesource.com/42024
Run-TryBot: Michael Hudson-Doyle <michael.hudson@canonical.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: default avatarBrad Fitzpatrick <bradfitz@golang.org>
parent f72534ab
...@@ -147,7 +147,7 @@ func newdie(ctxt *Link, parent *dwarf.DWDie, abbrev int, name string, version in ...@@ -147,7 +147,7 @@ func newdie(ctxt *Link, parent *dwarf.DWDie, abbrev int, name string, version in
if name != "" && (abbrev <= dwarf.DW_ABRV_VARIABLE || abbrev >= dwarf.DW_ABRV_NULLTYPE) { if name != "" && (abbrev <= dwarf.DW_ABRV_VARIABLE || abbrev >= dwarf.DW_ABRV_NULLTYPE) {
if abbrev != dwarf.DW_ABRV_VARIABLE || version == 0 { if abbrev != dwarf.DW_ABRV_VARIABLE || version == 0 {
sym := ctxt.Syms.Lookup(dwarf.InfoPrefix+name, version) sym := ctxt.Syms.Lookup(dwarf.InfoPrefix+name, version)
sym.Attr |= AttrHidden sym.Attr |= AttrNotInSymbolTable
sym.Type = SDWARFINFO sym.Type = SDWARFINFO
die.Sym = sym die.Sym = sym
} }
...@@ -339,7 +339,7 @@ func dotypedef(ctxt *Link, parent *dwarf.DWDie, name string, def *dwarf.DWDie) { ...@@ -339,7 +339,7 @@ func dotypedef(ctxt *Link, parent *dwarf.DWDie, name string, def *dwarf.DWDie) {
} }
sym := ctxt.Syms.Lookup(dtolsym(def.Sym).Name+"..def", 0) sym := ctxt.Syms.Lookup(dtolsym(def.Sym).Name+"..def", 0)
sym.Attr |= AttrHidden sym.Attr |= AttrNotInSymbolTable
sym.Type = SDWARFINFO sym.Type = SDWARFINFO
def.Sym = sym def.Sym = sym
...@@ -1081,7 +1081,7 @@ func writelines(ctxt *Link, syms []*Symbol) ([]*Symbol, []*Symbol) { ...@@ -1081,7 +1081,7 @@ func writelines(ctxt *Link, syms []*Symbol) ([]*Symbol, []*Symbol) {
epcs = s epcs = s
dsym := ctxt.Syms.Lookup(dwarf.InfoPrefix+s.Name, int(s.Version)) dsym := ctxt.Syms.Lookup(dwarf.InfoPrefix+s.Name, int(s.Version))
dsym.Attr |= AttrHidden | AttrReachable dsym.Attr |= AttrNotInSymbolTable | AttrReachable
dsym.Type = SDWARFINFO dsym.Type = SDWARFINFO
for _, r := range dsym.R { for _, r := range dsym.R {
if r.Type == objabi.R_DWARFREF && r.Sym.Size == 0 { if r.Type == objabi.R_DWARFREF && r.Sym.Size == 0 {
......
...@@ -337,7 +337,7 @@ func fieldtrack(ctxt *Link) { ...@@ -337,7 +337,7 @@ func fieldtrack(ctxt *Link) {
for _, s := range ctxt.Syms.Allsym { for _, s := range ctxt.Syms.Allsym {
if strings.HasPrefix(s.Name, "go.track.") { if strings.HasPrefix(s.Name, "go.track.") {
s.Attr |= AttrSpecial // do not lay out in data segment s.Attr |= AttrSpecial // do not lay out in data segment
s.Attr |= AttrHidden s.Attr |= AttrNotInSymbolTable
if s.Attr.Reachable() { if s.Attr.Reachable() {
buf.WriteString(s.Name[9:]) buf.WriteString(s.Name[9:])
for p := s.Reachparent; p != nil; p = p.Reachparent { for p := s.Reachparent; p != nil; p = p.Reachparent {
......
...@@ -1903,7 +1903,7 @@ func genasmsym(ctxt *Link, put func(*Link, *Symbol, string, SymbolType, int64, * ...@@ -1903,7 +1903,7 @@ func genasmsym(ctxt *Link, put func(*Link, *Symbol, string, SymbolType, int64, *
} }
for _, s := range ctxt.Syms.Allsym { for _, s := range ctxt.Syms.Allsym {
if s.Attr.Hidden() { if s.Attr.NotInSymbolTable() {
continue continue
} }
if (s.Name == "" || s.Name[0] == '.') && s.Version == 0 && s.Name != ".rathole" && s.Name != ".TOC." { if (s.Name == "" || s.Name[0] == '.') && s.Version == 0 && s.Name != ".rathole" && s.Name != ".TOC." {
......
...@@ -118,8 +118,8 @@ const ( ...@@ -118,8 +118,8 @@ const (
// AttrStackCheck is used by dostkcheck to only check each NoSplit // AttrStackCheck is used by dostkcheck to only check each NoSplit
// function's stack usage once. // function's stack usage once.
AttrStackCheck AttrStackCheck
// AttrHidden marks symbols that are not written to the symbol table. // AttrNotInSymbolTable marks symbols that are not written to the symbol table.
AttrHidden AttrNotInSymbolTable
// AttrOnList marks symbols that are on some list (such as the list of // AttrOnList marks symbols that are on some list (such as the list of
// all text symbols, or one of the lists of data symbols) and is // all text symbols, or one of the lists of data symbols) and is
// consulted to avoid bugs where a symbol is put on a list twice. // consulted to avoid bugs where a symbol is put on a list twice.
...@@ -145,7 +145,7 @@ func (a Attribute) CgoExportDynamic() bool { return a&AttrCgoExportDynamic != 0 ...@@ -145,7 +145,7 @@ func (a Attribute) CgoExportDynamic() bool { return a&AttrCgoExportDynamic != 0
func (a Attribute) CgoExportStatic() bool { return a&AttrCgoExportStatic != 0 } func (a Attribute) CgoExportStatic() bool { return a&AttrCgoExportStatic != 0 }
func (a Attribute) Special() bool { return a&AttrSpecial != 0 } func (a Attribute) Special() bool { return a&AttrSpecial != 0 }
func (a Attribute) StackCheck() bool { return a&AttrStackCheck != 0 } func (a Attribute) StackCheck() bool { return a&AttrStackCheck != 0 }
func (a Attribute) Hidden() bool { return a&AttrHidden != 0 } func (a Attribute) NotInSymbolTable() bool { return a&AttrNotInSymbolTable != 0 }
func (a Attribute) OnList() bool { return a&AttrOnList != 0 } func (a Attribute) OnList() bool { return a&AttrOnList != 0 }
func (a Attribute) Local() bool { return a&AttrLocal != 0 } func (a Attribute) Local() bool { return a&AttrLocal != 0 }
func (a Attribute) ReflectMethod() bool { return a&AttrReflectMethod != 0 } func (a Attribute) ReflectMethod() bool { return a&AttrReflectMethod != 0 }
......
...@@ -470,7 +470,7 @@ func (ctxt *Link) symtab() { ...@@ -470,7 +470,7 @@ func (ctxt *Link) symtab() {
switch { switch {
case strings.HasPrefix(s.Name, "type."): case strings.HasPrefix(s.Name, "type."):
if !ctxt.DynlinkingGo() { if !ctxt.DynlinkingGo() {
s.Attr |= AttrHidden s.Attr |= AttrNotInSymbolTable
} }
if UseRelro() { if UseRelro() {
s.Type = STYPERELRO s.Type = STYPERELRO
...@@ -488,22 +488,22 @@ func (ctxt *Link) symtab() { ...@@ -488,22 +488,22 @@ func (ctxt *Link) symtab() {
case strings.HasPrefix(s.Name, "go.itablink."): case strings.HasPrefix(s.Name, "go.itablink."):
nitablinks++ nitablinks++
s.Type = SITABLINK s.Type = SITABLINK
s.Attr |= AttrHidden s.Attr |= AttrNotInSymbolTable
s.Outer = symitablink s.Outer = symitablink
case strings.HasPrefix(s.Name, "go.string."): case strings.HasPrefix(s.Name, "go.string."):
s.Type = SGOSTRING s.Type = SGOSTRING
s.Attr |= AttrHidden s.Attr |= AttrNotInSymbolTable
s.Outer = symgostring s.Outer = symgostring
case strings.HasPrefix(s.Name, "runtime.gcbits."): case strings.HasPrefix(s.Name, "runtime.gcbits."):
s.Type = SGCBITS s.Type = SGCBITS
s.Attr |= AttrHidden s.Attr |= AttrNotInSymbolTable
s.Outer = symgcbits s.Outer = symgcbits
case strings.HasSuffix(s.Name, "·f"): case strings.HasSuffix(s.Name, "·f"):
if !ctxt.DynlinkingGo() { if !ctxt.DynlinkingGo() {
s.Attr |= AttrHidden s.Attr |= AttrNotInSymbolTable
} }
if UseRelro() { if UseRelro() {
s.Type = SGOFUNCRELRO s.Type = SGOFUNCRELRO
...@@ -518,7 +518,7 @@ func (ctxt *Link) symtab() { ...@@ -518,7 +518,7 @@ func (ctxt *Link) symtab() {
strings.HasPrefix(s.Name, "gclocals·"), strings.HasPrefix(s.Name, "gclocals·"),
strings.HasPrefix(s.Name, "inltree."): strings.HasPrefix(s.Name, "inltree."):
s.Type = SGOFUNC s.Type = SGOFUNC
s.Attr |= AttrHidden s.Attr |= AttrNotInSymbolTable
s.Outer = symgofunc s.Outer = symgofunc
s.Align = 4 s.Align = 4
liveness += (s.Size + int64(s.Align) - 1) &^ (int64(s.Align) - 1) liveness += (s.Size + int64(s.Align) - 1) &^ (int64(s.Align) - 1)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment