Add fuzzing for transform::Hlsl

BUG=tint:722

Change-Id: Iaf107077a596dd607c2f785d8787177279e0bcef
Reviewed-on: https://dawn-review.googlesource.com/c/tint/+/49461
Commit-Queue: Ryan Harrison <rharrison@chromium.org>
Auto-Submit: Ryan Harrison <rharrison@chromium.org>
Reviewed-by: Ben Clayton <bclayton@google.com>
diff --git a/fuzzers/BUILD.gn b/fuzzers/BUILD.gn
index 9f00ed3..890507a 100644
--- a/fuzzers/BUILD.gn
+++ b/fuzzers/BUILD.gn
@@ -94,6 +94,11 @@
   }
 
   if (tint_build_wgsl_reader && tint_build_hlsl_writer) {
+    fuzzer_test("tint_hlsl_transform_fuzzer") {
+      sources = [ "tint_hlsl_transform_fuzzer.cc" ]
+      deps = [ ":tint_fuzzer_common" ]
+    }
+
     fuzzer_test("tint_wgsl_reader_hlsl_writer_fuzzer") {
       sources = [ "tint_wgsl_reader_hlsl_writer_fuzzer.cc" ]
       deps = [ ":tint_fuzzer_common" ]
@@ -172,7 +177,10 @@
       ]
     }
     if (tint_build_wgsl_reader && tint_build_hlsl_writer) {
-      deps += [ ":tint_wgsl_reader_hlsl_writer_fuzzer" ]
+      deps += [
+        ":tint_hlsl_transform_fuzzer",
+        ":tint_wgsl_reader_hlsl_writer_fuzzer",
+      ]
     }
     if (tint_build_wgsl_reader && tint_build_msl_writer) {
       deps += [ ":tint_wgsl_reader_msl_writer_fuzzer" ]
diff --git a/fuzzers/CMakeLists.txt b/fuzzers/CMakeLists.txt
index f0c617d..08086e0 100644
--- a/fuzzers/CMakeLists.txt
+++ b/fuzzers/CMakeLists.txt
@@ -41,6 +41,7 @@
 
 if (${TINT_BUILD_WGSL_READER} AND ${TINT_BUILD_HLSL_WRITER})
   add_tint_fuzzer(tint_wgsl_reader_hlsl_writer_fuzzer)
+  add_tint_fuzzer(tint_hlsl_transform_fuzzer)
 endif()
 
 if (${TINT_BUILD_WGSL_READER} AND ${TINT_BUILD_MSL_WRITER})
diff --git a/fuzzers/tint_all_transforms_fuzzer.cc b/fuzzers/tint_all_transforms_fuzzer.cc
index 95b130f..5efe17b 100644
--- a/fuzzers/tint_all_transforms_fuzzer.cc
+++ b/fuzzers/tint_all_transforms_fuzzer.cc
@@ -17,29 +17,70 @@
 namespace tint {
 namespace fuzzers {
 
-extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
-  transform::Manager transform_manager;
-  transform::DataMap transform_inputs;
+struct Config {
+  const uint8_t* data;
+  size_t size;
+  transform::Manager manager;
+  transform::DataMap inputs;
+};
 
-  if (!ExtractFirstIndexOffsetInputs(&data, &size, &transform_inputs)) {
-    return 0;
+bool AddPlatformIndependentPasses(Config* config) {
+  if (!ExtractFirstIndexOffsetInputs(&config->data, &config->size,
+                                     &config->inputs)) {
+    return false;
   }
 
-  if (!ExtractBindingRemapperInputs(&data, &size, &transform_inputs)) {
-    return 0;
+  if (!ExtractBindingRemapperInputs(&config->data, &config->size,
+                                    &config->inputs)) {
+    return false;
   }
 
-  transform_manager.Add<transform::BoundArrayAccessors>();
-  transform_manager
+  config->manager.Add<transform::BoundArrayAccessors>();
+  config->manager
       .Add<transform::EmitVertexPointSize>();  // TODO(tint:753): Remove once
                                                // transform used by sanitizers
-  transform_manager.Add<transform::FirstIndexOffset>();
-  transform_manager.Add<transform::BindingRemapper>();
+  config->manager.Add<transform::FirstIndexOffset>();
+  config->manager.Add<transform::BindingRemapper>();
 
-  fuzzers::CommonFuzzer fuzzer(InputFormat::kWGSL, OutputFormat::kSpv);
-  fuzzer.SetTransformManager(&transform_manager, std::move(transform_inputs));
+  return true;
+}
 
-  return fuzzer.Run(data, size);
+extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
+  {
+    Config config;
+    config.data = data;
+    config.size = size;
+
+    if (!AddPlatformIndependentPasses(&config)) {
+      return 0;
+    }
+
+    fuzzers::CommonFuzzer fuzzer(InputFormat::kWGSL, OutputFormat::kSpv);
+    fuzzer.SetTransformManager(&(config.manager), std::move(config.inputs));
+
+    fuzzer.Run(config.data, config.size);
+  }
+
+#if TINT_BUILD_HLSL_WRITER
+  {
+    Config config;
+    config.data = data;
+    config.size = size;
+
+    if (!AddPlatformIndependentPasses(&config)) {
+      return 0;
+    }
+
+    config.manager.Add<transform::Hlsl>();
+
+    fuzzers::CommonFuzzer fuzzer(InputFormat::kWGSL, OutputFormat::kHLSL);
+    fuzzer.SetTransformManager(&config.manager, std::move(config.inputs));
+
+    fuzzer.Run(config.data, config.size);
+  }
+#endif  // TINT_BUILD_HLSL_WRITER
+
+  return 0;
 }
 
 }  // namespace fuzzers
diff --git a/fuzzers/tint_hlsl_transform_fuzzer.cc b/fuzzers/tint_hlsl_transform_fuzzer.cc
new file mode 100644
index 0000000..6950f87
--- /dev/null
+++ b/fuzzers/tint_hlsl_transform_fuzzer.cc
@@ -0,0 +1,31 @@
+// Copyright 2021 The Tint Authors.
+//
+// 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.
+
+#include "fuzzers/tint_common_fuzzer.h"
+
+namespace tint {
+namespace fuzzers {
+
+extern "C" int LLVMFuzzerTestOneInput(const uint8_t* data, size_t size) {
+  transform::Manager transform_manager;
+  transform_manager.Add<transform::Hlsl>();
+
+  fuzzers::CommonFuzzer fuzzer(InputFormat::kWGSL, OutputFormat::kHLSL);
+  fuzzer.SetTransformManager(&transform_manager, {});
+
+  return fuzzer.Run(data, size);
+}
+
+}  // namespace fuzzers
+}  // namespace tint