blob: 20c0050309f503515c8879578ea2cb97c3388bb5 [file] [log] [blame]
Adam Sawickiae5c4662019-01-02 10:23:35 +01001//
Adam Sawickiaa183742021-02-16 17:28:49 +01002// Copyright (c) 2017-2021 Advanced Micro Devices, Inc. All rights reserved.
Adam Sawickiae5c4662019-01-02 10:23:35 +01003//
4// Permission is hereby granted, free of charge, to any person obtaining a copy
5// of this software and associated documentation files (the "Software"), to deal
6// in the Software without restriction, including without limitation the rights
7// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8// copies of the Software, and to permit persons to whom the Software is
9// furnished to do so, subject to the following conditions:
10//
11// The above copyright notice and this permission notice shall be included in
12// all copies or substantial portions of the Software.
13//
14// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
19// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
20// THE SOFTWARE.
21//
22
Adam Sawickif1a793c2018-03-13 15:42:22 +010023#include "Common.h"
24
25#ifdef _WIN32
26
Adam Sawickib8333fb2018-03-13 16:15:53 +010027void ReadFile(std::vector<char>& out, const char* fileName)
28{
29 std::ifstream file(fileName, std::ios::ate | std::ios::binary);
30 assert(file.is_open());
31 size_t fileSize = (size_t)file.tellg();
32 if(fileSize > 0)
33 {
34 out.resize(fileSize);
35 file.seekg(0);
36 file.read(out.data(), fileSize);
37 }
38 else
39 out.clear();
40}
41
42void SetConsoleColor(CONSOLE_COLOR color)
43{
44 WORD attr = 0;
45 switch(color)
46 {
47 case CONSOLE_COLOR::INFO:
Adam Sawicki8caf0bd2020-07-15 16:56:30 +020048 attr = FOREGROUND_INTENSITY;
Adam Sawickib8333fb2018-03-13 16:15:53 +010049 break;
50 case CONSOLE_COLOR::NORMAL:
51 attr = FOREGROUND_RED | FOREGROUND_GREEN | FOREGROUND_BLUE;
52 break;
53 case CONSOLE_COLOR::WARNING:
54 attr = FOREGROUND_RED | FOREGROUND_GREEN | FOREGROUND_INTENSITY;
55 break;
56 case CONSOLE_COLOR::ERROR_:
57 attr = FOREGROUND_RED | FOREGROUND_INTENSITY;
58 break;
59 default:
60 assert(0);
61 }
62
63 HANDLE out = GetStdHandle(STD_OUTPUT_HANDLE);
64 SetConsoleTextAttribute(out, attr);
65}
66
67void PrintMessage(CONSOLE_COLOR color, const char* msg)
68{
69 if(color != CONSOLE_COLOR::NORMAL)
70 SetConsoleColor(color);
71
72 printf("%s\n", msg);
73
74 if (color != CONSOLE_COLOR::NORMAL)
75 SetConsoleColor(CONSOLE_COLOR::NORMAL);
76}
77
78void PrintMessage(CONSOLE_COLOR color, const wchar_t* msg)
79{
80 if(color != CONSOLE_COLOR::NORMAL)
81 SetConsoleColor(color);
82
83 wprintf(L"%s\n", msg);
84
85 if (color != CONSOLE_COLOR::NORMAL)
86 SetConsoleColor(CONSOLE_COLOR::NORMAL);
87}
88
89static const size_t CONSOLE_SMALL_BUF_SIZE = 256;
90
91void PrintMessageV(CONSOLE_COLOR color, const char* format, va_list argList)
92{
93 size_t dstLen = (size_t)::_vscprintf(format, argList);
94 if(dstLen)
95 {
96 bool useSmallBuf = dstLen < CONSOLE_SMALL_BUF_SIZE;
97 char smallBuf[CONSOLE_SMALL_BUF_SIZE];
98 std::vector<char> bigBuf(useSmallBuf ? 0 : dstLen + 1);
99 char* bufPtr = useSmallBuf ? smallBuf : bigBuf.data();
100 ::vsprintf_s(bufPtr, dstLen + 1, format, argList);
101 PrintMessage(color, bufPtr);
102 }
103}
104
105void PrintMessageV(CONSOLE_COLOR color, const wchar_t* format, va_list argList)
106{
107 size_t dstLen = (size_t)::_vcwprintf(format, argList);
108 if(dstLen)
109 {
110 bool useSmallBuf = dstLen < CONSOLE_SMALL_BUF_SIZE;
111 wchar_t smallBuf[CONSOLE_SMALL_BUF_SIZE];
112 std::vector<wchar_t> bigBuf(useSmallBuf ? 0 : dstLen + 1);
113 wchar_t* bufPtr = useSmallBuf ? smallBuf : bigBuf.data();
114 ::vswprintf_s(bufPtr, dstLen + 1, format, argList);
115 PrintMessage(color, bufPtr);
116 }
117}
118
119void PrintMessageF(CONSOLE_COLOR color, const char* format, ...)
120{
121 va_list argList;
122 va_start(argList, format);
123 PrintMessageV(color, format, argList);
124 va_end(argList);
125}
126
127void PrintMessageF(CONSOLE_COLOR color, const wchar_t* format, ...)
128{
129 va_list argList;
130 va_start(argList, format);
131 PrintMessageV(color, format, argList);
132 va_end(argList);
133}
134
135void PrintWarningF(const char* format, ...)
136{
137 va_list argList;
138 va_start(argList, format);
139 PrintMessageV(CONSOLE_COLOR::WARNING, format, argList);
140 va_end(argList);
141}
142
143void PrintWarningF(const wchar_t* format, ...)
144{
145 va_list argList;
146 va_start(argList, format);
147 PrintMessageV(CONSOLE_COLOR::WARNING, format, argList);
148 va_end(argList);
149}
150
151void PrintErrorF(const char* format, ...)
152{
153 va_list argList;
154 va_start(argList, format);
155 PrintMessageV(CONSOLE_COLOR::WARNING, format, argList);
156 va_end(argList);
157}
158
159void PrintErrorF(const wchar_t* format, ...)
160{
161 va_list argList;
162 va_start(argList, format);
163 PrintMessageV(CONSOLE_COLOR::WARNING, format, argList);
164 va_end(argList);
165}
166
167void SaveFile(const wchar_t* filePath, const void* data, size_t dataSize)
168{
169 FILE* f = nullptr;
170 _wfopen_s(&f, filePath, L"wb");
171 if(f)
172 {
173 fwrite(data, 1, dataSize, f);
174 fclose(f);
175 }
176 else
177 assert(0);
178}
179
Adam Sawickiafd50562021-02-26 11:59:58 +0100180std::wstring SizeToStr(size_t size)
181{
182 if(size == 0)
183 return L"0";
184 wchar_t result[32];
185 double size2 = (double)size;
186 if (size2 >= 1024.0*1024.0*1024.0*1024.0)
187 {
188 swprintf_s(result, L"%.2f TB", size2 / (1024.0*1024.0*1024.0*1024.0));
189 }
190 else if (size2 >= 1024.0*1024.0*1024.0)
191 {
192 swprintf_s(result, L"%.2f GB", size2 / (1024.0*1024.0*1024.0));
193 }
194 else if (size2 >= 1024.0*1024.0)
195 {
196 swprintf_s(result, L"%.2f MB", size2 / (1024.0*1024.0));
197 }
198 else if (size2 >= 1024.0)
199 {
200 swprintf_s(result, L"%.2f KB", size2 / 1024.0);
201 }
202 else
203 swprintf_s(result, L"%llu B", size);
204 return result;
205}
206
207const wchar_t* PhysicalDeviceTypeToStr(VkPhysicalDeviceType type)
208{
209 // Skipping common prefix VK_PHYSICAL_DEVICE_TYPE_
210 static const wchar_t* const VALUES[] = {
211 L"OTHER",
212 L"INTEGRATED_GPU",
213 L"DISCRETE_GPU",
214 L"VIRTUAL_GPU",
215 L"CPU",
216 };
217 return (uint32_t)type < _countof(VALUES) ? VALUES[(uint32_t)type] : L"";
218}
219
220const wchar_t* VendorIDToStr(uint32_t vendorID)
221{
222 switch(vendorID)
223 {
224 // Skipping common prefix VK_VENDOR_ID_ for these:
225 case 0x10001: return L"VIV";
226 case 0x10002: return L"VSI";
227 case 0x10003: return L"KAZAN";
228 case 0x10004: return L"CODEPLAY";
229 case 0x10005: return L"MESA";
230 case 0x10006: return L"POCL";
231 // Others...
232 case VENDOR_ID_AMD: return L"AMD";
233 case VENDOR_ID_NVIDIA: return L"NVIDIA";
234 case VENDOR_ID_INTEL: return L"Intel";
235 case 0x1010: return L"ImgTec";
236 case 0x13B5: return L"ARM";
237 case 0x5143: return L"Qualcomm";
238 }
239 return L"";
240}
241
242#if VMA_VULKAN_VERSION >= 1002000
243const wchar_t* DriverIDToStr(VkDriverId driverID)
244{
245 // Skipping common prefix VK_DRIVER_ID_
246 static const wchar_t* const VALUES[] = {
247 L"",
248 L"AMD_PROPRIETARY",
249 L"AMD_OPEN_SOURCE",
250 L"MESA_RADV",
251 L"NVIDIA_PROPRIETARY",
252 L"INTEL_PROPRIETARY_WINDOWS",
253 L"INTEL_OPEN_SOURCE_MESA",
254 L"IMAGINATION_PROPRIETARY",
255 L"QUALCOMM_PROPRIETARY",
256 L"ARM_PROPRIETARY",
257 L"GOOGLE_SWIFTSHADER",
258 L"GGP_PROPRIETARY",
259 L"BROADCOM_PROPRIETARY",
260 L"MESA_LLVMPIPE",
261 L"MOLTENVK",
262 };
263 return (uint32_t)driverID < _countof(VALUES) ? VALUES[(uint32_t)driverID] : L"";
264}
265#endif // #if VMA_VULKAN_VERSION >= 1002000
266
267
Adam Sawickif1a793c2018-03-13 15:42:22 +0100268#endif // #ifdef _WIN32