mirror of
https://github.com/encounter/dawn-cmake.git
synced 2025-12-21 18:59:21 +00:00
Move all the implementations of Toggle to Toggles.cpp
This patch moves all the code related to Toggle from Instance.cpp to Toggles.cpp to make the code in Instance.cpp cleaner. BUG=dawn:56 Change-Id: Ica2a779569478a58ddf21e632a211c0c5b889b00 Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/9580 Reviewed-by: Corentin Wallez <cwallez@chromium.org> Reviewed-by: Austin Eng <enga@chromium.org> Commit-Queue: Jiawei Shao <jiawei.shao@intel.com>
This commit is contained in:
committed by
Commit Bot service account
parent
35ad5221fb
commit
d08611b7a8
@@ -49,47 +49,6 @@ namespace dawn_native {
|
||||
}
|
||||
#endif // defined(DAWN_ENABLE_BACKEND_VULKAN)
|
||||
|
||||
namespace {
|
||||
|
||||
struct ToggleEnumAndInfo {
|
||||
Toggle toggle;
|
||||
ToggleInfo info;
|
||||
};
|
||||
|
||||
using ToggleEnumAndInfoList =
|
||||
std::array<ToggleEnumAndInfo, static_cast<size_t>(Toggle::EnumCount)>;
|
||||
|
||||
static constexpr ToggleEnumAndInfoList kToggleNameAndInfoList = {
|
||||
{{Toggle::EmulateStoreAndMSAAResolve,
|
||||
{"emulate_store_and_msaa_resolve",
|
||||
"Emulate storing into multisampled color attachments and doing MSAA resolve "
|
||||
"simultaneously. This workaround is enabled by default on the Metal drivers that do "
|
||||
"not support MTLStoreActionStoreAndMultisampleResolve. To support StoreOp::Store on "
|
||||
"those platforms, we should do MSAA resolve in another render pass after ending the "
|
||||
"previous one.",
|
||||
"https://bugs.chromium.org/p/dawn/issues/detail?id=56"}},
|
||||
{Toggle::NonzeroClearResourcesOnCreationForTesting,
|
||||
{"nonzero_clear_resources_on_creation_for_testing",
|
||||
"Clears texture to full 1 bits as soon as they are created, but doesn't update "
|
||||
"the tracking state of the texture. This way we can test the logic of clearing "
|
||||
"textures that use recycled memory.",
|
||||
"https://bugs.chromium.org/p/dawn/issues/detail?id=145"}},
|
||||
{Toggle::AlwaysResolveIntoZeroLevelAndLayer,
|
||||
{"always_resolve_into_zero_level_and_layer",
|
||||
"When the resolve target is a texture view that is created on the non-zero level or "
|
||||
"layer of a texture, we first resolve into a temporarily 2D texture with only one "
|
||||
"mipmap level and one array layer, and copy the result of MSAA resolve into the "
|
||||
"true resolve target. This workaround is enabled by default on the Metal drivers "
|
||||
"that have bugs when setting non-zero resolveLevel or resolveSlice.",
|
||||
"https://bugs.chromium.org/p/dawn/issues/detail?id=56"}},
|
||||
{Toggle::LazyClearResourceOnFirstUse,
|
||||
{"lazy_clear_resource_on_first_use",
|
||||
"Clears resource to zero on first usage. This initializes the resource "
|
||||
"so that no dirty bits from recycled memory is present in the new resource.",
|
||||
"https://bugs.chromium.org/p/dawn/issues/detail?id=145"}}}};
|
||||
|
||||
} // anonymous namespace
|
||||
|
||||
// InstanceBase
|
||||
|
||||
void InstanceBase::DiscoverDefaultAdapters() {
|
||||
@@ -119,51 +78,12 @@ namespace dawn_native {
|
||||
return !ConsumedError(DiscoverAdaptersInternal(options));
|
||||
}
|
||||
|
||||
const char* InstanceBase::ToggleEnumToName(Toggle toggle) {
|
||||
ASSERT(toggle != Toggle::InvalidEnum);
|
||||
|
||||
const ToggleEnumAndInfo& toggleNameAndInfo =
|
||||
kToggleNameAndInfoList[static_cast<size_t>(toggle)];
|
||||
ASSERT(toggleNameAndInfo.toggle == toggle);
|
||||
return toggleNameAndInfo.info.name;
|
||||
}
|
||||
|
||||
const ToggleInfo* InstanceBase::GetToggleInfo(const char* toggleName) {
|
||||
ASSERT(toggleName);
|
||||
|
||||
EnsureToggleNameToEnumMapInitialized();
|
||||
|
||||
const auto& iter = mToggleNameToEnumMap.find(toggleName);
|
||||
if (iter != mToggleNameToEnumMap.cend()) {
|
||||
return &kToggleNameAndInfoList[static_cast<size_t>(iter->second)].info;
|
||||
}
|
||||
return nullptr;
|
||||
return mTogglesInfo.GetToggleInfo(toggleName);
|
||||
}
|
||||
|
||||
Toggle InstanceBase::ToggleNameToEnum(const char* toggleName) {
|
||||
ASSERT(toggleName);
|
||||
|
||||
EnsureToggleNameToEnumMapInitialized();
|
||||
|
||||
const auto& iter = mToggleNameToEnumMap.find(toggleName);
|
||||
if (iter != mToggleNameToEnumMap.cend()) {
|
||||
return kToggleNameAndInfoList[static_cast<size_t>(iter->second)].toggle;
|
||||
}
|
||||
return Toggle::InvalidEnum;
|
||||
}
|
||||
|
||||
void InstanceBase::EnsureToggleNameToEnumMapInitialized() {
|
||||
if (mToggleNameToEnumMapInitialized) {
|
||||
return;
|
||||
}
|
||||
|
||||
for (size_t index = 0; index < kToggleNameAndInfoList.size(); ++index) {
|
||||
const ToggleEnumAndInfo& toggleNameAndInfo = kToggleNameAndInfoList[index];
|
||||
ASSERT(index == static_cast<size_t>(toggleNameAndInfo.toggle));
|
||||
mToggleNameToEnumMap[toggleNameAndInfo.info.name] = toggleNameAndInfo.toggle;
|
||||
}
|
||||
|
||||
mToggleNameToEnumMapInitialized = true;
|
||||
return mTogglesInfo.ToggleNameToEnum(toggleName);
|
||||
}
|
||||
|
||||
const std::vector<std::unique_ptr<AdapterBase>>& InstanceBase::GetAdapters() const {
|
||||
|
||||
Reference in New Issue
Block a user