| // Copyright 2018 The Dawn 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. |
| |
| #ifndef SRC_DAWN_NATIVE_PHYSICALDEVICE_H_ |
| #define SRC_DAWN_NATIVE_PHYSICALDEVICE_H_ |
| |
| #include <string> |
| #include <vector> |
| |
| #include "dawn/native/DawnNative.h" |
| |
| #include "dawn/common/GPUInfo.h" |
| #include "dawn/common/Ref.h" |
| #include "dawn/common/RefCounted.h" |
| #include "dawn/common/ityp_span.h" |
| #include "dawn/native/Error.h" |
| #include "dawn/native/Features.h" |
| #include "dawn/native/Limits.h" |
| #include "dawn/native/Toggles.h" |
| #include "dawn/native/dawn_platform.h" |
| |
| namespace dawn::native { |
| |
| class DeviceBase; |
| |
| class PhysicalDeviceBase : public RefCounted { |
| public: |
| PhysicalDeviceBase(InstanceBase* instance, wgpu::BackendType backend); |
| ~PhysicalDeviceBase() override; |
| |
| MaybeError Initialize(); |
| |
| ResultOrError<Ref<DeviceBase>> CreateDevice(AdapterBase* adapter, |
| const DeviceDescriptor* descriptor, |
| const TogglesState& deviceToggles); |
| |
| uint32_t GetVendorId() const; |
| uint32_t GetDeviceId() const; |
| const std::string& GetVendorName() const; |
| const std::string& GetArchitectureName() const; |
| const std::string& GetName() const; |
| const gpu_info::DriverVersion& GetDriverVersion() const; |
| const std::string& GetDriverDescription() const; |
| wgpu::AdapterType GetAdapterType() const; |
| wgpu::BackendType GetBackendType() const; |
| |
| // This method differs from APIGetInstance() in that it won't increase the ref count of the |
| // instance. |
| InstanceBase* GetInstance() const; |
| |
| void ResetInternalDeviceForTesting(); |
| |
| // Get all features supported by the physical device and suitable with given toggles. |
| FeaturesSet GetSupportedFeatures(const TogglesState& toggles) const; |
| // Check if all given features are supported by the physical device and suitable with given |
| // toggles. |
| bool SupportsAllRequiredFeatures(const ityp::span<size_t, const wgpu::FeatureName>& features, |
| const TogglesState& toggles) const; |
| |
| const CombinedLimits& GetLimits() const; |
| |
| virtual bool SupportsExternalImages() const = 0; |
| |
| virtual bool SupportsFeatureLevel(FeatureLevel featureLevel) const = 0; |
| |
| // Backend-specific force-setting and defaulting device toggles |
| virtual void SetupBackendAdapterToggles(TogglesState* adapterToggles) const = 0; |
| // Backend-specific force-setting and defaulting device toggles |
| virtual void SetupBackendDeviceToggles(TogglesState* deviceToggles) const = 0; |
| |
| // Check if a feature os supported by this adapter AND suitable with given toggles. |
| MaybeError ValidateFeatureSupportedWithToggles(wgpu::FeatureName feature, |
| const TogglesState& toggles) const; |
| |
| protected: |
| uint32_t mVendorId = 0xFFFFFFFF; |
| std::string mVendorName; |
| std::string mArchitectureName; |
| uint32_t mDeviceId = 0xFFFFFFFF; |
| std::string mName; |
| wgpu::AdapterType mAdapterType = wgpu::AdapterType::Unknown; |
| gpu_info::DriverVersion mDriverVersion; |
| std::string mDriverDescription; |
| |
| // Juat a wrapper of ValidateFeatureSupportedWithToggles, return true if a feature is supported |
| // by this adapter AND suitable with given toggles. |
| bool IsFeatureSupportedWithToggles(wgpu::FeatureName feature, |
| const TogglesState& toggles) const; |
| // Mark a feature as enabled in mSupportedFeatures. |
| void EnableFeature(Feature feature); |
| // Used for the tests that intend to use an adapter without all features enabled. |
| void SetSupportedFeaturesForTesting(const std::vector<wgpu::FeatureName>& requiredFeatures); |
| |
| void GetDefaultLimitsForSupportedFeatureLevel(Limits* limits) const; |
| |
| private: |
| virtual ResultOrError<Ref<DeviceBase>> CreateDeviceImpl(AdapterBase* adapter, |
| const DeviceDescriptor* descriptor, |
| const TogglesState& deviceToggles) = 0; |
| |
| virtual MaybeError InitializeImpl() = 0; |
| |
| // Check base WebGPU features and discover supported features. |
| virtual void InitializeSupportedFeaturesImpl() = 0; |
| |
| // Check base WebGPU limits and populate supported limits. |
| virtual MaybeError InitializeSupportedLimitsImpl(CombinedLimits* limits) = 0; |
| |
| virtual void InitializeVendorArchitectureImpl(); |
| |
| virtual MaybeError ValidateFeatureSupportedWithTogglesImpl( |
| wgpu::FeatureName feature, |
| const TogglesState& toggles) const = 0; |
| |
| virtual MaybeError ResetInternalDeviceForTestingImpl(); |
| Ref<InstanceBase> mInstance; |
| wgpu::BackendType mBackend; |
| |
| // Features set that CAN be supported by devices of this adapter. Some features in this set may |
| // be guarded by toggles, and creating a device with these features required may result in a |
| // validation error if proper toggles are not enabled/disabled. |
| FeaturesSet mSupportedFeatures; |
| |
| CombinedLimits mLimits; |
| }; |
| |
| } // namespace dawn::native |
| |
| #endif // SRC_DAWN_NATIVE_PHYSICALDEVICE_H_ |