LLVM: lib/Target/VE/VEFrameLowering.cpp Source File (original) (raw)

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

124

125using namespace llvm;

126

130 STI(ST) {}

131

136 bool RequireFPUpdate) const {

140

141

142

143

144

145

146

147

159 }

171 }

178}

179

184 bool RequireFPUpdate) const {

188

189

190

191

192

193

194

195

198 .addReg(VE::SX11)

210 }

220 }

221}

222

223void VEFrameLowering::emitSPAdjustment(MachineFunction &MF,

226 int64_t NumBytes,

230

231 if (NumBytes == 0) {

232

233 } else if (isInt<7>(NumBytes)) {

234

238 } else if (isInt<32>(NumBytes)) {

239

244 } else {

245

246

247

248

249

261 }

262

264

268 }

269}

270

275

276

277

278

279

280

281

282

283

284

285

286

287

288

289

290

291

292

293

294

295

296

297

298

299

300

303}

304

308 assert(&MF.front() == &MBB && "Shrink-wrapping not yet supported");

313 bool NeedsStackRealignment = RegInfo.shouldRealignStack(MF);

314

315

316

318

319 if (NeedsStackRealignment && !RegInfo.canRealignStack(MF))

321 "\" required "

322 "stack re-alignment, but LLVM couldn't handle it "

323 "(probably because it has a dynamic alloca).");

324

325

326

328

329

330

331

333

335 }

336

337

338

340

341

343

344

346

347

348

349

354

355

358 assert((RuntimeAlign == std::nullopt || !FuncInfo->isLeafProc()) &&

359 "SP has to be saved in order to align variable sized stack object!");

360 emitSPAdjustment(MF, MBB, MBBI, -(int64_t)NumBytes, RuntimeAlign);

361

363

367 }

368

369

370 if (NumBytes != 0)

371 emitSPExtend(MF, MBB, MBBI);

372}

373

379 int64_t Size = MI.getOperand(0).getImm();

380 if (MI.getOpcode() == VE::ADJCALLSTACKDOWN)

382

384 emitSPAdjustment(MF, MBB, I, Size);

385 }

387}

388

396

398

399

401

402

406 } else {

407

408 emitSPAdjustment(MF, MBB, MBBI, NumBytes, std::nullopt);

409 }

410

411

413}

414

415

416

417

420

425}

426

430

432}

433

436

437

439}

440

442 int FI,

447

449

450 if (hasFP(MF)) {

451

452 FrameReg = VE::SX11;

455 }

456 if (RegInfo->hasStackRealignment(MF) && !isFixed) {

457

458

460 FrameReg = VE::SX17;

461 else

462 FrameReg = VE::SX11;

465 }

466

469}

470

471bool VEFrameLowering::isLeafProc(MachineFunction &MF) const {

472

475

476 return !MFI.hasCalls()

477 && MRI.isPhysRegUsed(VE::SX18)

478

479 && MRI.isPhysRegUsed(VE::SX11)

480 && hasFP(MF);

481}

482

487

488

489

490 if (isLeafProc(MF) && hasBP(MF)) {

493 }

494}

unsigned const MachineRegisterInfo * MRI

MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL

MachineBasicBlock MachineBasicBlock::iterator MBBI

const HexagonInstrInfo * TII

unsigned const TargetRegisterInfo * TRI

This file declares the machine register scavenger class.

assert(ImpDefSCC.getReg()==AMDGPU::SCC &&ImpDefSCC.isDef())

iterator getLastNonDebugInstr(bool SkipPseudoOp=true)

Returns an iterator to the last non-debug instruction in the basic block, or end().

instr_iterator erase(instr_iterator I)

Remove an instruction from the instruction list and delete it.

The MachineFrameInfo class represents an abstract stack frame until prolog/epilog code is inserted.

bool hasVarSizedObjects() const

This method may be called any time after instruction selection is complete to determine if the stack ...

uint64_t getStackSize() const

Return the number of bytes that must be allocated to hold all of the fixed size frame objects.

bool hasCalls() const

Return true if the current function has any function calls.

bool isFrameAddressTaken() const

This method may be called any time after instruction selection is complete to determine if there is a...

Align getMaxAlign() const

Return the alignment in bytes that this function must be aligned to, which is greater than the defaul...

int64_t getObjectOffset(int ObjectIdx) const

Return the assigned stack offset of the specified object from the incoming stack pointer.

void setStackSize(uint64_t Size)

Set the size of the stack.

bool isFixedObjectIndex(int ObjectIdx) const

Returns true if the specified index corresponds to a fixed stack object.

const TargetSubtargetInfo & getSubtarget() const

getSubtarget - Return the subtarget for which this machine code is being compiled.

StringRef getName() const

getName - Return the name of the corresponding LLVM function.

MachineFrameInfo & getFrameInfo()

getFrameInfo - Return the frame info object for the current function.

MachineRegisterInfo & getRegInfo()

