| // Copyright 2020 The Chromium Authors |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| // Message format for the MojoLPM fuzzer for the CodeCacheHost interface. |
| |
| syntax = "proto2"; |
| |
| package content.fuzzing.code_cache_host.proto; |
| |
| import "third_party/blink/public/mojom/loader/code_cache.mojom.mojolpm.proto"; |
| |
| // Bind a new CodeCacheHost remote |
| message NewCodeCacheHostAction { |
| enum OriginId { |
| ORIGIN_A = 0; |
| ORIGIN_B = 1; |
| ORIGIN_OPAQUE = 2; |
| ORIGIN_EMPTY = 3; |
| } |
| |
| required uint32 id = 1; |
| required uint32 render_process_id = 2; |
| required OriginId origin_id = 3; |
| } |
| |
| // Run the specific sequence for (an indeterminate) period. This is not |
| // intended to create a specific ordering, but to allow the fuzzer to delay a |
| // later task until previous tasks have completed. |
| message RunThreadAction { |
| enum ThreadId { |
| IO = 0; |
| UI = 1; |
| } |
| |
| required ThreadId id = 1; |
| } |
| |
| // Actions that can be performed by the fuzzer. |
| message Action { |
| oneof action { |
| NewCodeCacheHostAction new_code_cache_host = 1; |
| RunThreadAction run_thread = 2; |
| mojolpm.blink.mojom.CodeCacheHost.RemoteAction |
| code_cache_host_remote_action = 3; |
| } |
| } |
| |
| // Sequence provides a level of indirection which allows Testcase to compactly |
| // express repeated sequences of actions. |
| message Sequence { |
| repeated uint32 action_indexes = 1 [packed = true]; |
| } |
| |
| // Testcase is the top-level message type interpreted by the fuzzer. |
| message Testcase { |
| repeated Action actions = 1; |
| repeated Sequence sequences = 2; |
| repeated uint32 sequence_indexes = 3 [packed = true]; |
| } |