1 //===-- BPFSubtarget.cpp - BPF Subtarget Information ----------------------===//
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7 //===----------------------------------------------------------------------===//
9 // This file implements the BPF specific subclass of TargetSubtargetInfo.
11 //===----------------------------------------------------------------------===//
13 #include "BPFSubtarget.h"
15 #include "llvm/MC/TargetRegistry.h"
16 #include "llvm/TargetParser/Host.h"
20 #define DEBUG_TYPE "bpf-subtarget"
22 #define GET_SUBTARGETINFO_TARGET_DESC
23 #define GET_SUBTARGETINFO_CTOR
24 #include "BPFGenSubtargetInfo.inc"
26 static cl::opt
<bool> Disable_ldsx("disable-ldsx", cl::Hidden
, cl::init(false),
27 cl::desc("Disable ldsx insns"));
28 static cl::opt
<bool> Disable_movsx("disable-movsx", cl::Hidden
, cl::init(false),
29 cl::desc("Disable movsx insns"));
30 static cl::opt
<bool> Disable_bswap("disable-bswap", cl::Hidden
, cl::init(false),
31 cl::desc("Disable bswap insns"));
32 static cl::opt
<bool> Disable_sdiv_smod("disable-sdiv-smod", cl::Hidden
,
33 cl::init(false), cl::desc("Disable sdiv/smod insns"));
34 static cl::opt
<bool> Disable_gotol("disable-gotol", cl::Hidden
, cl::init(false),
35 cl::desc("Disable gotol insn"));
37 Disable_StoreImm("disable-storeimm", cl::Hidden
, cl::init(false),
38 cl::desc("Disable BPF_ST (immediate store) insn"));
40 void BPFSubtarget::anchor() {}
42 BPFSubtarget
&BPFSubtarget::initializeSubtargetDependencies(StringRef CPU
,
44 initializeEnvironment();
45 initSubtargetFeatures(CPU
, FS
);
46 ParseSubtargetFeatures(CPU
, /*TuneCPU*/ CPU
, FS
);
50 void BPFSubtarget::initializeEnvironment() {
63 void BPFSubtarget::initSubtargetFeatures(StringRef CPU
, StringRef FS
) {
65 CPU
= sys::detail::getHostCPUNameForBPF();
66 if (CPU
== "generic" || CPU
== "v1")
82 HasLdsx
= !Disable_ldsx
;
83 HasMovsx
= !Disable_movsx
;
84 HasBswap
= !Disable_bswap
;
85 HasSdivSmod
= !Disable_sdiv_smod
;
86 HasGotol
= !Disable_gotol
;
87 HasStoreImm
= !Disable_StoreImm
;
92 BPFSubtarget::BPFSubtarget(const Triple
&TT
, const std::string
&CPU
,
93 const std::string
&FS
, const TargetMachine
&TM
)
94 : BPFGenSubtargetInfo(TT
, CPU
, /*TuneCPU*/ CPU
, FS
),
95 FrameLowering(initializeSubtargetDependencies(CPU
, FS
)),