blob: bd358a413128c0cfe7722c340045406fec221f89 [file] [log] [blame]
Andrew Lenharth0934ae02005-07-22 20:52:16 +00001//===- AlphaJITInfo.h - Alpha impl. of the JIT interface ----*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
Chris Lattner4ee451d2007-12-29 20:36:04 +00005// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
Andrew Lenharth0934ae02005-07-22 20:52:16 +00007//
8//===----------------------------------------------------------------------===//
9//
10// This file contains the Alpha implementation of the TargetJITInfo class.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef ALPHA_JITINFO_H
15#define ALPHA_JITINFO_H
16
17#include "llvm/Target/TargetJITInfo.h"
Owen Anderson3ea93de2009-06-25 18:13:04 +000018#include <map>
Andrew Lenharth0934ae02005-07-22 20:52:16 +000019
20namespace llvm {
21 class TargetMachine;
22
23 class AlphaJITInfo : public TargetJITInfo {
24 protected:
25 TargetMachine &TM;
Owen Anderson3ea93de2009-06-25 18:13:04 +000026
27 //because gpdist are paired and relative to the pc of the first inst,
28 //we need to have some state
29 std::map<std::pair<void*, int>, void*> gpdistmap;
Andrew Lenharth0934ae02005-07-22 20:52:16 +000030 public:
Dan Gohman950a4c42008-03-25 22:06:05 +000031 explicit AlphaJITInfo(TargetMachine &tm) : TM(tm)
Andrew Lenharth0934ae02005-07-22 20:52:16 +000032 { useGOT = true; }
33
Jeffrey Yasskin108c8382009-11-23 23:35:19 +000034 virtual StubLayout getStubLayout();
Nicolas Geoffray51cc3c12008-04-16 20:46:05 +000035 virtual void *emitFunctionStub(const Function* F, void *Fn,
Bruno Cardoso Lopesa3f99f92009-05-30 20:51:52 +000036 JITCodeEmitter &JCE);
Andrew Lenharth0934ae02005-07-22 20:52:16 +000037 virtual LazyResolverFn getLazyResolverFunction(JITCompilerFn);
38 virtual void relocate(void *Function, MachineRelocation *MR,
39 unsigned NumRelocs, unsigned char* GOTBase);
40
41 /// replaceMachineCodeForFunction - Make it so that calling the function
42 /// whose machine code is at OLD turns into a call to NEW, perhaps by
43 /// overwriting OLD with a branch to NEW. This is used for self-modifying
44 /// code.
45 ///
46 virtual void replaceMachineCodeForFunction(void *Old, void *New);
Andrew Lenharth0934ae02005-07-22 20:52:16 +000047 private:
48 static const unsigned GOToffset = 4096;
49
50 };
51}
52
53#endif