Re-land: "Trace Tests: Remove auto-generated code."

No significant changes in the re-land.

Bug: angleproject:5133
Change-Id: Ib5bb8fba3e9e2f1f648d5af251b7b2319c9f37dd
Reviewed-on: https://chromium-review.googlesource.com/c/angle/angle/+/3352432
Reviewed-by: Cody Northrop <cnorthrop@google.com>
Commit-Queue: Cody Northrop <cnorthrop@google.com>
This commit is contained in:
Jamie Madill 2021-09-07 11:47:23 -04:00 коммит произвёл Angle LUCI CQ
Родитель 542f7d8087
Коммит 4d893a9359
12 изменённых файлов: 76 добавлений и 4109 удалений

Просмотреть файл

@ -536,14 +536,12 @@ template("angle_trace_fixture") {
}
template("angle_trace") {
_trace_prefix = invoker.trace_prefix
angle_shared_library(target_name) {
testonly = true
# Similar to capture replay sample, use the file index for sources
sources = invoker.sources
# TODO(http://anglebug.com/5133): Revert back to non-autogen'ed data.
data = invoker.data
defines = [ "ANGLE_REPLAY_IMPLEMENTATION" ]
suppressed_configs += [ "$angle_root:constructor_and_destructor_warnings" ]
@ -574,8 +572,4 @@ template("angle_trace") {
output_name = invoker.output_name
}
}
angle_source_set(target_name + "_headers") {
sources = [ "${_trace_prefix}.h" ]
}
}

Просмотреть файл

@ -1,14 +1,8 @@
{
"src/tests/restricted_traces/.gitignore":
"f9c1b1aed4e36a56ba9827b0c240ec7d",
"371f3b4bd514af95e67a73f82116d4b6",
"src/tests/restricted_traces/gen_restricted_traces.py":
"241d7eb3d8322ff67f44b84f8a06a4cf",
"7780405f8e0d92fa87a772dd64c62efb",
"src/tests/restricted_traces/restricted_traces.json":
"a8796f0bd187a30986282ec23b929ec5",
"src/tests/restricted_traces/restricted_traces_autogen.cpp":
"9b82e13de93cb7a6992d60d93315d759",
"src/tests/restricted_traces/restricted_traces_autogen.gni":
"533142bd343d0a925932c3e9903ae06f",
"src/tests/restricted_traces/restricted_traces_autogen.h":
"77a97c4bb042e28be314bf45e915e013"
"a8796f0bd187a30986282ec23b929ec5"
}

Просмотреть файл

