Flutter Engine
The Flutter Engine
FuzzSkRuntimeBlender.cpp
Go to the documentation of this file.
1/*
2 * Copyright 2023 Google, LLC
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7
8#include "fuzz/Fuzz.h"
9#include "fuzz/FuzzCommon.h"
17
18using namespace skia_private;
19
20/**
21 * The fuzzer treats the input bytes as an SkSL blend program. The requested number of
22 * uniforms and children are automatically synthesized to match the program's needs.
23 *
24 * We fuzz twice, with two different settings for inlining in the SkSL compiler. By default, the
25 * compiler inlines most small to medium functions. This can hide bugs related to function-calling.
26 * So we run the fuzzer once with inlining disabled, and again with it enabled.
27 * This gives us better coverage, and eases the burden on the fuzzer to inject useless noise into
28 * functions to suppress inlining.
29 */
30static bool FuzzSkRuntimeBlender_Once(const SkString& shaderText,
33 SkRuntimeEffect* effect = result.effect.get();
34 if (!effect) {
35 return false;
36 }
37
38 sk_sp<SkData> uniformBytes;
40 FuzzCreateValidInputsForRuntimeEffect(effect, uniformBytes, children);
41
42 sk_sp<SkBlender> blender = effect->makeBlender(uniformBytes, SkSpan(children));
43 if (!blender) {
44 return false;
45 }
47 paint.setColor(SK_ColorRED);
48 paint.setBlender(std::move(blender));
49
51 if (!s) {
52 return false;
53 }
54 s->getCanvas()->drawPaint(paint);
55
56 return true;
57}
58
59bool FuzzSkRuntimeBlender(const uint8_t *data, size_t size) {
60 // Test once with optimization disabled...
61 SkString shaderText{reinterpret_cast<const char*>(data), size};
63 options.forceUnoptimized = true;
64 bool result = FuzzSkRuntimeBlender_Once(shaderText, options);
65
66 // ... and then with optimization enabled.
67 options.forceUnoptimized = false;
69
70 return result;
71}
72
73#if defined(SK_BUILD_FOR_LIBFUZZER)
74extern "C" int LLVMFuzzerTestOneInput(const uint8_t *data, size_t size) {
75 if (size > 3000) {
76 return 0;
77 }
79 return 0;
80}
81#endif
const char * options
void FuzzCreateValidInputsForRuntimeEffect(SkRuntimeEffect *effect, sk_sp< SkData > &uniformBytes, TArray< SkRuntimeEffect::ChildPtr > &children)
Definition: FuzzCommon.cpp:352
static bool FuzzSkRuntimeBlender_Once(const SkString &shaderText, const SkRuntimeEffect::Options &options)
bool FuzzSkRuntimeBlender(const uint8_t *data, size_t size)
constexpr SkColor SK_ColorRED
Definition: SkColor.h:126
SkSpan(Container &&) -> SkSpan< std::remove_pointer_t< decltype(std::data(std::declval< Container >()))> >
sk_sp< SkBlender > makeBlender(sk_sp< const SkData > uniforms, SkSpan< const ChildPtr > children={}) const
static Result MakeForBlender(SkString sksl, const Options &)
const Paint & paint
Definition: color_source.cc:38
int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size)
struct MyStruct s
GAsyncResult * result
SK_API sk_sp< SkSurface > Raster(const SkImageInfo &imageInfo, size_t rowBytes, const SkSurfaceProps *surfaceProps)
it will be possible to load the file into Perfetto s trace viewer disable asset Prevents usage of any non test fonts unless they were explicitly Loaded via prefetched default font Indicates whether the embedding started a prefetch of the default font manager before creating the engine run In non interactive keep the shell running after the Dart script has completed enable serial On low power devices with low core running concurrent GC tasks on threads can cause them to contend with the UI thread which could potentially lead to jank This option turns off all concurrent GC activities domain network JSON encoded network policy per domain This overrides the DisallowInsecureConnections switch Embedder can specify whether to allow or disallow insecure connections at a domain level old gen heap size
Definition: switches.h:259
static SkImageInfo MakeN32Premul(int width, int height)
std::shared_ptr< const fml::Mapping > data
Definition: texture_gles.cc:63