blob: 5e3713778286f9bb872bef630d45527c8ddb6d89 (
plain)
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
|
//===- llvm/MC/MCSPIRVObjectWriter.cpp - SPIR-V Object Writer ----*- 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
//
//===----------------------------------------------------------------------===//
#include "llvm/MC/MCAssembler.h"
#include "llvm/MC/MCSPIRVObjectWriter.h"
#include "llvm/MC/MCSection.h"
#include "llvm/MC/MCValue.h"
#include "llvm/Support/EndianStream.h"
using namespace llvm;
void SPIRVObjectWriter::writeHeader(const MCAssembler &Asm) {
constexpr uint32_t MagicNumber = 0x07230203;
constexpr uint32_t GeneratorID = 43;
constexpr uint32_t GeneratorMagicNumber =
(GeneratorID << 16) | (LLVM_VERSION_MAJOR);
constexpr uint32_t Schema = 0;
W.write<uint32_t>(MagicNumber);
W.write<uint32_t>((VersionInfo.Major << 16) | (VersionInfo.Minor << 8));
W.write<uint32_t>(GeneratorMagicNumber);
W.write<uint32_t>(VersionInfo.Bound);
W.write<uint32_t>(Schema);
}
void SPIRVObjectWriter::setBuildVersion(unsigned Major, unsigned Minor,
unsigned Bound) {
VersionInfo.Major = Major;
VersionInfo.Minor = Minor;
VersionInfo.Bound = Bound;
}
uint64_t SPIRVObjectWriter::writeObject() {
uint64_t StartOffset = W.OS.tell();
writeHeader(*Asm);
for (const MCSection &S : *Asm)
Asm->writeSectionData(W.OS, &S);
return W.OS.tell() - StartOffset;
}
std::unique_ptr<MCObjectWriter>
llvm::createSPIRVObjectWriter(std::unique_ptr<MCSPIRVObjectTargetWriter> MOTW,
raw_pwrite_stream &OS) {
return std::make_unique<SPIRVObjectWriter>(std::move(MOTW), OS);
}
|