blob: 81b70c092f414d3b9e78a0ce1f113a1bfd28151e [file] [log] [blame]
/*
* Copyright 2016 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#define ATRACE_TAG ATRACE_TAG_GRAPHICS
#include "GpuService.h"
#include <binder/IResultReceiver.h>
#include <binder/Parcel.h>
#include <utils/String8.h>
#include <utils/Trace.h>
#include <vkjson.h>
namespace android {
namespace {
status_t cmd_help(int out);
status_t cmd_vkjson(int out, int err);
}
const char* const GpuService::SERVICE_NAME = "gpu";
GpuService::GpuService() = default;
void GpuService::setGpuStats(const std::string& driverPackageName,
const std::string& driverVersionName, uint64_t driverVersionCode,
const std::string& driverBuildDate, const std::string& appPackageName,
GraphicsEnv::Driver driver, bool isDriverLoaded,
int64_t driverLoadingTime) {
ATRACE_CALL();
std::lock_guard<std::mutex> lock(mStateLock);
ALOGV("Received:\n"
"\tdriverPackageName[%s]\n"
"\tdriverVersionName[%s]\n"
"\tdriverVersionCode[%llu]\n"
"\tdriverBuildDate[%s]\n"
"\tappPackageName[%s]\n"
"\tdriver[%d]\n"
"\tisDriverLoaded[%d]\n"
"\tdriverLoadingTime[%lld]",
driverPackageName.c_str(), driverVersionName.c_str(),
(unsigned long long)driverVersionCode, driverBuildDate.c_str(), appPackageName.c_str(),
static_cast<int32_t>(driver), isDriverLoaded, (long long)driverLoadingTime);
}
status_t GpuService::shellCommand(int /*in*/, int out, int err, std::vector<String16>& args) {
ATRACE_CALL();
ALOGV("shellCommand");
for (size_t i = 0, n = args.size(); i < n; i++)
ALOGV(" arg[%zu]: '%s'", i, String8(args[i]).string());
if (args.size() >= 1) {
if (args[0] == String16("vkjson"))
return cmd_vkjson(out, err);
if (args[0] == String16("help"))
return cmd_help(out);
}
// no command, or unrecognized command
cmd_help(err);
return BAD_VALUE;
}
namespace {
status_t cmd_help(int out) {
FILE* outs = fdopen(out, "w");
if (!outs) {
ALOGE("vkjson: failed to create out stream: %s (%d)", strerror(errno),
errno);
return BAD_VALUE;
}
fprintf(outs,
"GPU Service commands:\n"
" vkjson dump Vulkan properties as JSON\n");
fclose(outs);
return NO_ERROR;
}
void vkjsonPrint(FILE* out) {
std::string json = VkJsonInstanceToJson(VkJsonGetInstance());
fwrite(json.data(), 1, json.size(), out);
fputc('\n', out);
}
status_t cmd_vkjson(int out, int /*err*/) {
FILE* outs = fdopen(out, "w");
if (!outs) {
int errnum = errno;
ALOGE("vkjson: failed to create output stream: %s", strerror(errnum));
return -errnum;
}
vkjsonPrint(outs);
fclose(outs);
return NO_ERROR;
}
} // anonymous namespace
} // namespace android