@ -39,14 +39,11 @@ if (angle_build_capture_replay_tests) {
_trace_json_path = "$_dir/$_trace.json"
# This extra empty step is needed to prevent GN from warning on reassignment.
_trace_data = {
}
_trace_data = []
_trace_data = read_file(_trace_json_path, "json")
_ctx = _trace_data.WindowSurfaceContextID
_target = "cr_trace_${_trace_counter}"
_trace_counter += 1
angle_trace(_target) {
trace_prefix = "$_dir/${_trace}_context${_ctx}"
sources = rebase_path(_trace_data.TraceFiles, ".", _dir)
data = []
fixture = ":angle_capture_replay_tests_fixture"

Просмотреть файл

@ -11,6 +11,7 @@
#include "common/PackedEnums.h"
#include "common/string_utils.h"
#include "common/system_utils.h"
#include "restricted_traces/restricted_traces_export.h"
#include "tests/perf_tests/ANGLEPerfTest.h"
#include "tests/perf_tests/ANGLEPerfTestArgs.h"
#include "tests/perf_tests/DrawCallPerfParams.h"
@ -19,8 +20,6 @@
#include "util/png_utils.h"
#include "util/test_utils.h"
#include "restricted_traces/restricted_traces_autogen.h"
#include <rapidjson/document.h>
#include <rapidjson/istreamwrapper.h>
@ -1936,15 +1935,17 @@ void RegisterTraceTests()
}
// Load JSON data.
std::stringstream tracesJsonStream;
tracesJsonStream << rootTracePath << GetPathSeparator() << "restricted_traces.json";
std::string tracesJsonPath = tracesJsonStream.str();
std::vector<std::string> traces;
if (!LoadTraceNamesFromJSON(tracesJsonPath, &traces))
{
ERR() << "Unable to load traces from JSON file: " << tracesJsonPath;
return;
std::stringstream tracesJsonStream;
tracesJsonStream << rootTracePath << GetPathSeparator() << "restricted_traces.json";
std::string tracesJsonPath = tracesJsonStream.str();
if (!LoadTraceNamesFromJSON(tracesJsonPath, &traces))
{
ERR() << "Unable to load traces from JSON file: " << tracesJsonPath;
return;
}
}
std::vector<TraceInfo> traceInfos;
@ -1958,9 +1959,8 @@ void RegisterTraceTests()
TraceInfo traceInfo = {};
if (!LoadTraceInfoFromJSON(trace, traceJsonPath, &traceInfo))
{
static_assert(sizeof(TraceInfo) == sizeof(trace_angle::TraceInfo), "Size mismatch");
trace_angle::TraceInfo autogenFormatInfo = trace_angle::GetTraceInfo(trace.c_str());
memcpy(&traceInfo, &autogenFormatInfo, sizeof(TraceInfo));
ERR() << "Unable to load traced data from JSON file: " << traceJsonPath;
return;
}
traceInfos.push_back(traceInfo);

114
src/tests/restricted_traces/.gitignore поставляемый
Просмотреть файл

@ -1,113 +1 @@
aliexpress/
among_us/
angry_birds_2_1500/
arena_of_valor/
asphalt_8/
asphalt_9/
avakin_life/
aztec_ruins/
badland/
beach_buggy_racing/
blockman_go/
brawl_stars/
bricks_breaker_quest/
bubble_shooter/
bus_simulator_indonesia/
call_break_offline_card_game/
candy_crush_500/
candy_crush_soda_saga/
car_parking_multiplayer/
clash_of_clans/
clash_royale/
cod_mobile/
coin_master/
command_and_conquer_rivals/
cookie_run_kingdom/
disney_tsum_tsum/
dota_underlords/
dr_driving/
dragon_ball_legends/
dragon_raja/
efootball_pes_2021/
egypt_1500/
eight_ball_pool/
extreme_car_driving_simulator/
fallout_shelter_online/
farm_heroes_saga/
fate_grand_order/
fifa_mobile/
final_fantasy/
free_fire/
gardenscapes/
genshin_impact/
google_maps/
happy_color/
hay_day/
hearthstone/
higgs_domino_island/
hill_climb_racing/
homescapes/
idle_heroes/
junes_journey/
kartrider_rush/
klondike_adventures/
league_of_legends_wild_rift/
lego_legacy/
lineage_m/
ludo_king/
magic_tiles_3/
manhattan_10/
manhattan_31/
mario_kart_tour/
marvel_contest_of_champions/
messenger_lite/
minecraft/
mini_world/
mobile_legends/
my_talking_tom2/
my_talking_tom_friends/
nba2k20_800/
nier_reincarnation/
one_punch_man/
plants_vs_zombies_2/
pokemon_go/
pokemon_unite/
professional_baseball_spirits/
pubg_mobile_battle_royale/
pubg_mobile_lite/
pubg_mobile_skydive/
ragnarok_m_eternal_love/
raid_shadow_legends/
real_commando_secret_mission/
real_cricket_20/
real_gangster_crime/
rise_of_kingdoms/
romancing_saga/
rope_hero_vice_town/
saint_seiya_awakening/
sakura_school_simulator/
scrabble_go/
shadow_fight_2/
slingshot_test1/
slingshot_test2/
sniper_3d/
sonic_the_hedgehog/
standoff_2/
subway_princess_runner/
subway_surfers/
summoners_war/
talking_tom_hero_dash/
temple_run_2/
temple_run_300/
toon_blast/
township/
trex_200/
whatsapp/
words_with_friends_2/
wordscapes/
world_cricket_championship_2/
world_of_kings/
world_of_tanks_blitz/
world_war_doh/
worms_zone_io/
zillow/
*/

Просмотреть файл

@ -8,7 +8,6 @@ import("../../../gni/angle.gni")
angle_shared_library("angle_restricted_trace_loader") {
sources = [
"restricted_traces_autogen.h",
"restricted_traces_export.h",
"trace_egl_loader_autogen.cpp",
"trace_egl_loader_autogen.h",
@ -28,45 +27,45 @@ angle_trace_fixture("angle_restricted_trace_fixture") {
public_configs = [ "$angle_root:no_gl_prototypes" ]
}
# Imports "angle_restricted_traces"
import("restricted_traces_autogen.gni")
_traces = []
_trace_headers = []
_trace_json = read_file("restricted_traces.json", "json")
_trace_targets = []
foreach(_trace_data, angle_restricted_traces) {
_trace = _trace_data[0]
_trace_ctx = _trace_data[1]
_target = "angle_restricted_trace_${_trace}"
foreach(_trace_and_version, _trace_json.traces) {
_trace_and_version_arr = []
_trace_and_version_arr = string_split(_trace_and_version)
_trace = _trace_and_version_arr[0]
_trace_json_path = "$_trace/$_trace.json"
_trace_data = []
_trace_data = read_file(_trace_json_path, "json")
_target = "angle_restricted_trace_$_trace"
angle_trace(_target) {
sources = _trace_data[2]
data = _trace_data[3]
trace_prefix = _trace_data[4]
sources = rebase_path(_trace_data.TraceFiles, ".", _trace)
data = [
"$_trace/$_trace.json",
"$_trace/$_trace.angledata.gz",
]
fixture = ":angle_restricted_trace_fixture"
}
_traces += [ ":${_target}" ]
_trace_headers += [ ":${_target}_headers" ]
_trace_targets += [ ":$_target" ]
}
angle_shared_library("angle_restricted_traces") {
testonly = true
sources = [
"restricted_traces_autogen.cpp",
"restricted_traces_autogen.h",
"restricted_traces_export.h",
]
sources = [ "restricted_traces_export.h" ]
data = [ "restricted_traces.json" ]
data_deps = _traces
data_deps = _trace_targets
defines = [ "ANGLE_TRACE_IMPLEMENTATION" ]
deps = [
"$angle_root:angle_common",
"$angle_root/util:angle_util",
] + _trace_headers
"$angle_root:angle_common",
"$angle_root/util:angle_util",
]
public_deps = [ ":angle_restricted_trace_loader" ]
}

Просмотреть файл

@ -15,134 +15,6 @@ import json
import os
import sys
GNI_TEMPLATE = """\
# GENERATED FILE - DO NOT EDIT.
# Generated by {script_name} using data from {data_source_name}
#
# Copyright 2020 The ANGLE Project Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
#
# A list of all restricted trace tests, paired with their context.
# Can be consumed by tests/BUILD.gn.
angle_restricted_traces = [
{test_list}
]
"""
HEADER_TEMPLATE = """\
// GENERATED FILE - DO NOT EDIT.
// Generated by {script_name} using data from {data_source_name}
//
// Copyright 2020 The ANGLE Project Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
//
// {filename}: Types and enumerations for trace tests.
#ifndef ANGLE_RESTRICTED_TRACES_AUTOGEN_H_
#define ANGLE_RESTRICTED_TRACES_AUTOGEN_H_
#include <cstdint>
#include <vector>
#include <KHR/khrplatform.h>
#include <EGL/egl.h>
#include "restricted_traces_export.h"
namespace trace_angle
{{
using GenericProc = void (*)();
using LoadProc = GenericProc(KHRONOS_APIENTRY *)(const char *);
ANGLE_TRACE_LOADER_EXPORT void LoadEGL(LoadProc loadProc);
ANGLE_TRACE_LOADER_EXPORT void LoadGLES(LoadProc loadProc);
static constexpr size_t kTraceInfoMaxNameLen = 128;
static constexpr uint32_t kDefaultReplayContextClientMajorVersion = 3;
static constexpr uint32_t kDefaultReplayContextClientMinorVersion = 1;
static constexpr uint32_t kDefaultReplayDrawSurfaceColorSpace = EGL_COLORSPACE_LINEAR;
struct TraceInfo
{{
char name[kTraceInfoMaxNameLen];
uint32_t contextClientMajorVersion;
uint32_t contextClientMinorVersion;
uint32_t frameEnd;
uint32_t frameStart;
uint32_t drawSurfaceWidth;
uint32_t drawSurfaceHeight;
uint32_t drawSurfaceColorSpace;
uint32_t displayPlatformType;
uint32_t displayDeviceType;
int configRedBits;
int configBlueBits;
int configGreenBits;
int configAlphaBits;
int configDepthBits;
int configStencilBits;
bool isBinaryDataCompressed;
bool areClientArraysEnabled;
bool isBindGeneratesResourcesEnabled;
bool isWebGLCompatibilityEnabled;
bool isRobustResourceInitEnabled;
}};
ANGLE_TRACE_EXPORT const TraceInfo &GetTraceInfo(const char *traceName);
}} // namespace trace_angle
#endif // ANGLE_RESTRICTED_TRACES_AUTOGEN_H_
"""
SOURCE_TEMPLATE = """\
// GENERATED FILE - DO NOT EDIT.
// Generated by {script_name} using data from {data_source_name}
//
// Copyright 2020 The ANGLE Project Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
//
// {filename}: Types and enumerations for trace tests.
#include "{filename}.h"
#include "common/PackedEnums.h"
#include "common/system_utils.h"
{trace_includes}
namespace trace_angle
{{
namespace
{{
constexpr size_t kNumTraces = {num_traces};
struct TracePair
{{
const char name[kTraceInfoMaxNameLen];
TraceInfo info;
}};
constexpr TracePair kTraceInfos[kNumTraces] = {{
{trace_infos}
}};
}}
const TraceInfo &GetTraceInfo(const char *traceName)
{{
// Could be improved using std::lower_bound.
for (const TracePair &tracePair : kTraceInfos)
{{
if (strncmp(tracePair.name, traceName, kTraceInfoMaxNameLen) == 0)
{{
return tracePair.info;
}}
}}
UNREACHABLE();
return kTraceInfos[0].info;
}}
}} // namespace trace_angle
"""
CIPD_TRACE_PREFIX = 'angle/traces'
EXPERIMENTAL_CIPD_PREFIX = 'experimental/google.com/%s/angle/traces'
DEPS_PATH = '../../../DEPS'
@ -172,176 +44,6 @@ def reject_duplicate_keys(pairs):
return found_keys
def load_json_metadata(trace):
json_file_name = '%s/%s.json' % (trace, trace)
with open(json_file_name) as f:
return json.loads(f.read())
# TODO(http://anglebug.com/5878): Revert back to non-autogen'ed file names for the angledata.gz.
def get_angledata_filename(trace):
angledata_files = glob.glob('%s/%s*angledata.gz' % (trace, trace))
assert len(angledata_files) == 1, "Trace '%s' has %d angledata.gz files" % (
trace, len(angledata_files))
return angledata_files[0].replace('\\', '/')
# TODO(jmadill): Remove the GNI generation. http://anglebug.com/5133
def gen_gni(traces, gni_file, format_args):
test_list = []
for trace in traces:
context = get_context(trace)
angledata_file = get_angledata_filename(trace)
txt_file = '%s/%s_capture_context%s_files.txt' % (trace, trace, context)
if os.path.exists(txt_file):
with open(txt_file) as f:
files = f.readlines()
f.close()
source_files = ['"%s/%s"' % (trace, file.strip()) for file in files]
else:
json_data = load_json_metadata(trace)
files = json_data["TraceFiles"]
source_files = ['"%s/%s"' % (trace, file.strip()) for file in files]
data_files = ['"%s"' % angledata_file]
json_file_name = '%s/%s.json' % (trace, trace)
if os.path.exists(json_file_name):
data_files.append('"%s"' % json_file_name)
for prefix_expr in ['%s/%s_capture_context%s', '%s/%s_context%s']:
prefix = prefix_expr % (trace, trace, context)
prefix_cpp = '%s.cpp' % prefix
if os.path.exists(prefix_cpp):
break
assert os.path.exists(prefix_cpp), '%s does not exist' % prefix_cpp
test_list += [
'["%s", %s, [%s], [%s], "%s"]' %
(trace, context, ','.join(source_files), ','.join(data_files), prefix)
]
format_args['test_list'] = ',\n'.join(test_list)
gni_data = GNI_TEMPLATE.format(**format_args)
with open(gni_file, "w") as out_file:
out_file.write(gni_data)
return True
def contains_string(trace, string):
"""Determines if the trace contains a string"""
for file in os.listdir(trace):
if fnmatch.fnmatch(file, '*.h'):
with open(os.path.join(trace, file)) as f:
if string in f.read():
return True
return False
def contains_context_version(trace):
"""Determines if the trace contains the major/minor context version"""
return contains_string(trace, 'kReplayContextClientMajorVersion')
def contains_colorspace(trace):
"""Determines if the trace contains an EGL surface color space"""
return contains_string(trace, 'kReplayDrawSurfaceColorSpace')
# TODO(jmadill): Remove after retrace. http://anglebug.com/5133
def json_metadata_exists(trace):
return os.path.isfile('%s/%s.json' % (trace, trace))
def get_trace_info(trace):
# Skip getting trace info if we're using JSON metadata.
# TODO: Remove generated code. http://anglebug.com/5133
if json_metadata_exists(trace):
return ''
# Some traces don't contain major/minor version, so use defaults
info = [f'"{trace}"']
if contains_context_version(trace):
info += [
f'{trace}::kReplayContextClientMajorVersion',
f'{trace}::kReplayContextClientMinorVersion'
]
else:
info += [
'kDefaultReplayContextClientMajorVersion', 'kDefaultReplayContextClientMinorVersion'
]
info += [
f'{trace}::kReplayFrameStart', f'{trace}::kReplayFrameEnd',
f'{trace}::kReplayDrawSurfaceWidth', f'{trace}::kReplayDrawSurfaceHeight'
]
if contains_colorspace(trace):
info += [f'{trace}::kReplayDrawSurfaceColorSpace']
else:
info += ['kDefaultReplayDrawSurfaceColorSpace']
# Add placeholder fields to fix an MSVC warning.
info += ['0'] * 8
info += ['false'] * 5
return ", ".join(info)
def get_context(trace):
"""Returns the trace context number."""
# TODO(jmadill): Remove the txt scan once migrated. http://anglebug.com/5133
# Load up the only header present for each trace
for file in os.listdir(trace):
if fnmatch.fnmatch(file, '*.txt'):
# Strip the extension to isolate the context by scanning
# for numbers leading up to the last one, i.e.:
# app_capture_context123_files.txt
# ^^
# start---||---end
start = len(file) - 11
end = start + 1
while file[start - 1].isdigit():
start -= 1
context = file[start:end]
assert context.isnumeric(), 'Trace context number is not numeric: %s' % context
return context
expr = re.compile(r'.*_context(\d+).cpp')
for file in os.listdir(trace):
m = expr.match(file)
if m:
context = m.group(1)
assert context.isnumeric(), 'Trace context number is not numeric: %s' % context
return context
assert False, 'Failed to find context number for %s' % trace
def get_header_name(trace):
return '%s/%s_capture_context%s.h' % (trace, trace, get_context(trace))
def gen_header(header_file, format_args):
header_data = HEADER_TEMPLATE.format(**format_args)
with open(header_file, "w") as out_file:
out_file.write(header_data)
return True
def gen_source(source_file, format_args):
source_data = SOURCE_TEMPLATE.format(**format_args)
with open(source_file, "w") as out_file:
out_file.write(source_data)
return True
def gen_git_ignore(traces):
ignores = ['%s/' % trace for trace in traces]
with open('.gitignore', 'w') as out_file:
out_file.write('\n'.join(sorted(ignores)))
return True
def read_json(json_file):
with open(json_file) as map_file:
return json.loads(map_file.read(), object_pairs_hook=reject_duplicate_keys)
@ -386,9 +88,6 @@ def update_deps(trace_pairs):
def main():
json_file = 'restricted_traces.json'
gni_file = 'restricted_traces_autogen.gni'
header_file = 'restricted_traces_autogen.h'
source_file = 'restricted_traces_autogen.cpp'
json_data = read_json(json_file)
if 'traces' not in json_data:
@ -402,8 +101,9 @@ def main():
inputs = [json_file]
# Note: we do not include DEPS in the list of outputs to simplify the integration.
# Otherwise we'd continually need to regenerate on any roll.
outputs = [gni_file, header_file, source_file, '.gitignore']
# Otherwise we'd continually need to regenerate on any roll. We include .gitignore
# in the outputs so we have a placeholder value.
outputs = ['.gitignore']
if sys.argv[1] == 'inputs':
print(','.join(inputs))
@ -414,36 +114,6 @@ def main():
return 1
return 0
format_args = {
'script_name': os.path.basename(__file__),
'data_source_name': json_file,
}
if not gen_gni(traces, gni_file, format_args):
print('.gni file generation failed.')
return 1
trace_infos = ['{"%s", {%s}}' % (trace, get_trace_info(trace)) for trace in traces]
no_json_traces = filter(lambda trace: not json_metadata_exists(trace), traces)
includes = ['#include "%s"' % get_header_name(trace) for trace in no_json_traces]
format_args['filename'] = 'restricted_traces_autogen'
format_args['num_traces'] = len(trace_infos)
format_args['trace_includes'] = '\n'.join(includes)
format_args['trace_infos'] = ',\n'.join(trace_infos)
if not gen_header(header_file, format_args):
print('.h file generation failed.')
return 1
if not gen_source(source_file, format_args):
print('.cpp file generation failed.')
return 1
if not gen_git_ignore(traces):
print('.gitignore file generation failed')
return 1
if not update_deps(trace_pairs):
print('DEPS file update failed')
return 1

Просмотреть файл

@ -1,153 +0,0 @@
// GENERATED FILE - DO NOT EDIT.
// Generated by gen_restricted_traces.py using data from restricted_traces.json
//
// Copyright 2020 The ANGLE Project Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
//
// restricted_traces_autogen: Types and enumerations for trace tests.
#include "restricted_traces_autogen.h"
#include "common/PackedEnums.h"
#include "common/system_utils.h"
namespace trace_angle
{
namespace
{
constexpr size_t kNumTraces = 113;
struct TracePair
{
const char name[kTraceInfoMaxNameLen];
TraceInfo info;
};
constexpr TracePair kTraceInfos[kNumTraces] = {{"aliexpress", {}},
{"among_us", {}},
{"angry_birds_2_1500", {}},
{"arena_of_valor", {}},
{"asphalt_8", {}},
{"asphalt_9", {}},
{"avakin_life", {}},
{"aztec_ruins", {}},
{"badland", {}},
{"beach_buggy_racing", {}},
{"blockman_go", {}},
{"brawl_stars", {}},
{"bricks_breaker_quest", {}},
{"bubble_shooter", {}},
{"bus_simulator_indonesia", {}},
{"call_break_offline_card_game", {}},
{"candy_crush_500", {}},
{"candy_crush_soda_saga", {}},
{"car_parking_multiplayer", {}},
{"clash_of_clans", {}},
{"clash_royale", {}},
{"cod_mobile", {}},
{"coin_master", {}},
{"command_and_conquer_rivals", {}},
{"cookie_run_kingdom", {}},
{"disney_tsum_tsum", {}},
{"dota_underlords", {}},
{"dr_driving", {}},
{"dragon_ball_legends", {}},
{"dragon_raja", {}},
{"efootball_pes_2021", {}},
{"egypt_1500", {}},
{"eight_ball_pool", {}},
{"extreme_car_driving_simulator", {}},
{"fallout_shelter_online", {}},
{"farm_heroes_saga", {}},
{"fate_grand_order", {}},
{"fifa_mobile", {}},
{"final_fantasy", {}},
{"free_fire", {}},
{"gardenscapes", {}},
{"genshin_impact", {}},
{"google_maps", {}},
{"happy_color", {}},
{"hay_day", {}},
{"hearthstone", {}},
{"higgs_domino_island", {}},
{"hill_climb_racing", {}},
{"homescapes", {}},
{"idle_heroes", {}},
{"junes_journey", {}},
{"kartrider_rush", {}},
{"klondike_adventures", {}},
{"league_of_legends_wild_rift", {}},
{"lego_legacy", {}},
{"lineage_m", {}},
{"ludo_king", {}},
{"magic_tiles_3", {}},
{"manhattan_10", {}},
{"manhattan_31", {}},
{"mario_kart_tour", {}},
{"marvel_contest_of_champions", {}},
{"messenger_lite", {}},
{"minecraft", {}},
{"mini_world", {}},
{"mobile_legends", {}},
{"my_talking_tom2", {}},
{"my_talking_tom_friends", {}},
{"nba2k20_800", {}},
{"nier_reincarnation", {}},
{"one_punch_man", {}},
{"plants_vs_zombies_2", {}},
{"pokemon_go", {}},
{"pokemon_unite", {}},
{"professional_baseball_spirits", {}},
{"pubg_mobile_battle_royale", {}},
{"pubg_mobile_lite", {}},
{"pubg_mobile_skydive", {}},
{"ragnarok_m_eternal_love", {}},
{"raid_shadow_legends", {}},
{"real_commando_secret_mission", {}},
{"real_cricket_20", {}},
{"real_gangster_crime", {}},
{"rise_of_kingdoms", {}},
{"romancing_saga", {}},
{"rope_hero_vice_town", {}},
{"saint_seiya_awakening", {}},
{"sakura_school_simulator", {}},
{"scrabble_go", {}},
{"shadow_fight_2", {}},
{"slingshot_test1", {}},
{"slingshot_test2", {}},
{"sniper_3d", {}},
{"sonic_the_hedgehog", {}},
{"standoff_2", {}},
{"subway_princess_runner", {}},
{"subway_surfers", {}},
{"summoners_war", {}},
{"talking_tom_hero_dash", {}},
{"temple_run_2", {}},
{"temple_run_300", {}},
{"toon_blast", {}},
{"township", {}},
{"trex_200", {}},
{"whatsapp", {}},
{"words_with_friends_2", {}},
{"wordscapes", {}},
{"world_cricket_championship_2", {}},
{"world_of_kings", {}},
{"world_of_tanks_blitz", {}},
{"world_war_doh", {}},
{"worms_zone_io", {}},
{"zillow", {}}};
} // namespace
const TraceInfo &GetTraceInfo(const char *traceName)
{
// Could be improved using std::lower_bound.
for (const TracePair &tracePair : kTraceInfos)
{
if (strncmp(tracePair.name, traceName, kTraceInfoMaxNameLen) == 0)
{
return tracePair.info;
}
}
UNREACHABLE();
return kTraceInfos[0].info;
}
} // namespace trace_angle

Разница между файлами не показана из-за своего большого размера Загрузить разницу

Просмотреть файл

@ -1,61 +0,0 @@
// GENERATED FILE - DO NOT EDIT.
// Generated by gen_restricted_traces.py using data from restricted_traces.json
//
// Copyright 2020 The ANGLE Project Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
//
// restricted_traces_autogen: Types and enumerations for trace tests.
#ifndef ANGLE_RESTRICTED_TRACES_AUTOGEN_H_
#define ANGLE_RESTRICTED_TRACES_AUTOGEN_H_
#include <EGL/egl.h>
#include <KHR/khrplatform.h>
#include <cstdint>
#include <vector>
#include "restricted_traces_export.h"
namespace trace_angle
{
using GenericProc = void (*)();
using LoadProc = GenericProc(KHRONOS_APIENTRY *)(const char *);
ANGLE_TRACE_LOADER_EXPORT void LoadEGL(LoadProc loadProc);
ANGLE_TRACE_LOADER_EXPORT void LoadGLES(LoadProc loadProc);
static constexpr size_t kTraceInfoMaxNameLen = 128;
static constexpr uint32_t kDefaultReplayContextClientMajorVersion = 3;
static constexpr uint32_t kDefaultReplayContextClientMinorVersion = 1;
static constexpr uint32_t kDefaultReplayDrawSurfaceColorSpace = EGL_COLORSPACE_LINEAR;
struct TraceInfo
{
char name[kTraceInfoMaxNameLen];
uint32_t contextClientMajorVersion;
uint32_t contextClientMinorVersion;
uint32_t frameEnd;
uint32_t frameStart;
uint32_t drawSurfaceWidth;
uint32_t drawSurfaceHeight;
uint32_t drawSurfaceColorSpace;
uint32_t displayPlatformType;
uint32_t displayDeviceType;
int configRedBits;
int configBlueBits;
int configGreenBits;
int configAlphaBits;
int configDepthBits;
int configStencilBits;
bool isBinaryDataCompressed;
bool areClientArraysEnabled;
bool isBindGeneratesResourcesEnabled;
bool isWebGLCompatibilityEnabled;
bool isRobustResourceInitEnabled;
};
ANGLE_TRACE_EXPORT const TraceInfo &GetTraceInfo(const char *traceName);
} // namespace trace_angle
#endif // ANGLE_RESTRICTED_TRACES_AUTOGEN_H_

Просмотреть файл

@ -37,4 +37,12 @@
# endif
#endif // !defined(ANGLE_TRACE_LOADER_EXPORT)
namespace trace_angle
{
using GenericProc = void (*)();
using LoadProc = GenericProc(KHRONOS_APIENTRY *)(const char *);
ANGLE_TRACE_LOADER_EXPORT void LoadEGL(LoadProc loadProc);
ANGLE_TRACE_LOADER_EXPORT void LoadGLES(LoadProc loadProc);
} // namespace trace_angle
#endif // ANGLE_RESTRICTED_TRACES_EXPORT_H_

Просмотреть файл

@ -20,29 +20,36 @@ import stat
import subprocess
import sys
from gen_restricted_traces import get_context as get_context
from gen_restricted_traces import read_json as read_json
DEFAULT_TEST_SUITE = 'angle_perftests'
DEFAULT_TEST_JSON = 'restricted_traces.json'
DEFAULT_LOG_LEVEL = 'info'
DEFAULT_BACKUP_FOLDER = 'retrace-backups'
# We preserve select metadata in the trace header that can't be re-captured properly.
# Currently this is just the set of default framebuffer surface config bits.
METADATA_KEYWORDS = ['kDefaultFramebuffer']
EXIT_SUCCESS = 0
EXIT_FAILURE = 1
def load_trace_json(trace):
json_file_name = '%s/%s.json' % (trace, trace)
return read_json(json_file_name)
def get_context(trace, trace_path):
"""Returns the trace context number."""
json_data = load_trace_json(trace)
return str(json_data['WindowSurfaceContextID'])
def get_script_dir():
return os.path.dirname(sys.argv[0])
# TODO(jmadill): Remove after retrace. http://anglebug.com/5133
def json_metadata_exists(trace):
json_file_name = os.path.join(get_script_dir(), '%s/%s.json') % (trace, trace)
return os.path.isfile(json_file_name)
def context_header(trace, trace_path):
context_id = get_context(trace, trace_path)
header = '%s_context%s.h' % (trace, context_id)
return os.path.join(trace_path, header)
def load_json_metadata(trace):
@ -55,41 +62,6 @@ def src_trace_path(trace):
return os.path.join(get_script_dir(), trace)
def context_header(trace, trace_path):
context_id = get_context(trace_path)
# TODO(jmadill): Remove after retrace. http://anglebug.com/5133
for try_path_expr in ['%s_capture_context%s.h', '%s_context%s.h']:
header = try_path_expr % (trace, context_id)
try_path = os.path.join(trace_path, header)
if os.path.isfile(try_path):
return try_path
logging.fatal('Could not find context header for %s' % trace)
return None
def get_num_frames(trace):
if json_metadata_exists(trace):
json_metadata = load_json_metadata(trace)
if 'FrameEnd' in json_metadata:
return int(json_metadata['FrameEnd'])
trace_path = src_trace_path(trace)
lo = 99999999
hi = 0
for file in os.listdir(trace_path):
match = re.match(r'.+_context\d_frame(\d+)\.cpp', file)
if match:
frame = int(match.group(1))
if frame < lo:
lo = frame
if frame > hi:
hi = frame
return hi - lo + 1
def get_trace_metadata(trace):
trace_path = src_trace_path(trace)
header_file = context_header(trace, trace_path)
@ -124,6 +96,11 @@ def replace_metadata(header_file, metadata):
f.writelines(lines)
def get_num_frames(json_data):
metadata = json_data['TraceMetadata']
return metadata['FrameEnd'] - metadata['FrameStart'] + 1
def path_contains_header(path):
for file in os.listdir(path):
if fnmatch.fnmatch(file, '*.h'):
@ -157,14 +134,6 @@ def backup_traces(args, traces):
copy_trace_folder(trace_path, trace_backup_path)
# TODO(jmadill): Remove this once migrated. http://anglebug.com/5133
def run_code_generation():
python_binary = 'py.exe' if os.name == 'nt' else 'python3'
angle_dir = os.path.join(get_script_dir(), '..', '..', '..')
gen_path = os.path.join(angle_dir, 'scripts', 'run_code_generation.py')
subprocess.check_call([python_binary, gen_path])
def restore_traces(args, traces):
for trace in fnmatch.filter(traces, args.traces):
trace_path = src_trace_path(trace)
@ -173,13 +142,6 @@ def restore_traces(args, traces):
logging.error('Trace folder not found at %s' % trace_backup_path)
else:
copy_trace_folder(trace_backup_path, trace_path)
# TODO(jmadill): Remove this once migrated. http://anglebug.com/5133
angle_dir = os.path.join(get_script_dir(), '..', '..', '..')
json_path = os.path.join(angle_dir, 'scripts', 'code_generation_hashes',
'restricted_traces.json')
if os.path.exists(json_path):
os.unlink(json_path)
run_code_generation()
def run_autoninja(args):
@ -232,16 +194,12 @@ def upgrade_traces(args, traces):
logging.info('Skipping "%s" because the out folder already exists' % trace)
continue
num_frames = get_num_frames(trace)
metadata = get_trace_metadata(trace)
json_data = load_trace_json(trace)
num_frames = get_num_frames(json_data)
metadata = json_data['TraceMetadata']
logging.debug('Read metadata: %s' % str(metadata))
if json_metadata_exists(trace):
json_metadata = load_json_metadata(trace)
else:
json_metadata = {}
max_steps = min(args.limit, num_frames) if args.limit else num_frames
# We start tracing from frame 2. --retrace-mode issues a Swap() after Setup() so we can
@ -276,8 +234,6 @@ def upgrade_traces(args, traces):
logging.error('There was a problem tracing "%s", could not find header file: %s' %
(trace, header_file))
failures += [trace]
else:
replace_metadata(header_file, metadata)
except:
logging.exception('There was an exception running "%s":' % trace)
failures += [trace]
@ -302,7 +258,8 @@ def validate_traces(args, traces):
failures = []
for trace in fnmatch.filter(traces, args.traces):
num_frames = get_num_frames(trace)
json_data = load_trace_json(trace)
num_frames = get_num_frames(json_data)
max_steps = min(args.limit, num_frames) if args.limit else num_frames
try:
run_test_suite(args, trace, max_steps, additional_args, additional_env)