/*
* Copyright 2018 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.
*/
#pragma once
#include "tuningfork/tuningfork.h"
#include "tuningfork/tuningfork_extra.h"
#ifdef PROTOBUF_NANO
#include "pb_encode.h"
#include "pb_decode.h"
#endif
#include <stdint.h>
#include <string>
#include <chrono>
#include <vector>
#include <jni.h>
class AAsset;
namespace tuningfork {
typedef std::vector<uint8_t> ProtobufSerialization;
// The instrumentation key identifies a tick point within a frame or a trace segment
typedef uint16_t InstrumentationKey;
typedef uint64_t TraceHandle;
typedef std::chrono::steady_clock::time_point TimePoint;
typedef std::chrono::steady_clock::duration Duration;
struct Settings {
struct AggregationStrategy {
enum Submission {
TICK_BASED,
TIME_BASED
};
Submission method;
int32_t intervalms_or_count;
int32_t max_instrumentation_keys;
std::vector<int> annotation_enum_size;
};
struct Histogram {
int32_t instrument_key;
float bucket_min;
float bucket_max;
int32_t n_buckets;
};
AggregationStrategy aggregation_strategy;
std::vector<Histogram> histograms;
};
// Extra information that is uploaded with the ClearCut proto.
struct ExtraUploadInfo {
std::string experiment_id;
std::string session_id;
uint64_t total_memory_bytes;
uint32_t gl_es_version;
std::string build_fingerprint;
std::string build_version_sdk;
std::vector<uint64_t> cpu_max_freq_hz;
std::string apk_package_name;
int apk_version_code;
int tuningfork_version;
};
class Backend {
public:
virtual ~Backend() {};
virtual bool Process(const ProtobufSerialization &tuningfork_log_event) = 0;
};
class ParamsLoader {
public:
virtual ~ParamsLoader() {};
virtual bool GetFidelityParams(ProtobufSerialization &fidelity_params, size_t timeout_ms) {
return false;
}
};
class ProtoPrint {
public:
virtual ~ProtoPrint() {};
virtual void Print(const ProtobufSerialization &tuningfork_log_event);
};
class DebugBackend : public Backend {
public:
~DebugBackend() override;
bool Process(const ProtobufSerialization &tuningfork_log_event) override;
};
// You can provide your own time source rather than steady_clock by inheriting this and passing
// it to init.
class ITimeProvider {
public:
virtual std::chrono::steady_clock::time_point NowNs() = 0;
};
// init must be called before any other functions
// If no backend is passed, a debug version is used which returns empty fidelity params
// and outputs histograms in protobuf text format to logcat.
// If no timeProvider is passed, std::chrono::steady_clock is used.
void Init(const ProtobufSerialization &settings, const ExtraUploadInfo& extra_info,
Backend *backend = 0, ParamsLoader *loader = 0, ITimeProvider *time_provider = 0);
// Init must be called before any other functions
void Init(const ProtobufSerialization &settings, JNIEnv* env, jobject activity);
// Blocking call to get fidelity parameters from the server.
// Returns true if parameters could be downloaded within the timeout, false otherwise.
// Note that once fidelity parameters are downloaded, any timing information is recorded
// as being associated with those parameters.
// If you subsequently call GetFidelityParameters, any data that is already collected will be
// submitted to the backend.
bool GetFidelityParameters(const ProtobufSerialization& defaultParams,
ProtobufSerialization ¶ms, size_t timeout_ms);
// Protobuf serialization of the current annotation
// Returns the internal annotation id if it was set or -1 if not
uint64_t SetCurrentAnnotation(const ProtobufSerialization &annotation);
// Record a frame tick that will be associated with the instrumentation key and the current
// annotation
void FrameTick(InstrumentationKey id);
// Record a frame tick using an external time, rather than system time
void FrameDeltaTimeNanos(InstrumentationKey id, Duration dt);
// Start a trace segment
TraceHandle StartTrace(InstrumentationKey key);
// Record a trace with the key and annotation set using startTrace
void EndTrace(TraceHandle h);
void SetUploadCallback(ProtoCallback cbk);
} // namespace tuningfork