getRegInfo - Return information about the registers currently in use.

Ty * getInfo()

getInfo - Keep track of various per-function pieces of information for backends that would like to do...

const MachineBasicBlock & front() const

const TargetMachine & getTarget() const

getTarget - Return the target machine this machine code is compiled with

const MachineInstrBuilder & addImm(int64_t Val) const

Add a new immediate operand.

const MachineInstrBuilder & addReg(Register RegNo, unsigned flags=0, unsigned SubReg=0) const

Add a new virtual register operand.

Representation of each machine instruction.

MachineRegisterInfo - Keep track of information for virtual and physical registers,...

Wrapper class representing virtual and physical registers.

StackOffset holds a fixed and a scalable offset in bytes.

int64_t getFixed() const

Returns the fixed component of the stack.

Information about stack frame layout on the target.

bool hasFP(const MachineFunction &MF) const

hasFP - Return true if the specified function should have a dedicated frame pointer register.

virtual void determineCalleeSaves(MachineFunction &MF, BitVector &SavedRegs, RegScavenger *RS=nullptr) const

This method determines which of the registers reported by TargetRegisterInfo::getCalleeSavedRegs() sh...

bool DisableFramePointerElim(const MachineFunction &MF) const

DisableFramePointerElim - This returns true if frame pointer elimination optimization should be disab...

TargetRegisterInfo base class - We assume that the target defines a static array of TargetRegisterDes...

bool hasStackRealignment(const MachineFunction &MF) const

True if stack realignment is required and still possible.

virtual const TargetRegisterInfo * getRegisterInfo() const

getRegisterInfo - If register information is available, return it.

Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...

void emitEpilogueInsns(MachineFunction &MF, MachineBasicBlock &MBB, MachineBasicBlock::iterator MBBI, uint64_t NumBytes, bool RequireFPUpdate) const

bool hasBP(const MachineFunction &MF) const

void emitPrologueInsns(MachineFunction &MF, MachineBasicBlock &MBB, MachineBasicBlock::iterator MBBI, uint64_t NumBytes, bool RequireFPUpdate) const

MachineBasicBlock::iterator eliminateCallFramePseudoInstr(MachineFunction &MF, MachineBasicBlock &MBB, MachineBasicBlock::iterator I) const override

This method is called during prolog/epilog code insertion to eliminate call frame setup and destroy p...

StackOffset getFrameIndexReference(const MachineFunction &MF, int FI, Register &FrameReg) const override

getFrameIndexReference - This method should return the base register and offset used to reference a f...

bool hasFPImpl(const MachineFunction &MF) const override

void determineCalleeSaves(MachineFunction &MF, BitVector &SavedRegs, RegScavenger *RS=nullptr) const override

This method determines which of the registers reported by TargetRegisterInfo::getCalleeSavedRegs() sh...

void emitEpilogue(MachineFunction &MF, MachineBasicBlock &MBB) const override

void emitPrologue(MachineFunction &MF, MachineBasicBlock &MBB) const override

emitProlog/emitEpilog - These methods insert prolog and epilog code into the function.

VEFrameLowering(const VESubtarget &ST)

bool hasGOT(const MachineFunction &MF) const

bool hasReservedCallFrame(const MachineFunction &MF) const override

hasReservedCallFrame - Under normal circumstances, when a frame pointer is not required,...

Register getGlobalBaseReg() const

void setLeafProc(bool rhs)

uint64_t getAdjustedFrameSize(uint64_t FrameSize) const

Given a actual stack size as determined by FrameInfo, this function returns adjusted framesize which ...

const VEInstrInfo * getInstrInfo() const override

const VERegisterInfo * getRegisterInfo() const override

This is an optimization pass for GlobalISel generic memory operations.

MachineInstrBuilder BuildMI(MachineFunction &MF, const MIMetadata &MIMD, const MCInstrDesc &MCID)

Builder interface. Specify how to create the initial instruction itself.

unsigned Log2_64(uint64_t Value)

Return the floor log base 2 of the specified value, -1 if the value is zero.

unsigned M1(unsigned Val)

constexpr uint32_t Hi_32(uint64_t Value)

Return the high 32 bits of a 64 bit value.

void report_fatal_error(Error Err, bool gen_crash_diag=true)

Report a serious error, calling any installed error handler.

constexpr uint32_t Lo_32(uint64_t Value)

Return the low 32 bits of a 64 bit value.

uint64_t alignTo(uint64_t Size, Align A)

Returns a multiple of A needed to store Size bytes.

unsigned M0(unsigned Val)

This struct is a compact representation of a valid (non-zero power of two) alignment.

uint64_t value() const

This is a hole in the type system and should not be abused.

This struct is a compact representation of a valid (power of two) or undefined (0) alignment.

Align valueOrOne() const

For convenience, returns a valid alignment or 1 if undefined.

Register getFrameRegister(const MachineFunction &MF) const override