tint: Fix dxc on Linux

Fixes "dxc failed : unable to parse shader model.".

On windows the called program is responsible for splitting arguments
from one joined string. Command line arguments on 'nix systems need to
be passed as separate strings. This CL makes it so that we pass in the
arg separately, and support ignoring empty string args to make writing
this code easier.

Change-Id: Ia9618c2a743f8fdb49913572e2bbfc4bd1519d3a
Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/98110
Reviewed-by: Ben Clayton <bclayton@google.com>
Kokoro: Kokoro <noreply+kokoro@google.com>
Reviewed-by: Dan Sinclair <dsinclair@chromium.org>
Commit-Queue: Antonio Maiorano <amaiorano@google.com>
This commit is contained in:
Antonio Maiorano 2022-08-03 21:40:46 +00:00 committed by Dawn LUCI CQ
parent 50940aeef1
commit 50bddbffca
3 changed files with 13 additions and 14 deletions

View File

@ -251,7 +251,9 @@ Command::Output Command::Exec(std::initializer_list<std::string> arguments) cons
std::vector<const char*> args;
args.emplace_back(path_.c_str());
for (auto& arg : arguments) {
args.emplace_back(arg.c_str());
if (!arg.empty()) {
args.emplace_back(arg.c_str());
}
}
args.emplace_back(nullptr);
auto res = execv(path_.c_str(), const_cast<char* const*>(args.data()));

View File

@ -200,7 +200,9 @@ Command::Output Command::Exec(std::initializer_list<std::string> arguments) cons
std::stringstream args;
args << path_;
for (auto& arg : arguments) {
args << " " << arg;
if (!arg.empty()) {
args << " " << arg;
}
}
PROCESS_INFORMATION pi{};

View File

@ -69,21 +69,16 @@ Result HlslUsingDXC(const std::string& dxc_path,
break;
}
std::string profile =
"-T " + std::string(stage_prefix) + "_" + std::string(shader_model_version);
if (require_16bit_types) {
// Add "-enable-16bit-types" flag if required
profile = profile + " -enable-16bit-types";
}
// Match Dawn's compile flags
// See dawn\src\dawn_native\d3d12\RenderPipelineD3D12.cpp
// and dawn_native\d3d12\ShaderModuleD3D12.cpp (GetDXCArguments)
auto res = dxc(profile.c_str(),
"-E " + ep.first, // Entry point
"/Zpr", // D3DCOMPILE_PACK_MATRIX_ROW_MAJOR
"/Gis", // D3DCOMPILE_IEEE_STRICTNESS
file.Path());
auto res = dxc(
"-T " + std::string(stage_prefix) + "_" + std::string(shader_model_version), // Profile
"-E " + ep.first, // Entry point
"/Zpr", // D3DCOMPILE_PACK_MATRIX_ROW_MAJOR
"/Gis", // D3DCOMPILE_IEEE_STRICTNESS
require_16bit_types ? "-enable-16bit-types" : "", // Enable 16-bit if required
file.Path());
if (!res.out.empty()) {
if (!result.output.empty()) {
result.output += "\n";