xref: /aosp_15_r20/external/swiftshader/src/Reactor/LLVMAsm.hpp (revision 03ce13f70fcc45d86ee91b7ee4cab1936a95046e)
1*03ce13f7SAndroid Build Coastguard Worker // Copyright 2020 The SwiftShader Authors. All Rights Reserved.
2*03ce13f7SAndroid Build Coastguard Worker //
3*03ce13f7SAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License");
4*03ce13f7SAndroid Build Coastguard Worker // you may not use this file except in compliance with the License.
5*03ce13f7SAndroid Build Coastguard Worker // You may obtain a copy of the License at
6*03ce13f7SAndroid Build Coastguard Worker //
7*03ce13f7SAndroid Build Coastguard Worker //    http://www.apache.org/licenses/LICENSE-2.0
8*03ce13f7SAndroid Build Coastguard Worker //
9*03ce13f7SAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software
10*03ce13f7SAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS,
11*03ce13f7SAndroid Build Coastguard Worker // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*03ce13f7SAndroid Build Coastguard Worker // See the License for the specific language governing permissions and
13*03ce13f7SAndroid Build Coastguard Worker // limitations under the License.
14*03ce13f7SAndroid Build Coastguard Worker 
15*03ce13f7SAndroid Build Coastguard Worker #ifndef rr_LLVMAsm_hpp
16*03ce13f7SAndroid Build Coastguard Worker #define rr_LLVMAsm_hpp
17*03ce13f7SAndroid Build Coastguard Worker 
18*03ce13f7SAndroid Build Coastguard Worker #ifdef ENABLE_RR_EMIT_ASM_FILE
19*03ce13f7SAndroid Build Coastguard Worker 
20*03ce13f7SAndroid Build Coastguard Worker #	include "llvm/ExecutionEngine/Orc/JITTargetMachineBuilder.h"
21*03ce13f7SAndroid Build Coastguard Worker #	include <string>
22*03ce13f7SAndroid Build Coastguard Worker #	include <vector>
23*03ce13f7SAndroid Build Coastguard Worker 
24*03ce13f7SAndroid Build Coastguard Worker namespace rr {
25*03ce13f7SAndroid Build Coastguard Worker namespace AsmFile {
26*03ce13f7SAndroid Build Coastguard Worker 
27*03ce13f7SAndroid Build Coastguard Worker // Generate a unique name for the asm file
28*03ce13f7SAndroid Build Coastguard Worker std::string generateFilename(const std::string &emitDir, std::string routineName);
29*03ce13f7SAndroid Build Coastguard Worker 
30*03ce13f7SAndroid Build Coastguard Worker // Emit an asm file for the current module
31*03ce13f7SAndroid Build Coastguard Worker bool emitAsmFile(const std::string &filename, llvm::orc::JITTargetMachineBuilder builder, llvm::Module &module);
32*03ce13f7SAndroid Build Coastguard Worker 
33*03ce13f7SAndroid Build Coastguard Worker // Rewrites the previously generated asm file, adding extra useful information.
34*03ce13f7SAndroid Build Coastguard Worker // In particular, it prepends the final resolved location (address) of each instruction.
35*03ce13f7SAndroid Build Coastguard Worker // NOTE: Doing this is error-prone since we parse text, and are thus dependent on the
36*03ce13f7SAndroid Build Coastguard Worker // exact format of LLVM's assembly output. It would be nice if LLVM's asm output included
37*03ce13f7SAndroid Build Coastguard Worker // at least the 0-based relative address of each instruction.
38*03ce13f7SAndroid Build Coastguard Worker void fixupAsmFile(const std::string &filename, std::vector<const void *> addresses);
39*03ce13f7SAndroid Build Coastguard Worker 
40*03ce13f7SAndroid Build Coastguard Worker }  // namespace AsmFile
41*03ce13f7SAndroid Build Coastguard Worker }  // namespace rr
42*03ce13f7SAndroid Build Coastguard Worker 
43*03ce13f7SAndroid Build Coastguard Worker #endif  // ENABLE_RR_EMIT_ASM_FILE
44*03ce13f7SAndroid Build Coastguard Worker 
45*03ce13f7SAndroid Build Coastguard Worker #endif  // rr_LLVMAsm_hpp
46