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