mirror of
https://github.com/encounter/dawn-cmake.git
synced 2025-08-08 21:19:14 +00:00
New objects are introduced to control what happens before device creation in dawn_native: - Instance: a connection from the application to dawn_native that is used for dependency injection and to discover adapters. - Adapters: represents the possibility of device creation for a specific (GPU, backend) pair. - BackendConnection: an internal object that standardizes the interface between the frontend and backends. The BackendConnection interface is implemented for the Null backend and stubbed out in other backends. This allows this change to port the ValidationTests to use the new Instance and Adapters concept and deal with other backends later. BUG=dawn:29 Change-Id: I19719a9342b4af091accc0c02fb6b9697eadde7b Reviewed-on: https://dawn-review.googlesource.com/c/3500 Reviewed-by: Stephen White <senorblanco@chromium.org> Reviewed-by: Kai Ninomiya <kainino@chromium.org> Reviewed-by: Corentin Wallez <cwallez@chromium.org> Commit-Queue: Corentin Wallez <cwallez@chromium.org>
55 lines
1.6 KiB
C++
55 lines
1.6 KiB
C++
// 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;
|
|
}
|
|
|
|
const PCIInfo& AdapterBase::GetPCIInfo() const {
|
|
return mPCIInfo;
|
|
}
|
|
|
|
InstanceBase* AdapterBase::GetInstance() const {
|
|
return mInstance;
|
|
}
|
|
|
|
DeviceBase* AdapterBase::CreateDevice() {
|
|
DeviceBase* result = nullptr;
|
|
|
|
if (mInstance->ConsumedError(CreateDeviceInternal(&result))) {
|
|
return nullptr;
|
|
}
|
|
|
|
return result;
|
|
}
|
|
|
|
MaybeError AdapterBase::CreateDeviceInternal(DeviceBase** result) {
|
|
// 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.
|
|
DAWN_TRY_ASSIGN(*result, CreateDeviceImpl());
|
|
return {};
|
|
}
|
|
|
|
} // namespace dawn_native
|