elf_object.hh (11906:4b99c1bb3b72) elf_object.hh (14017:815c925b777d)
1/*
2 * Copyright (c) 2013 ARM Limited
3 * All rights reserved
4 *
5 * The license below extends only to copyright in the software and shall
6 * not be construed as granting a license to any other intellectual
7 * property including but not limited to intellectual property relating
8 * to a hardware implementation of the functionality of the software
9 * licensed hereunder. You may use the software subject to the license
10 * terms below provided that you ensure that this notice is replicated
11 * unmodified and in its entirety in all distributions of the software,
12 * modified or unmodified, in source code or in binary form.
13 *
14 * Copyright (c) 2003-2005 The Regents of The University of Michigan
15 * All rights reserved.
16 *
17 * Redistribution and use in source and binary forms, with or without
18 * modification, are permitted provided that the following conditions are
19 * met: redistributions of source code must retain the above copyright
20 * notice, this list of conditions and the following disclaimer;
21 * redistributions in binary form must reproduce the above copyright
22 * notice, this list of conditions and the following disclaimer in the
23 * documentation and/or other materials provided with the distribution;
24 * neither the name of the copyright holders nor the names of its
25 * contributors may be used to endorse or promote products derived from
26 * this software without specific prior written permission.
27 *
28 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
29 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
30 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
31 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
32 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
33 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
34 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
35 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
36 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
37 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
38 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
39 *
40 * Authors: Steve Reinhardt
41 */
42
43#ifndef __ELF_OBJECT_HH__
44#define __ELF_OBJECT_HH__
45
46#include <set>
47#include <vector>
48
49#include "base/loader/object_file.hh"
50
51class ElfObject : public ObjectFile
52{
53 protected:
54 // The global definition of a gem5 "Section" is closest to ELF's segments.
55 typedef ObjectFile::Section Segment;
56
57 // These values are provided to a linux process by the kernel, so we
58 // need to keep them around.
59 Addr _programHeaderTable;
60 uint16_t _programHeaderSize;
61 uint16_t _programHeaderCount;
62 std::set<std::string> sectionNames;
63
64 ElfObject *interpreter;
65
66 // An interpreter load bias is the location in the process address space
67 // where the interpreter is chosen to reside. Typically, this is carved
68 // out of the top of the mmap reserve section.
69 Addr ldBias;
70
71 // The interpreter is typically a relocatable shared library and will
72 // have a default value of zero which means that it does not care where
73 // it is placed. However, the loader can be compiled and linked so that
74 // it does care and needs a specific entry point.
75 bool relocate;
76
77 // The ldMin and ldMax fields are required to know how large of an
78 // area is required to map the interpreter.
79 Addr ldMin;
80 Addr ldMax;
81
82 /// Helper functions for loadGlobalSymbols() and loadLocalSymbols().
83 bool loadSomeSymbols(SymbolTable *symtab, int binding, Addr mask,
84 Addr base, Addr offset);
85
86 ElfObject(const std::string &_filename, size_t _len, uint8_t *_data,
87 Arch _arch, OpSys _opSys);
88
89 void getSections();
90 bool sectionExists(std::string sec);
91
92 std::vector<Segment> extraSegments;
93
94 public:
95 virtual ~ElfObject() {}
96
1/*
2 * Copyright (c) 2013 ARM Limited
3 * All rights reserved
4 *
5 * The license below extends only to copyright in the software and shall
6 * not be construed as granting a license to any other intellectual
7 * property including but not limited to intellectual property relating
8 * to a hardware implementation of the functionality of the software
9 * licensed hereunder. You may use the software subject to the license
10 * terms below provided that you ensure that this notice is replicated
11 * unmodified and in its entirety in all distributions of the software,
12 * modified or unmodified, in source code or in binary form.
13 *
14 * Copyright (c) 2003-2005 The Regents of The University of Michigan
15 * All rights reserved.
16 *
17 * Redistribution and use in source and binary forms, with or without
18 * modification, are permitted provided that the following conditions are
19 * met: redistributions of source code must retain the above copyright
20 * notice, this list of conditions and the following disclaimer;
21 * redistributions in binary form must reproduce the above copyright
22 * notice, this list of conditions and the following disclaimer in the
23 * documentation and/or other materials provided with the distribution;
24 * neither the name of the copyright holders nor the names of its
25 * contributors may be used to endorse or promote products derived from
26 * this software without specific prior written permission.
27 *
28 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
29 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
30 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
31 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
32 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
33 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
34 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
35 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
36 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
37 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
38 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
39 *
40 * Authors: Steve Reinhardt
41 */
42
43#ifndef __ELF_OBJECT_HH__
44#define __ELF_OBJECT_HH__
45
46#include <set>
47#include <vector>
48
49#include "base/loader/object_file.hh"
50
51class ElfObject : public ObjectFile
52{
53 protected:
54 // The global definition of a gem5 "Section" is closest to ELF's segments.
55 typedef ObjectFile::Section Segment;
56
57 // These values are provided to a linux process by the kernel, so we
58 // need to keep them around.
59 Addr _programHeaderTable;
60 uint16_t _programHeaderSize;
61 uint16_t _programHeaderCount;
62 std::set<std::string> sectionNames;
63
64 ElfObject *interpreter;
65
66 // An interpreter load bias is the location in the process address space
67 // where the interpreter is chosen to reside. Typically, this is carved
68 // out of the top of the mmap reserve section.
69 Addr ldBias;
70
71 // The interpreter is typically a relocatable shared library and will
72 // have a default value of zero which means that it does not care where
73 // it is placed. However, the loader can be compiled and linked so that
74 // it does care and needs a specific entry point.
75 bool relocate;
76
77 // The ldMin and ldMax fields are required to know how large of an
78 // area is required to map the interpreter.
79 Addr ldMin;
80 Addr ldMax;
81
82 /// Helper functions for loadGlobalSymbols() and loadLocalSymbols().
83 bool loadSomeSymbols(SymbolTable *symtab, int binding, Addr mask,
84 Addr base, Addr offset);
85
86 ElfObject(const std::string &_filename, size_t _len, uint8_t *_data,
87 Arch _arch, OpSys _opSys);
88
89 void getSections();
90 bool sectionExists(std::string sec);
91
92 std::vector<Segment> extraSegments;
93
94 public:
95 virtual ~ElfObject() {}
96
97 bool loadSections(PortProxy& mem_proxy, Addr addr_mask = maxAddr,
97 bool loadSections(const PortProxy& mem_proxy, Addr addr_mask = maxAddr,
98 Addr offset = 0) override;
99
100 virtual bool loadAllSymbols(SymbolTable *symtab, Addr base = 0,
101 Addr offset = 0, Addr addr_mask = maxAddr)
102 override;
103
104 virtual bool loadGlobalSymbols(SymbolTable *symtab, Addr base = 0,
105 Addr offset = 0, Addr addr_mask = maxAddr)
106 override;
107
108 virtual bool loadLocalSymbols(SymbolTable *symtab, Addr base = 0,
109 Addr offset = 0, Addr addr_mask = maxAddr)
110 override;
111
112 virtual bool loadWeakSymbols(SymbolTable *symtab, Addr base = 0,
113 Addr offset = 0, Addr addr_mask = maxAddr)
114 override;
115
116
117 virtual ObjectFile *getInterpreter() const override
118 { return interpreter; }
119 virtual Addr bias() const override { return ldBias; }
120 virtual bool relocatable() const override { return relocate; }
121 virtual Addr mapSize() const override { return ldMax - ldMin; }
122 virtual void updateBias(Addr bias_addr) override;
123
124 virtual bool hasTLS() override { return sectionExists(".tbss"); }
125
126 static ObjectFile *tryFile(const std::string &fname,
127 size_t len, uint8_t *data,
128 bool skip_interp_check = false);
129 Addr programHeaderTable() {return _programHeaderTable;}
130 uint16_t programHeaderSize() {return _programHeaderSize;}
131 uint16_t programHeaderCount() {return _programHeaderCount;}
132};
133
134#endif // __ELF_OBJECT_HH__
98 Addr offset = 0) override;
99
100 virtual bool loadAllSymbols(SymbolTable *symtab, Addr base = 0,
101 Addr offset = 0, Addr addr_mask = maxAddr)
102 override;
103
104 virtual bool loadGlobalSymbols(SymbolTable *symtab, Addr base = 0,
105 Addr offset = 0, Addr addr_mask = maxAddr)
106 override;
107
108 virtual bool loadLocalSymbols(SymbolTable *symtab, Addr base = 0,
109 Addr offset = 0, Addr addr_mask = maxAddr)
110 override;
111
112 virtual bool loadWeakSymbols(SymbolTable *symtab, Addr base = 0,
113 Addr offset = 0, Addr addr_mask = maxAddr)
114 override;
115
116
117 virtual ObjectFile *getInterpreter() const override
118 { return interpreter; }
119 virtual Addr bias() const override { return ldBias; }
120 virtual bool relocatable() const override { return relocate; }
121 virtual Addr mapSize() const override { return ldMax - ldMin; }
122 virtual void updateBias(Addr bias_addr) override;
123
124 virtual bool hasTLS() override { return sectionExists(".tbss"); }
125
126 static ObjectFile *tryFile(const std::string &fname,
127 size_t len, uint8_t *data,
128 bool skip_interp_check = false);
129 Addr programHeaderTable() {return _programHeaderTable;}
130 uint16_t programHeaderSize() {return _programHeaderSize;}
131 uint16_t programHeaderCount() {return _programHeaderCount;}
132};
133
134#endif // __ELF_OBJECT_HH__