yuzu/src/video_core/host1x/host1x.cpp

38 lines
1.2 KiB
C++
Raw Normal View History

2022-11-05 16:58:44 +04:00
// SPDX-FileCopyrightText: 2021 yuzu Emulator Project
// SPDX-License-Identifier: GPL-3.0-or-later
#include "core/core.h"
#include "video_core/host1x/host1x.h"
2024-01-31 22:54:14 +04:00
#include "video_core/host1x/nvdec.h"
#include "video_core/host1x/vic.h"
2022-11-05 16:58:44 +04:00
2024-01-31 22:54:14 +04:00
namespace Tegra::Host1x {
2022-11-05 16:58:44 +04:00
Host1x::Host1x(Core::System& system_)
2024-01-07 13:47:31 +04:00
: system{system_}, syncpoint_manager{},
memory_manager(system.DeviceMemory()), gmmu_manager{system, memory_manager, 32, 12},
2022-11-05 16:58:44 +04:00
allocator{std::make_unique<Common::FlatAllocator<u32, 0, 32>>(1 << 12)} {}
2024-01-07 13:47:31 +04:00
Host1x::~Host1x() = default;
2024-01-31 22:54:14 +04:00
void Host1x::StartDevice(s32 fd, ChannelType type, u32 syncpt) {
switch (type) {
case ChannelType::NvDec:
devices[fd] = std::make_unique<Tegra::Host1x::Nvdec>(*this, fd, syncpt);
last_nvdec_fd = fd;
break;
case ChannelType::VIC:
devices[fd] = std::make_unique<Tegra::Host1x::Vic>(*this, fd, GetLastNvdecDevice(), syncpt);
break;
default:
LOG_ERROR(HW_GPU, "Unimplemented host1x device {}", static_cast<u32>(type));
break;
}
}
void Host1x::StopDevice(s32 fd, ChannelType type) {
devices.erase(fd);
}
2022-11-05 16:58:44 +04:00
2024-01-31 22:54:14 +04:00
} // namespace Tegra::Host1x