1894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman//==-- MSP430.h - Top-level interface for MSP430 representation --*- C++ -*-==//
2894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman//
3894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman//                     The LLVM Compiler Infrastructure
4894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman//
5894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman// This file is distributed under the University of Illinois Open Source
6894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman// License. See LICENSE.TXT for details.
7894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman//
8894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman//===----------------------------------------------------------------------===//
9894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman//
10894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman// This file contains the entry points for global functions defined in
11894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman// the LLVM MSP430 backend.
12894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman//
13894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman//===----------------------------------------------------------------------===//
14894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman
15894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman#ifndef LLVM_TARGET_MSP430_H
16894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman#define LLVM_TARGET_MSP430_H
17894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman
1819bac1e08be200c31efd26f0f5fd144c9b3eefd3John Bauman#include "MCTargetDesc/MSP430MCTargetDesc.h"
19894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman#include "llvm/Target/TargetMachine.h"
20894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman
21894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Baumannamespace MSP430CC {
22894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman  // MSP430 specific condition code.
23894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman  enum CondCodes {
24894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman    COND_E  = 0,  // aka COND_Z
25894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman    COND_NE = 1,  // aka COND_NZ
26894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman    COND_HS = 2,  // aka COND_C
27894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman    COND_LO = 3,  // aka COND_NC
28894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman    COND_GE = 4,
29894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman    COND_L  = 5,
30894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman
31894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman    COND_INVALID = -1
32894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman  };
33894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman}
34894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman
35894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Baumannamespace llvm {
36894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman  class MSP430TargetMachine;
37894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman  class FunctionPass;
38894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman  class formatted_raw_ostream;
39894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman
40894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman  FunctionPass *createMSP430ISelDag(MSP430TargetMachine &TM,
41894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman                                    CodeGenOpt::Level OptLevel);
42894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman
43894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman  FunctionPass *createMSP430BranchSelectionPass();
44894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman
45894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman} // end namespace llvm;
46894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman
47894018228b0e0bdbd7aa7e8f47d4a9458789ca82John Bauman#endif
48