12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 |
- //===-- BPFSubtarget.cpp - BPF Subtarget Information ----------------------===//
- //
- // 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 implements the BPF specific subclass of TargetSubtargetInfo.
- //
- //===----------------------------------------------------------------------===//
- #include "BPFSubtarget.h"
- #include "BPF.h"
- #include "llvm/MC/TargetRegistry.h"
- #include "llvm/Support/Host.h"
- using namespace llvm;
- #define DEBUG_TYPE "bpf-subtarget"
- #define GET_SUBTARGETINFO_TARGET_DESC
- #define GET_SUBTARGETINFO_CTOR
- #include "BPFGenSubtargetInfo.inc"
- void BPFSubtarget::anchor() {}
- BPFSubtarget &BPFSubtarget::initializeSubtargetDependencies(StringRef CPU,
- StringRef FS) {
- initializeEnvironment();
- initSubtargetFeatures(CPU, FS);
- ParseSubtargetFeatures(CPU, /*TuneCPU*/ CPU, FS);
- return *this;
- }
- void BPFSubtarget::initializeEnvironment() {
- HasJmpExt = false;
- HasJmp32 = false;
- HasAlu32 = false;
- UseDwarfRIS = false;
- }
- void BPFSubtarget::initSubtargetFeatures(StringRef CPU, StringRef FS) {
- if (CPU == "probe")
- CPU = sys::detail::getHostCPUNameForBPF();
- if (CPU == "generic" || CPU == "v1")
- return;
- if (CPU == "v2") {
- HasJmpExt = true;
- return;
- }
- if (CPU == "v3") {
- HasJmpExt = true;
- HasJmp32 = true;
- HasAlu32 = true;
- return;
- }
- }
- BPFSubtarget::BPFSubtarget(const Triple &TT, const std::string &CPU,
- const std::string &FS, const TargetMachine &TM)
- : BPFGenSubtargetInfo(TT, CPU, /*TuneCPU*/ CPU, FS),
- FrameLowering(initializeSubtargetDependencies(CPU, FS)),
- TLInfo(TM, *this) {}
|