2018-03-18 23:15:05 +03:00
|
|
|
// Copyright 2018 yuzu Emulator Project
|
|
|
|
// Licensed under GPLv2 or any later version
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
2018-08-11 01:39:37 +03:00
|
|
|
#include "common/assert.h"
|
2018-03-18 23:15:05 +03:00
|
|
|
#include "video_core/engines/fermi_2d.h"
|
|
|
|
#include "video_core/engines/maxwell_3d.h"
|
|
|
|
#include "video_core/engines/maxwell_compute.h"
|
2018-06-11 01:02:33 +03:00
|
|
|
#include "video_core/engines/maxwell_dma.h"
|
2018-03-18 23:15:05 +03:00
|
|
|
#include "video_core/gpu.h"
|
2018-08-03 19:55:58 +03:00
|
|
|
#include "video_core/rasterizer_interface.h"
|
2018-03-18 23:15:05 +03:00
|
|
|
|
|
|
|
namespace Tegra {
|
|
|
|
|
2018-08-11 01:39:37 +03:00
|
|
|
u32 FramebufferConfig::BytesPerPixel(PixelFormat format) {
|
|
|
|
switch (format) {
|
|
|
|
case PixelFormat::ABGR8:
|
|
|
|
return 4;
|
|
|
|
}
|
|
|
|
|
|
|
|
UNREACHABLE();
|
|
|
|
}
|
|
|
|
|
2018-08-03 19:55:58 +03:00
|
|
|
GPU::GPU(VideoCore::RasterizerInterface& rasterizer) {
|
2018-03-18 23:15:05 +03:00
|
|
|
memory_manager = std::make_unique<MemoryManager>();
|
2018-08-03 19:55:58 +03:00
|
|
|
maxwell_3d = std::make_unique<Engines::Maxwell3D>(rasterizer, *memory_manager);
|
2018-04-24 04:12:40 +03:00
|
|
|
fermi_2d = std::make_unique<Engines::Fermi2D>(*memory_manager);
|
2018-03-18 23:15:05 +03:00
|
|
|
maxwell_compute = std::make_unique<Engines::MaxwellCompute>();
|
2018-06-11 01:02:33 +03:00
|
|
|
maxwell_dma = std::make_unique<Engines::MaxwellDMA>(*memory_manager);
|
2018-03-18 23:15:05 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
GPU::~GPU() = default;
|
|
|
|
|
2018-07-21 01:31:36 +03:00
|
|
|
const Engines::Maxwell3D& GPU::Maxwell3D() const {
|
|
|
|
return *maxwell_3d;
|
|
|
|
}
|
|
|
|
|
|
|
|
Engines::Maxwell3D& GPU::Maxwell3D() {
|
2018-03-22 23:19:35 +03:00
|
|
|
return *maxwell_3d;
|
|
|
|
}
|
|
|
|
|
2018-04-25 05:57:10 +03:00
|
|
|
u32 RenderTargetBytesPerPixel(RenderTargetFormat format) {
|
|
|
|
ASSERT(format != RenderTargetFormat::NONE);
|
|
|
|
|
|
|
|
switch (format) {
|
2018-06-06 05:07:40 +03:00
|
|
|
case RenderTargetFormat::RGBA32_FLOAT:
|
2018-08-11 21:01:50 +03:00
|
|
|
case RenderTargetFormat::RGBA32_UINT:
|
2018-06-06 05:07:40 +03:00
|
|
|
return 16;
|
2018-08-13 07:04:52 +03:00
|
|
|
case RenderTargetFormat::RGBA16_UINT:
|
2018-06-06 06:01:20 +03:00
|
|
|
case RenderTargetFormat::RGBA16_FLOAT:
|
2018-07-24 02:10:00 +03:00
|
|
|
case RenderTargetFormat::RG32_FLOAT:
|
2018-08-13 15:55:16 +03:00
|
|
|
case RenderTargetFormat::RG32_UINT:
|
2018-06-06 06:01:20 +03:00
|
|
|
return 8;
|
2018-04-25 05:57:10 +03:00
|
|
|
case RenderTargetFormat::RGBA8_UNORM:
|
2018-08-10 18:44:43 +03:00
|
|
|
case RenderTargetFormat::RGBA8_SNORM:
|
2018-08-11 21:01:50 +03:00
|
|
|
case RenderTargetFormat::RGBA8_SRGB:
|
2018-04-25 05:57:10 +03:00
|
|
|
case RenderTargetFormat::RGB10_A2_UNORM:
|
2018-07-23 23:56:52 +03:00
|
|
|
case RenderTargetFormat::BGRA8_UNORM:
|
2018-08-11 21:01:50 +03:00
|
|
|
case RenderTargetFormat::RG16_UNORM:
|
|
|
|
case RenderTargetFormat::RG16_SNORM:
|
|
|
|
case RenderTargetFormat::RG16_UINT:
|
|
|
|
case RenderTargetFormat::RG16_SINT:
|
|
|
|
case RenderTargetFormat::RG16_FLOAT:
|
2018-08-01 16:31:42 +03:00
|
|
|
case RenderTargetFormat::R32_FLOAT:
|
2018-08-08 09:40:04 +03:00
|
|
|
case RenderTargetFormat::R11G11B10_FLOAT:
|
2018-08-13 15:55:16 +03:00
|
|
|
case RenderTargetFormat::R32_UINT:
|
2018-04-25 05:57:10 +03:00
|
|
|
return 4;
|
2018-08-11 21:01:50 +03:00
|
|
|
case RenderTargetFormat::R16_UNORM:
|
|
|
|
case RenderTargetFormat::R16_SNORM:
|
|
|
|
case RenderTargetFormat::R16_UINT:
|
|
|
|
case RenderTargetFormat::R16_SINT:
|
|
|
|
case RenderTargetFormat::R16_FLOAT:
|
2018-08-13 06:02:34 +03:00
|
|
|
case RenderTargetFormat::RG8_UNORM:
|
2018-08-10 19:07:37 +03:00
|
|
|
case RenderTargetFormat::RG8_SNORM:
|
2018-08-11 21:01:50 +03:00
|
|
|
return 2;
|
|
|
|
case RenderTargetFormat::R8_UNORM:
|
2018-08-12 04:44:42 +03:00
|
|
|
case RenderTargetFormat::R8_UINT:
|
2018-08-11 21:01:50 +03:00
|
|
|
return 1;
|
2018-04-25 05:57:10 +03:00
|
|
|
default:
|
2018-04-27 14:54:05 +03:00
|
|
|
UNIMPLEMENTED_MSG("Unimplemented render target format {}", static_cast<u32>(format));
|
2018-04-25 05:57:10 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-11 21:01:50 +03:00
|
|
|
u32 DepthFormatBytesPerPixel(DepthFormat format) {
|
|
|
|
switch (format) {
|
|
|
|
case DepthFormat::Z32_S8_X24_FLOAT:
|
|
|
|
return 8;
|
|
|
|
case DepthFormat::Z32_FLOAT:
|
|
|
|
case DepthFormat::S8_Z24_UNORM:
|
|
|
|
case DepthFormat::Z24_X8_UNORM:
|
|
|
|
case DepthFormat::Z24_S8_UNORM:
|
|
|
|
case DepthFormat::Z24_C8_UNORM:
|
|
|
|
return 4;
|
|
|
|
case DepthFormat::Z16_UNORM:
|
|
|
|
return 2;
|
|
|
|
default:
|
|
|
|
UNIMPLEMENTED_MSG("Unimplemented Depth format {}", static_cast<u32>(format));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-03-18 23:15:05 +03:00
|
|
|
} // namespace Tegra
|