Follow up to the series: 1. https://reviews.llvm.org/D140161 2. https://reviews.llvm.org/D140349 3. https://reviews.llvm.org/D140331 4. https://reviews.llvm.org/D140323 Completes the work from the previous two for remaining targets. This creates the following named passes that can be run via `llc -{start|stop}-{before|after}`: - arc-isel - arm-isel - avr-isel - bpf-isel - csky-isel - hexagon-isel - lanai-isel - loongarch-isel - m68k-isel - msp430-isel - mips-isel - nvptx-isel - ppc-codegen - riscv-isel - sparc-isel - systemz-isel - ve-isel - wasm-isel - xcore-isel A nice way to write tests for SelectionDAGISel might be to use a RUN: line like: llc -mtriple=<triple> -start-before=<arch>-isel -stop-after=finalize-isel -o - Fixes: https://github.com/llvm/llvm-project/issues/59538 Reviewed By: asb, zixuan-wu Differential Revision: https://reviews.llvm.org/D140364
51 lines
1.4 KiB
C++
51 lines
1.4 KiB
C++
//==-- MSP430.h - Top-level interface for MSP430 representation --*- C++ -*-==//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file contains the entry points for global functions defined in
|
|
// the LLVM MSP430 backend.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_LIB_TARGET_MSP430_MSP430_H
|
|
#define LLVM_LIB_TARGET_MSP430_MSP430_H
|
|
|
|
#include "MCTargetDesc/MSP430MCTargetDesc.h"
|
|
#include "llvm/Target/TargetMachine.h"
|
|
|
|
namespace MSP430CC {
|
|
// MSP430 specific condition code.
|
|
enum CondCodes {
|
|
COND_E = 0, // aka COND_Z
|
|
COND_NE = 1, // aka COND_NZ
|
|
COND_HS = 2, // aka COND_C
|
|
COND_LO = 3, // aka COND_NC
|
|
COND_GE = 4,
|
|
COND_L = 5,
|
|
COND_N = 6, // jump if negative
|
|
COND_NONE, // unconditional
|
|
|
|
COND_INVALID = -1
|
|
};
|
|
}
|
|
|
|
namespace llvm {
|
|
class FunctionPass;
|
|
class MSP430TargetMachine;
|
|
class PassRegistry;
|
|
|
|
FunctionPass *createMSP430ISelDag(MSP430TargetMachine &TM,
|
|
CodeGenOpt::Level OptLevel);
|
|
|
|
FunctionPass *createMSP430BranchSelectionPass();
|
|
|
|
void initializeMSP430DAGToDAGISelPass(PassRegistry &);
|
|
|
|
} // namespace llvm
|
|
|
|
#endif
|