2019-01-04 10:30:40 +00:00
|
|
|
// 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.
|
|
|
|
|
|
|
|
#include "dawn_native/Adapter.h"
|
|
|
|
|
|
|
|
#include "dawn_native/Instance.h"
|
|
|
|
|
|
|
|
namespace dawn_native {
|
|
|
|
|
|
|
|
AdapterBase::AdapterBase(InstanceBase* instance, BackendType backend)
|
|
|
|
: mInstance(instance), mBackend(backend) {
|
|
|
|
}
|
|
|
|
|
|
|
|
BackendType AdapterBase::GetBackendType() const {
|
|
|
|
return mBackend;
|
|
|
|
}
|
|
|
|
|
2019-04-15 16:36:25 +00:00
|
|
|
DeviceType AdapterBase::GetDeviceType() const {
|
|
|
|
return mDeviceType;
|
|
|
|
}
|
|
|
|
|
2019-01-04 10:30:40 +00:00
|
|
|
const PCIInfo& AdapterBase::GetPCIInfo() const {
|
|
|
|
return mPCIInfo;
|
|
|
|
}
|
|
|
|
|
|
|
|
InstanceBase* AdapterBase::GetInstance() const {
|
|
|
|
return mInstance;
|
|
|
|
}
|
|
|
|
|
2019-08-02 00:06:38 +00:00
|
|
|
ExtensionsSet AdapterBase::GetSupportedExtensions() const {
|
|
|
|
return mSupportedExtensions;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool AdapterBase::SupportsAllRequestedExtensions(
|
|
|
|
const std::vector<const char*>& requestedExtensions) const {
|
|
|
|
for (const char* extensionStr : requestedExtensions) {
|
|
|
|
Extension extensionEnum = mInstance->ExtensionNameToEnum(extensionStr);
|
|
|
|
if (extensionEnum == Extension::InvalidEnum) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
if (!mSupportedExtensions.IsEnabled(extensionEnum)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2019-04-26 07:52:57 +00:00
|
|
|
DeviceBase* AdapterBase::CreateDevice(const DeviceDescriptor* descriptor) {
|
2019-01-04 10:30:40 +00:00
|
|
|
DeviceBase* result = nullptr;
|
|
|
|
|
2019-04-26 07:52:57 +00:00
|
|
|
if (mInstance->ConsumedError(CreateDeviceInternal(&result, descriptor))) {
|
2019-01-04 10:30:40 +00:00
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2019-04-26 07:52:57 +00:00
|
|
|
MaybeError AdapterBase::CreateDeviceInternal(DeviceBase** result,
|
|
|
|
const DeviceDescriptor* descriptor) {
|
2019-08-02 00:06:38 +00:00
|
|
|
if (descriptor != nullptr) {
|
|
|
|
if (!SupportsAllRequestedExtensions(descriptor->requiredExtensions)) {
|
|
|
|
return DAWN_VALIDATION_ERROR("One or more requested extensions are not supported");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-01-04 10:30:40 +00:00
|
|
|
// TODO(cwallez@chromium.org): This will eventually have validation that the device
|
|
|
|
// descriptor is valid and is a subset what's allowed on this adapter.
|
2019-04-26 07:52:57 +00:00
|
|
|
DAWN_TRY_ASSIGN(*result, CreateDeviceImpl(descriptor));
|
2019-01-04 10:30:40 +00:00
|
|
|
return {};
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace dawn_native
|