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

View File

@ -200,8 +200,10 @@ Command::Output Command::Exec(std::initializer_list<std::string> arguments) cons
std::stringstream args; std::stringstream args;
args << path_; args << path_;
for (auto& arg : arguments) { for (auto& arg : arguments) {
if (!arg.empty()) {
args << " " << arg; args << " " << arg;
} }
}
PROCESS_INFORMATION pi{}; PROCESS_INFORMATION pi{};
if (!CreateProcessA(nullptr, // No module name (use command line) if (!CreateProcessA(nullptr, // No module name (use command line)

View File

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