blob: d7b471c4321978d3317ee75a3c3787d3fc4b3cef (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
|
//===- HexagonGNUInfo.h ---------------------------------------------------===//
//
// The MCLinker Project
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
#ifndef MCLD_TARGET_HEXAGON_GNU_INFO_H
#define MCLD_TARGET_HEXAGON_GNU_INFO_H
#include <mcld/Target/GNUInfo.h>
#include <mcld/TargetOptions.h>
#include <llvm/Support/ELF.h>
namespace mcld {
class HexagonGNUInfo : public GNUInfo
{
public:
enum CPUType {
V3 = 0x2,
V4 = 0x3,
V5
};
public:
HexagonGNUInfo(const TargetOptions& pTargetOptions);
uint32_t machine() const { return llvm::ELF::EM_HEXAGON; }
uint64_t defaultTextSegmentAddr() const { return 0x0; }
/// flags - the value of ElfXX_Ehdr::e_flags
uint64_t flags() const;
private:
const TargetOptions& m_Options;
};
} // namespace of mcld
#endif
|