blob: 858739c9dd609c457ffc85958d97078ab4b66087 [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;
Yiwei Zhangf40fb102019-02-27 21:05:06 -080092 return OK;
93}
94
95status_t GpuStatsAppInfo::readFromParcel(const Parcel* parcel) {
96 status_t status;
97 if ((status = parcel->readUtf8FromUtf16(&appPackageName)) != OK) return status;
98 if ((status = parcel->readUint64(&driverVersionCode)) != OK) return status;
99 if ((status = parcel->readInt64Vector(&glDriverLoadingTime)) != OK) return status;
100 if ((status = parcel->readInt64Vector(&vkDriverLoadingTime)) != OK) return status;
Yiwei Zhang8e7c4b62019-05-08 15:57:59 -0700101 if ((status = parcel->readInt64Vector(&angleDriverLoadingTime)) != OK) return status;
Yiwei Zhang8c5e3bd2019-05-09 14:34:19 -0700102 if ((status = parcel->readBool(&cpuVulkanInUse)) != OK) return status;
Yiwei Zhang69395cd2019-07-03 16:55:39 -0700103 if ((status = parcel->readBool(&falsePrerotation)) != OK) return status;
Yiwei Zhang011538f2019-12-20 14:37:21 -0800104 if ((status = parcel->readBool(&gles1InUse)) != OK) return status;
Tim Van Pattena9ad69b2021-11-24 19:29:38 -0700105 if ((status = parcel->readBool(&angleInUse)) != OK) return status;
Yiwei Zhangf40fb102019-02-27 21:05:06 -0800106 return OK;
107}
108
109std::string GpuStatsAppInfo::toString() const {
110 std::string result;
111 StringAppendF(&result, "appPackageName = %s\n", appPackageName.c_str());
112 StringAppendF(&result, "driverVersionCode = %" PRIu64 "\n", driverVersionCode);
Yiwei Zhang8c5e3bd2019-05-09 14:34:19 -0700113 StringAppendF(&result, "cpuVulkanInUse = %d\n", cpuVulkanInUse);
Yiwei Zhang69395cd2019-07-03 16:55:39 -0700114 StringAppendF(&result, "falsePrerotation = %d\n", falsePrerotation);
Yiwei Zhang011538f2019-12-20 14:37:21 -0800115 StringAppendF(&result, "gles1InUse = %d\n", gles1InUse);
Tim Van Pattena9ad69b2021-11-24 19:29:38 -0700116 StringAppendF(&result, "angleInUse = %d\n", angleInUse);
Yiwei Zhangf40fb102019-02-27 21:05:06 -0800117 result.append("glDriverLoadingTime:");
118 for (int32_t loadingTime : glDriverLoadingTime) {
119 StringAppendF(&result, " %d", loadingTime);
120 }
121 result.append("\n");
Yiwei Zhang8e7c4b62019-05-08 15:57:59 -0700122 result.append("angleDriverLoadingTime:");
123 for (int32_t loadingTime : angleDriverLoadingTime) {
124 StringAppendF(&result, " %d", loadingTime);
125 }
126 result.append("\n");
Yiwei Zhangf40fb102019-02-27 21:05:06 -0800127 result.append("vkDriverLoadingTime:");
128 for (int32_t loadingTime : vkDriverLoadingTime) {
129 StringAppendF(&result, " %d", loadingTime);
130 }
131 result.append("\n");
132 return result;
133}
134
135} // namespace android