// Copyright 2014 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. // Parsing of Plan 9 a.out executables. package main import ( "debug/plan9obj" "os" "sort" ) func plan9Symbols(f *os.File) []Sym { p, err := plan9obj.NewFile(f) if err != nil { errorf("parsing %s: %v", f.Name(), err) return nil } plan9Syms, err := p.Symbols() if err != nil { errorf("parsing %s: %v", f.Name(), err) return nil } // Build sorted list of addresses of all symbols. // We infer the size of a symbol by looking at where the next symbol begins. var addrs []uint64 for _, s := range plan9Syms { addrs = append(addrs, s.Value) } sort.Sort(uint64s(addrs)) var syms []Sym for _, s := range plan9Syms { sym := Sym{Addr: s.Value, Name: s.Name, Code: rune(s.Type)} i := sort.Search(len(addrs), func(x int) bool { return addrs[x] > s.Value }) if i < len(addrs) { sym.Size = int64(addrs[i] - s.Value) } syms = append(syms, sym) } return syms }