1 /*
2 * Copyright (c) 2025, Oracle and/or its affiliates. All rights reserved.
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * This code is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License version 2 only, as
7 * published by the Free Software Foundation. Oracle designates this
8 * particular file as subject to the "Classpath" exception as provided
9 * by Oracle in the LICENSE file that accompanied this code.
10 *
11 * This code is distributed in the hope that it will be useful, but WITHOUT
12 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14 * version 2 for more details (a copy is included in the LICENSE file that
15 * accompanied this code).
16 *
17 * You should have received a copy of the GNU General Public License version
18 * 2 along with this work; if not, write to the Free Software Foundation,
19 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
20 *
21 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
22 * or visit www.oracle.com if you need additional information or have any
23 * questions.
24 */
25 /*
26 You probably should not edit this this file!!!
27 It was auto generated 2025-10-24 13:27:45.800 by hat.FFIConfigCreator
28 */
29 #pragma once
30
31 #include <iostream>
32
33
34 struct BasicConfig{
35 static constexpr int MINIMIZE_COPIES_BIT = 1<<0x8;
36 static constexpr int TRACE_BIT = 1<<0x9;
37 static constexpr int PROFILE_BIT = 1<<0xa;
38 static constexpr int SHOW_CODE_BIT = 1<<0xb;
39 static constexpr int SHOW_KERNEL_MODEL_BIT = 1<<0xc;
40 static constexpr int SHOW_COMPUTE_MODEL_BIT = 1<<0xd;
41 static constexpr int INFO_BIT = 1<<0xe;
42 static constexpr int TRACE_COPIES_BIT = 1<<0xf;
43 static constexpr int TRACE_SKIPPED_COPIES_BIT = 1<<0x10;
44 static constexpr int TRACE_ENQUEUES_BIT = 1<<0x11;
45 static constexpr int TRACE_CALLS_BIT = 1<<0x12;
46 static constexpr int SHOW_WHY_BIT = 1<<0x13;
47 static constexpr int SHOW_STATE_BIT = 1<<0x14;
48 static constexpr int PTX_BIT = 1<<0x15;
49 static constexpr int INTERPRET_BIT = 1<<0x16;
50 static constexpr int NO_DIALECT_BIT = 1<<0x17;
51 static constexpr int HEADLESS_BIT = 1<<0x18;
52 static constexpr int SHOW_LOWERED_KERNEL_MODEL_BIT = 1<<0x19;
53 static constexpr int SHOW_COMPILATION_PHASES_BIT = 1<<0x1a;
54 static constexpr int PROFILE_CUDA_KERNEL_BIT = 1<<0x1b;
55 const static char *bitNames[]; // See below for initialization
56 const static char *bitDescriptions[]; // See below for initialization
57 int configBits;
58 bool minimizeCopies;
59 bool trace;
60 bool profile;
61 bool showCode;
62 bool showKernelModel;
63 bool showComputeModel;
64 bool info;
65 bool traceCopies;
66 bool traceSkippedCopies;
67 bool traceEnqueues;
68 bool traceCalls;
69 bool showWhy;
70 bool showState;
71 bool ptx;
72 bool interpret;
73 bool noDialect;
74 bool headless;
75 bool showLoweredKernelModel;
76 bool showCompilationPhases;
77 bool profileCudaKernel;
78 int platform;
79 int device;
80 bool alwaysCopy;
81 explicit BasicConfig(int configBits):
82 configBits(configBits),
83 minimizeCopies((configBits & MINIMIZE_COPIES_BIT)==MINIMIZE_COPIES_BIT),
84 trace((configBits & TRACE_BIT)==TRACE_BIT),
85 profile((configBits & PROFILE_BIT)==PROFILE_BIT),
86 showCode((configBits & SHOW_CODE_BIT)==SHOW_CODE_BIT),
87 showKernelModel((configBits & SHOW_KERNEL_MODEL_BIT)==SHOW_KERNEL_MODEL_BIT),
88 showComputeModel((configBits & SHOW_COMPUTE_MODEL_BIT)==SHOW_COMPUTE_MODEL_BIT),
89 info((configBits & INFO_BIT)==INFO_BIT),
90 traceCopies((configBits & TRACE_COPIES_BIT)==TRACE_COPIES_BIT),
91 traceSkippedCopies((configBits & TRACE_SKIPPED_COPIES_BIT)==TRACE_SKIPPED_COPIES_BIT),
92 traceEnqueues((configBits & TRACE_ENQUEUES_BIT)==TRACE_ENQUEUES_BIT),
93 traceCalls((configBits & TRACE_CALLS_BIT)==TRACE_CALLS_BIT),
94 showWhy((configBits & SHOW_WHY_BIT)==SHOW_WHY_BIT),
95 showState((configBits & SHOW_STATE_BIT)==SHOW_STATE_BIT),
96 ptx((configBits & PTX_BIT)==PTX_BIT),
97 interpret((configBits & INTERPRET_BIT)==INTERPRET_BIT),
98 noDialect((configBits & NO_DIALECT_BIT)==NO_DIALECT_BIT),
99 headless((configBits & HEADLESS_BIT)==HEADLESS_BIT),
100 showLoweredKernelModel((configBits & SHOW_LOWERED_KERNEL_MODEL_BIT)==SHOW_LOWERED_KERNEL_MODEL_BIT),
101 showCompilationPhases((configBits & SHOW_COMPILATION_PHASES_BIT)==SHOW_COMPILATION_PHASES_BIT),
102 profileCudaKernel((configBits & PROFILE_CUDA_KERNEL_BIT)==PROFILE_CUDA_KERNEL_BIT),
103 platform(configBits & 0xf),
104 alwaysCopy(!minimizeCopies),
105 device((configBits & 0xf0) >> 4){
106 if(info){
107 std::cout << "native minimizeCopies " << minimizeCopies << std::endl;
108 std::cout << "native trace " << trace << std::endl;
109 std::cout << "native profile " << profile << std::endl;
110 std::cout << "native showCode " << showCode << std::endl;
111 std::cout << "native showKernelModel " << showKernelModel << std::endl;
112 std::cout << "native showComputeModel " << showComputeModel << std::endl;
113 std::cout << "native info " << info << std::endl;
114 std::cout << "native traceCopies " << traceCopies << std::endl;
115 std::cout << "native traceSkippedCopies " << traceSkippedCopies << std::endl;
116 std::cout << "native traceEnqueues " << traceEnqueues << std::endl;
117 std::cout << "native traceCalls " << traceCalls << std::endl;
118 std::cout << "native showWhy " << showWhy << std::endl;
119 std::cout << "native showState " << showState << std::endl;
120 std::cout << "native ptx " << ptx << std::endl;
121 std::cout << "native interpret " << interpret << std::endl;
122 std::cout << "native noDialect " << noDialect << std::endl;
123 std::cout << "native headless " << headless << std::endl;
124 std::cout << "native showLoweredKernelModel " << showLoweredKernelModel << std::endl;
125 std::cout << "native showCompilationPhases " << showCompilationPhases << std::endl;
126 std::cout << "native profileCudaKernel " << profileCudaKernel << std::endl;
127 std::cout << "native platform " << platform << std::endl;
128 std::cout << "native device " << device << std::endl;
129 }
130 }
131 virtual ~BasicConfig()= default;
132 };
133
134 #ifdef shared_cpp
135 const char *BasicConfig::bitNames[]={
136 "MINIMIZE_COPIES_BIT",
137 "TRACE_BIT",
138 "PROFILE_BIT",
139 "SHOW_CODE_BIT",
140 "SHOW_KERNEL_MODEL_BIT",
141 "SHOW_COMPUTE_MODEL_BIT",
142 "INFO_BIT",
143 "TRACE_COPIES_BIT",
144 "TRACE_SKIPPED_COPIES_BIT",
145 "TRACE_ENQUEUES_BIT",
146 "TRACE_CALLS_BIT",
147 "SHOW_WHY_BIT",
148 "SHOW_STATE_BIT",
149 "PTX_BIT",
150 "INTERPRET_BIT",
151 "NO_DIALECT_BIT",
152 "HEADLESS_BIT",
153 "SHOW_LOWERED_KERNEL_MODEL_BIT",
154 "SHOW_COMPILATION_PHASES_BIT",
155 "PROFILE_CUDA_KERNEL_BIT",
156 };
157 const char *BasicConfig::bitDescriptions[]={
158 "FFI ONLY Try to minimize copies",
159 "FFI ONLY trace code",
160 "FFI ONLY Turn on profiling",
161 "Show generated code (PTX/OpenCL/CUDA)",
162 "Show (via OpWriter) Kernel Model",
163 "Show (via OpWriter) Compute Model",
164 "FFI ONLY Show platform and device info",
165 "FFI ONLY trace copies",
166 "FFI ONLY Trace skipped copies (see MINIMIZE_COPIES) ",
167 "FFI ONLY trace enqueued tasks",
168 "FFI ONLY trace calls (enter/leave)",
169 "FFI ONLY show why we decided to copy buffer (H to D)",
170 "Show iface buffer state changes",
171 "FFI (NVIDIA) ONLY pass PTX rather than C99 CUDA code",
172 "Interpret the code model rather than converting to bytecode",
173 "Skip generating HAT dialect ops",
174 "Don't show UI",
175 "Show (via OpWriter) Lowered Kernel Model",
176 "Show HAT compilation phases",
177 "Add -lineinfo to CUDA kernel compilation for profiling and debugging",
178 };
179 #endif