[InstCombine] Signed saturation patterns
[llvm-core.git] / lib / Target / RISCV / RISCVTargetObjectFile.h
blobb2daaaa9d364dc48b9ce6d79a7e68e9ff9c277b4
1 //===-- RISCVTargetObjectFile.h - RISCV Object Info -*- C++ ---------*-===//
2 //
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
6 //
7 //===----------------------------------------------------------------------===//
9 #ifndef LLVM_LIB_TARGET_RISCV_RISCVTARGETOBJECTFILE_H
10 #define LLVM_LIB_TARGET_RISCV_RISCVTARGETOBJECTFILE_H
12 #include "llvm/CodeGen/TargetLoweringObjectFileImpl.h"
14 namespace llvm {
15 class RISCVTargetMachine;
17 /// This implementation is used for RISCV ELF targets.
18 class RISCVELFTargetObjectFile : public TargetLoweringObjectFileELF {
19 MCSection *SmallDataSection;
20 MCSection *SmallBSSSection;
21 unsigned SSThreshold = 8;
23 public:
24 void Initialize(MCContext &Ctx, const TargetMachine &TM) override;
26 /// Return true if this global address should be placed into small data/bss
27 /// section.
28 bool isGlobalInSmallSection(const GlobalObject *GO,
29 const TargetMachine &TM) const;
31 MCSection *SelectSectionForGlobal(const GlobalObject *GO, SectionKind Kind,
32 const TargetMachine &TM) const override;
34 /// Return true if this constant should be placed into small data section.
35 bool isConstantInSmallSection(const DataLayout &DL, const Constant *CN) const;
37 MCSection *getSectionForConstant(const DataLayout &DL, SectionKind Kind,
38 const Constant *C,
39 unsigned &Align) const override;
41 void getModuleMetadata(Module &M) override;
43 bool isInSmallSection(uint64_t Size) const;
46 } // end namespace llvm
48 #endif