/* * 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. */ #ifndef __VTS_DRIVER_PROFILING_INTERFACE_H_ #define __VTS_DRIVER_PROFILING_INTERFACE_H_ #include <android-base/macros.h> #include <google/protobuf/io/zero_copy_stream_impl.h> #include <hidl/HidlSupport.h> #include <utils/Condition.h> #include <fstream> #include "test/vts/proto/ComponentSpecificationMessage.pb.h" using namespace std; namespace android { namespace vts { // Library class to trace, record and profile a HIDL HAL implementation. class VtsProfilingInterface { public: explicit VtsProfilingInterface(const string& trace_file_path); virtual ~VtsProfilingInterface(); // Get and create the VtsProfilingInterface singleton. static VtsProfilingInterface& getInstance(const string& trace_file_path); // returns true if the given message is added to the tracing queue. void AddTraceEvent( android::hardware::details::HidlInstrumentor::InstrumentationEvent event, const char* package, const char* version, const char* interface, const FunctionSpecificationMessage& message); private: // Internal method to get the corresponding trace file descriptor for a HAL // with given package and version. int GetTraceFile(const string& package, const string& version); // Internal method to create a trace file based on the trace_file_path_prefix_ // the given package and version, the device info and the current time. int CreateTraceFile(const string& package, const string& version); // Get the current time in nano seconds. int64_t NanoTime(); // Prefix of all trace files. string trace_file_path_prefix_; // Prefix of the trace file. // map between the HAL to the trace file description. map<string, int> trace_map_; Mutex mutex_; // Mutex used to synchronize the writing to the trace file. DISALLOW_COPY_AND_ASSIGN(VtsProfilingInterface); }; } // namespace vts } // namespace android #endif // __VTS_DRIVER_PROFILING_INTERFACE_H_