blob: 33cebe37f5fd91fa4e6e80274d9655b4e0bf832f [file] [log] [blame]
Yiwei Zhangf40fb102019-02-27 21:05:06 -08001/*
2 * Copyright 2019 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#include <inttypes.h>
18
19#include <android-base/stringprintf.h>
20#include <binder/Parcel.h>
21#include <graphicsenv/GpuStatsInfo.h>
22
23namespace android {
24
25using base::StringAppendF;
26
27status_t GpuStatsGlobalInfo::writeToParcel(Parcel* parcel) const {
28 status_t status;
29 if ((status = parcel->writeUtf8AsUtf16(driverPackageName)) != OK) return status;
30 if ((status = parcel->writeUtf8AsUtf16(driverVersionName)) != OK) return status;
31 if ((status = parcel->writeUint64(driverVersionCode)) != OK) return status;
32 if ((status = parcel->writeInt64(driverBuildTime)) != OK) return status;
33 if ((status = parcel->writeInt32(glLoadingCount)) != OK) return status;
34 if ((status = parcel->writeInt32(glLoadingFailureCount)) != OK) return status;
35 if ((status = parcel->writeInt32(vkLoadingCount)) != OK) return status;
36 if ((status = parcel->writeInt32(vkLoadingFailureCount)) != OK) return status;
Yiwei Zhang794d2952019-05-06 17:43:59 -070037 if ((status = parcel->writeInt32(vulkanVersion)) != OK) return status;
Yiwei Zhang174a2a02019-05-06 19:08:31 -070038 if ((status = parcel->writeInt32(cpuVulkanVersion)) != OK) return status;
39 if ((status = parcel->writeInt32(glesVersion)) != OK) return status;
Yiwei Zhang8e7c4b62019-05-08 15:57:59 -070040 if ((status = parcel->writeInt32(angleLoadingCount)) != OK) return status;
41 if ((status = parcel->writeInt32(angleLoadingFailureCount)) != OK) return status;
Yiwei Zhangf40fb102019-02-27 21:05:06 -080042 return OK;
43}
44
45status_t GpuStatsGlobalInfo::readFromParcel(const Parcel* parcel) {
46 status_t status;
47 if ((status = parcel->readUtf8FromUtf16(&driverPackageName)) != OK) return status;
48 if ((status = parcel->readUtf8FromUtf16(&driverVersionName)) != OK) return status;
49 if ((status = parcel->readUint64(&driverVersionCode)) != OK) return status;
50 if ((status = parcel->readInt64(&driverBuildTime)) != OK) return status;
51 if ((status = parcel->readInt32(&glLoadingCount)) != OK) return status;
52 if ((status = parcel->readInt32(&glLoadingFailureCount)) != OK) return status;
53 if ((status = parcel->readInt32(&vkLoadingCount)) != OK) return status;
54 if ((status = parcel->readInt32(&vkLoadingFailureCount)) != OK) return status;
Yiwei Zhang794d2952019-05-06 17:43:59 -070055 if ((status = parcel->readInt32(&vulkanVersion)) != OK) return status;
Yiwei Zhang174a2a02019-05-06 19:08:31 -070056 if ((status = parcel->readInt32(&cpuVulkanVersion)) != OK) return status;
57 if ((status = parcel->readInt32(&glesVersion)) != OK) return status;
Yiwei Zhang8e7c4b62019-05-08 15:57:59 -070058 if ((status = parcel->readInt32(&angleLoadingCount)) != OK) return status;
59 if ((status = parcel->readInt32(&angleLoadingFailureCount)) != OK) return status;
Yiwei Zhangf40fb102019-02-27 21:05:06 -080060 return OK;
61}
62
63std::string GpuStatsGlobalInfo::toString() const {
64 std::string result;
65 StringAppendF(&result, "driverPackageName = %s\n", driverPackageName.c_str());
66 StringAppendF(&result, "driverVersionName = %s\n", driverVersionName.c_str());
67 StringAppendF(&result, "driverVersionCode = %" PRIu64 "\n", driverVersionCode);
68 StringAppendF(&result, "driverBuildTime = %" PRId64 "\n", driverBuildTime);
69 StringAppendF(&result, "glLoadingCount = %d\n", glLoadingCount);
70 StringAppendF(&result, "glLoadingFailureCount = %d\n", glLoadingFailureCount);
Yiwei Zhang8e7c4b62019-05-08 15:57:59 -070071 StringAppendF(&result, "angleLoadingCount = %d\n", angleLoadingCount);
72 StringAppendF(&result, "angleLoadingFailureCount = %d\n", angleLoadingFailureCount);
Yiwei Zhangf40fb102019-02-27 21:05:06 -080073 StringAppendF(&result, "vkLoadingCount = %d\n", vkLoadingCount);
74 StringAppendF(&result, "vkLoadingFailureCount = %d\n", vkLoadingFailureCount);
Yiwei Zhang794d2952019-05-06 17:43:59 -070075 StringAppendF(&result, "vulkanVersion = %d\n", vulkanVersion);
Yiwei Zhang174a2a02019-05-06 19:08:31 -070076 StringAppendF(&result, "cpuVulkanVersion = %d\n", cpuVulkanVersion);
77 StringAppendF(&result, "glesVersion = %d\n", glesVersion);
Yiwei Zhangf40fb102019-02-27 21:05:06 -080078 return result;
79}
80
81status_t GpuStatsAppInfo::writeToParcel(Parcel* parcel) const {
82 status_t status;
83 if ((status = parcel->writeUtf8AsUtf16(appPackageName)) != OK) return status;
84 if ((status = parcel->writeUint64(driverVersionCode)) != OK) return status;
85 if ((status = parcel->writeInt64Vector(glDriverLoadingTime)) != OK) return status;
86 if ((status = parcel->writeInt64Vector(vkDriverLoadingTime)) != OK) return status;
Yiwei Zhang8e7c4b62019-05-08 15:57:59 -070087 if ((status = parcel->writeInt64Vector(angleDriverLoadingTime)) != OK) return status;
Yiwei Zhang8c5e3bd2019-05-09 14:34:19 -070088 if ((status = parcel->writeBool(cpuVulkanInUse)) != OK) return status;
Yiwei Zhang69395cd2019-07-03 16:55:39 -070089 if ((status = parcel->writeBool(falsePrerotation)) != OK) return status;
Yiwei Zhang011538f2019-12-20 14:37:21 -080090 if ((status = parcel->writeBool(gles1InUse)) != OK) return status;
Tim Van Pattena9ad69b2021-11-24 19:29:38 -070091 if ((status = parcel->writeBool(angleInUse)) != OK) return status;
Serdar Kocdemirb2901c92022-11-17 00:39:05 +000092 if ((status = parcel->writeBool(createdGlesContext)) != OK) return status;
93 if ((status = parcel->writeBool(createdVulkanDevice)) != OK) return status;
94 if ((status = parcel->writeBool(createdVulkanSwapchain)) != OK) return status;
95 if ((status = parcel->writeUint32(vulkanApiVersion)) != OK) return status;
96 if ((status = parcel->writeUint64(vulkanDeviceFeaturesEnabled)) != OK) return status;
97 if ((status = parcel->writeInt32Vector(vulkanInstanceExtensions)) != OK) return status;
98 if ((status = parcel->writeInt32Vector(vulkanDeviceExtensions)) != OK) return status;
Tom Murphyc23fcd02024-03-13 10:22:06 +000099 if ((status = parcel->writeUtf8VectorAsUtf16Vector(vulkanEngineNames)) != OK) return status;
Serdar Kocdemirb2901c92022-11-17 00:39:05 +0000100
Yiwei Zhangf40fb102019-02-27 21:05:06 -0800101 return OK;
102}
103
104status_t GpuStatsAppInfo::readFromParcel(const Parcel* parcel) {
105 status_t status;
106 if ((status = parcel->readUtf8FromUtf16(&appPackageName)) != OK) return status;
107 if ((status = parcel->readUint64(&driverVersionCode)) != OK) return status;
108 if ((status = parcel->readInt64Vector(&glDriverLoadingTime)) != OK) return status;
109 if ((status = parcel->readInt64Vector(&vkDriverLoadingTime)) != OK) return status;
Yiwei Zhang8e7c4b62019-05-08 15:57:59 -0700110 if ((status = parcel->readInt64Vector(&angleDriverLoadingTime)) != OK) return status;
Yiwei Zhang8c5e3bd2019-05-09 14:34:19 -0700111 if ((status = parcel->readBool(&cpuVulkanInUse)) != OK) return status;
Yiwei Zhang69395cd2019-07-03 16:55:39 -0700112 if ((status = parcel->readBool(&falsePrerotation)) != OK) return status;
Yiwei Zhang011538f2019-12-20 14:37:21 -0800113 if ((status = parcel->readBool(&gles1InUse)) != OK) return status;
Tim Van Pattena9ad69b2021-11-24 19:29:38 -0700114 if ((status = parcel->readBool(&angleInUse)) != OK) return status;
Serdar Kocdemirb2901c92022-11-17 00:39:05 +0000115 if ((status = parcel->readBool(&createdGlesContext)) != OK) return status;
116 if ((status = parcel->readBool(&createdVulkanDevice)) != OK) return status;
117 if ((status = parcel->readBool(&createdVulkanSwapchain)) != OK) return status;
118 if ((status = parcel->readUint32(&vulkanApiVersion)) != OK) return status;
119 if ((status = parcel->readUint64(&vulkanDeviceFeaturesEnabled)) != OK) return status;
120 if ((status = parcel->readInt32Vector(&vulkanInstanceExtensions)) != OK) return status;
121 if ((status = parcel->readInt32Vector(&vulkanDeviceExtensions)) != OK) return status;
Tom Murphyc23fcd02024-03-13 10:22:06 +0000122 if ((status = parcel->readUtf8VectorFromUtf16Vector(&vulkanEngineNames)) != OK) return status;
Serdar Kocdemirb2901c92022-11-17 00:39:05 +0000123
Yiwei Zhangf40fb102019-02-27 21:05:06 -0800124 return OK;
125}
126
127std::string GpuStatsAppInfo::toString() const {
128 std::string result;
129 StringAppendF(&result, "appPackageName = %s\n", appPackageName.c_str());
130 StringAppendF(&result, "driverVersionCode = %" PRIu64 "\n", driverVersionCode);
Yiwei Zhang8c5e3bd2019-05-09 14:34:19 -0700131 StringAppendF(&result, "cpuVulkanInUse = %d\n", cpuVulkanInUse);
Yiwei Zhang69395cd2019-07-03 16:55:39 -0700132 StringAppendF(&result, "falsePrerotation = %d\n", falsePrerotation);
Yiwei Zhang011538f2019-12-20 14:37:21 -0800133 StringAppendF(&result, "gles1InUse = %d\n", gles1InUse);
Tim Van Pattena9ad69b2021-11-24 19:29:38 -0700134 StringAppendF(&result, "angleInUse = %d\n", angleInUse);
Serdar Kocdemirb2901c92022-11-17 00:39:05 +0000135 StringAppendF(&result, "createdGlesContext = %d\n", createdGlesContext);
136 StringAppendF(&result, "createdVulkanDevice = %d\n", createdVulkanDevice);
137 StringAppendF(&result, "createdVulkanSwapchain = %d\n", createdVulkanSwapchain);
138 StringAppendF(&result, "vulkanApiVersion = 0x%" PRIx32 "\n", vulkanApiVersion);
139 StringAppendF(&result, "vulkanDeviceFeaturesEnabled = 0x%" PRIx64 "\n",
140 vulkanDeviceFeaturesEnabled);
Yiwei Zhangf40fb102019-02-27 21:05:06 -0800141 result.append("glDriverLoadingTime:");
142 for (int32_t loadingTime : glDriverLoadingTime) {
143 StringAppendF(&result, " %d", loadingTime);
144 }
145 result.append("\n");
Yiwei Zhang8e7c4b62019-05-08 15:57:59 -0700146 result.append("angleDriverLoadingTime:");
147 for (int32_t loadingTime : angleDriverLoadingTime) {
148 StringAppendF(&result, " %d", loadingTime);
149 }
150 result.append("\n");
Yiwei Zhangf40fb102019-02-27 21:05:06 -0800151 result.append("vkDriverLoadingTime:");
152 for (int32_t loadingTime : vkDriverLoadingTime) {
153 StringAppendF(&result, " %d", loadingTime);
154 }
155 result.append("\n");
Serdar Kocdemirb2901c92022-11-17 00:39:05 +0000156 result.append("vulkanInstanceExtensions:");
157 for (int32_t extension : vulkanInstanceExtensions) {
158 StringAppendF(&result, " 0x%x", extension);
159 }
160 result.append("\n");
161 result.append("vulkanDeviceExtensions:");
162 for (int32_t extension : vulkanDeviceExtensions) {
163 StringAppendF(&result, " 0x%x", extension);
164 }
165 result.append("\n");
Tom Murphyc23fcd02024-03-13 10:22:06 +0000166 result.append("vulkanEngineNames:");
167 for (const std::string& engineName : vulkanEngineNames) {
168 StringAppendF(&result, " %s,", engineName.c_str());
169 }
170 result.append("\n");
Yiwei Zhangf40fb102019-02-27 21:05:06 -0800171 return result;
172}
173
174} // namespace android