2019-03-25 15:54:59 +00:00
|
|
|
/*
|
|
|
|
* Copyright 2014 Google Inc.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
|
|
|
*/
|
|
|
|
|
2019-04-23 17:05:21 +00:00
|
|
|
#include "include/core/SkExecutor.h"
|
|
|
|
#include "include/gpu/GrContextOptions.h"
|
|
|
|
#include "tools/flags/CommonFlags.h"
|
2019-03-25 15:54:59 +00:00
|
|
|
|
|
|
|
DEFINE_int(gpuThreads,
|
|
|
|
2,
|
|
|
|
"Create this many extra threads to assist with GPU work, "
|
|
|
|
"including software path rendering. Defaults to two.");
|
|
|
|
|
|
|
|
static DEFINE_bool(cachePathMasks, true,
|
|
|
|
"Allows path mask textures to be cached in GPU configs.");
|
2020-09-23 17:55:27 +00:00
|
|
|
static DEFINE_bool(allPathsVolatile, false,
|
|
|
|
"Causes all GPU paths to be processed as if 'setIsVolatile' had been called.");
|
2019-03-25 15:54:59 +00:00
|
|
|
|
2020-12-16 02:55:10 +00:00
|
|
|
static DEFINE_bool(hwtess, false, "Enables support for tessellation shaders (if hw allows.).");
|
2019-03-25 15:54:59 +00:00
|
|
|
|
2020-09-17 18:16:54 +00:00
|
|
|
static DEFINE_int(maxTessellationSegments, 0,
|
|
|
|
"Overrides the max number of tessellation segments supported by the caps.");
|
|
|
|
|
2021-05-25 16:11:46 +00:00
|
|
|
static DEFINE_bool(alwaysHwTess, false,
|
|
|
|
"Always try to use hardware tessellation, regardless of how small a path may be.");
|
|
|
|
|
2019-03-25 15:54:59 +00:00
|
|
|
static DEFINE_string(pr, "",
|
|
|
|
"Set of enabled gpu path renderers. Defined as a list of: "
|
2021-06-19 17:50:17 +00:00
|
|
|
"[~]none [~]dashline [~]aahairline [~]aaconvex [~]aalinearizing [~]small [~]tri "
|
2021-07-23 21:33:09 +00:00
|
|
|
"[~]atlas [~]tess [~]all");
|
2019-03-25 15:54:59 +00:00
|
|
|
|
2021-06-24 00:47:09 +00:00
|
|
|
static DEFINE_int(internalSamples, -1,
|
|
|
|
"Number of samples for internal draws that use MSAA, or default value if negative.");
|
|
|
|
|
|
|
|
static DEFINE_int(maxAtlasSize, -1,
|
|
|
|
"Maximum width and height of internal texture atlases, or default value if negative.");
|
2019-12-27 20:47:25 +00:00
|
|
|
|
2019-03-25 15:54:59 +00:00
|
|
|
static DEFINE_bool(disableDriverCorrectnessWorkarounds, false,
|
|
|
|
"Disables all GPU driver correctness workarounds");
|
|
|
|
|
2021-04-22 15:08:12 +00:00
|
|
|
static DEFINE_bool(dontReduceOpsTaskSplitting, false,
|
|
|
|
"Don't reorder tasks to reduce render passes");
|
2019-03-25 15:54:59 +00:00
|
|
|
|
2021-07-09 13:10:02 +00:00
|
|
|
static DEFINE_bool(skgpuv2, false, "use the new GPU backend");
|
2021-06-04 20:37:30 +00:00
|
|
|
|
2021-04-14 15:52:25 +00:00
|
|
|
static DEFINE_int(gpuResourceCacheLimit, -1,
|
|
|
|
"Maximum number of bytes to use for budgeted GPU resources. "
|
|
|
|
"Default is -1, which means GrResourceCache::kDefaultMaxSize.");
|
|
|
|
|
2019-03-25 15:54:59 +00:00
|
|
|
static GpuPathRenderers get_named_pathrenderers_flags(const char* name) {
|
|
|
|
if (!strcmp(name, "none")) {
|
|
|
|
return GpuPathRenderers::kNone;
|
|
|
|
} else if (!strcmp(name, "dashline")) {
|
|
|
|
return GpuPathRenderers::kDashLine;
|
|
|
|
} else if (!strcmp(name, "aahairline")) {
|
|
|
|
return GpuPathRenderers::kAAHairline;
|
|
|
|
} else if (!strcmp(name, "aaconvex")) {
|
|
|
|
return GpuPathRenderers::kAAConvex;
|
|
|
|
} else if (!strcmp(name, "aalinearizing")) {
|
|
|
|
return GpuPathRenderers::kAALinearizing;
|
|
|
|
} else if (!strcmp(name, "small")) {
|
|
|
|
return GpuPathRenderers::kSmall;
|
2020-03-25 22:18:16 +00:00
|
|
|
} else if (!strcmp(name, "tri")) {
|
|
|
|
return GpuPathRenderers::kTriangulating;
|
2021-07-23 21:33:09 +00:00
|
|
|
} else if (!strcmp(name, "atlas")) {
|
|
|
|
return GpuPathRenderers::kAtlas;
|
2020-12-29 17:18:21 +00:00
|
|
|
} else if (!strcmp(name, "tess")) {
|
|
|
|
return GpuPathRenderers::kTessellation;
|
2019-12-28 21:51:11 +00:00
|
|
|
} else if (!strcmp(name, "default")) {
|
|
|
|
return GpuPathRenderers::kDefault;
|
2019-03-25 15:54:59 +00:00
|
|
|
}
|
2020-06-12 18:07:41 +00:00
|
|
|
SK_ABORT("error: unknown named path renderer \"%s\"\n", name);
|
2019-03-25 15:54:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static GpuPathRenderers collect_gpu_path_renderers_from_flags() {
|
|
|
|
if (FLAGS_pr.isEmpty()) {
|
2019-12-28 21:51:11 +00:00
|
|
|
return GpuPathRenderers::kDefault;
|
2019-03-25 15:54:59 +00:00
|
|
|
}
|
2019-03-30 06:31:23 +00:00
|
|
|
|
2019-03-25 15:54:59 +00:00
|
|
|
GpuPathRenderers gpuPathRenderers = ('~' == FLAGS_pr[0][0])
|
2019-12-28 21:51:11 +00:00
|
|
|
? GpuPathRenderers::kDefault
|
2019-03-30 06:31:23 +00:00
|
|
|
: GpuPathRenderers::kNone;
|
2019-03-25 15:54:59 +00:00
|
|
|
|
|
|
|
for (int i = 0; i < FLAGS_pr.count(); ++i) {
|
|
|
|
const char* name = FLAGS_pr[i];
|
|
|
|
if (name[0] == '~') {
|
|
|
|
gpuPathRenderers &= ~get_named_pathrenderers_flags(&name[1]);
|
|
|
|
} else {
|
|
|
|
gpuPathRenderers |= get_named_pathrenderers_flags(name);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return gpuPathRenderers;
|
|
|
|
}
|
|
|
|
|
|
|
|
void SetCtxOptionsFromCommonFlags(GrContextOptions* ctxOptions) {
|
|
|
|
static std::unique_ptr<SkExecutor> gGpuExecutor = (0 != FLAGS_gpuThreads)
|
|
|
|
? SkExecutor::MakeFIFOThreadPool(FLAGS_gpuThreads)
|
|
|
|
: nullptr;
|
|
|
|
|
|
|
|
ctxOptions->fExecutor = gGpuExecutor.get();
|
|
|
|
ctxOptions->fAllowPathMaskCaching = FLAGS_cachePathMasks;
|
2020-09-23 17:55:27 +00:00
|
|
|
ctxOptions->fAllPathsVolatile = FLAGS_allPathsVolatile;
|
2021-02-25 00:41:44 +00:00
|
|
|
ctxOptions->fEnableExperimentalHardwareTessellation = FLAGS_hwtess;
|
2020-09-17 18:16:54 +00:00
|
|
|
ctxOptions->fMaxTessellationSegmentsOverride = FLAGS_maxTessellationSegments;
|
2021-05-25 16:11:46 +00:00
|
|
|
ctxOptions->fAlwaysPreferHardwareTessellation = FLAGS_alwaysHwTess;
|
2019-03-25 15:54:59 +00:00
|
|
|
ctxOptions->fGpuPathRenderers = collect_gpu_path_renderers_from_flags();
|
|
|
|
ctxOptions->fDisableDriverCorrectnessWorkarounds = FLAGS_disableDriverCorrectnessWorkarounds;
|
2021-04-14 15:52:25 +00:00
|
|
|
ctxOptions->fResourceCacheLimitOverride = FLAGS_gpuResourceCacheLimit;
|
2019-03-25 15:54:59 +00:00
|
|
|
|
2021-06-24 00:47:09 +00:00
|
|
|
if (FLAGS_internalSamples >= 0) {
|
|
|
|
ctxOptions->fInternalMultisampleCount = FLAGS_internalSamples;
|
|
|
|
}
|
|
|
|
if (FLAGS_maxAtlasSize >= 0) {
|
|
|
|
ctxOptions->fMaxTextureAtlasSize = FLAGS_maxAtlasSize;
|
|
|
|
}
|
|
|
|
|
2021-05-26 18:46:28 +00:00
|
|
|
if (FLAGS_dontReduceOpsTaskSplitting) {
|
|
|
|
ctxOptions->fReduceOpsTaskSplitting = GrContextOptions::Enable::kNo;
|
|
|
|
} else {
|
|
|
|
ctxOptions->fReduceOpsTaskSplitting = GrContextOptions::Enable::kYes;
|
|
|
|
}
|
2021-06-04 20:37:30 +00:00
|
|
|
|
2021-07-09 13:10:02 +00:00
|
|
|
if (FLAGS_skgpuv2) {
|
|
|
|
ctxOptions->fUseSkGpuV2 = GrContextOptions::Enable::kYes;
|
2021-06-04 20:37:30 +00:00
|
|
|
}
|
2019-03-25 15:54:59 +00:00
|
|
|
}
|