2015-05-19 00:21:33 -04:00
|
|
|
// Copyright 2015 Citra Emulator Project
|
|
|
|
// Licensed under GPLv2 or any later version
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2015-06-27 12:56:17 -04:00
|
|
|
#include "common/common_types.h"
|
|
|
|
|
2016-04-16 18:57:57 -04:00
|
|
|
#include "core/hw/gpu.h"
|
|
|
|
|
|
|
|
struct ScreenInfo;
|
|
|
|
|
2015-06-27 12:56:17 -04:00
|
|
|
namespace Pica {
|
2015-07-21 19:04:05 -04:00
|
|
|
namespace Shader {
|
2015-06-27 12:56:17 -04:00
|
|
|
struct OutputVertex;
|
|
|
|
}
|
|
|
|
}
|
2015-05-19 00:21:33 -04:00
|
|
|
|
2015-12-06 22:06:12 -05:00
|
|
|
namespace VideoCore {
|
|
|
|
|
|
|
|
class RasterizerInterface {
|
2015-05-19 00:21:33 -04:00
|
|
|
public:
|
2016-09-17 20:38:01 -04:00
|
|
|
virtual ~RasterizerInterface() {
|
|
|
|
}
|
2015-05-19 00:21:33 -04:00
|
|
|
|
|
|
|
/// Queues the primitive formed by the given vertices for rendering
|
2015-07-21 19:04:05 -04:00
|
|
|
virtual void AddTriangle(const Pica::Shader::OutputVertex& v0,
|
|
|
|
const Pica::Shader::OutputVertex& v1,
|
|
|
|
const Pica::Shader::OutputVertex& v2) = 0;
|
2015-05-19 00:21:33 -04:00
|
|
|
|
|
|
|
/// Draw the current batch of triangles
|
|
|
|
virtual void DrawTriangles() = 0;
|
|
|
|
|
|
|
|
/// Notify rasterizer that the specified PICA register has been changed
|
|
|
|
virtual void NotifyPicaRegisterChanged(u32 id) = 0;
|
|
|
|
|
2016-04-16 18:57:57 -04:00
|
|
|
/// Notify rasterizer that all caches should be flushed to 3DS memory
|
|
|
|
virtual void FlushAll() = 0;
|
|
|
|
|
|
|
|
/// Notify rasterizer that any caches of the specified region should be flushed to 3DS memory
|
2015-12-06 20:56:45 -05:00
|
|
|
virtual void FlushRegion(PAddr addr, u32 size) = 0;
|
2015-05-19 00:21:33 -04:00
|
|
|
|
2016-09-17 20:38:01 -04:00
|
|
|
/// Notify rasterizer that any caches of the specified region should be flushed to 3DS memory
|
|
|
|
/// and invalidated
|
2016-04-16 18:57:57 -04:00
|
|
|
virtual void FlushAndInvalidateRegion(PAddr addr, u32 size) = 0;
|
|
|
|
|
|
|
|
/// Attempt to use a faster method to perform a display transfer
|
2016-09-17 20:38:01 -04:00
|
|
|
virtual bool AccelerateDisplayTransfer(const GPU::Regs::DisplayTransferConfig& config) {
|
|
|
|
return false;
|
|
|
|
}
|
2016-04-16 18:57:57 -04:00
|
|
|
|
|
|
|
/// Attempt to use a faster method to fill a region
|
2016-09-17 20:38:01 -04:00
|
|
|
virtual bool AccelerateFill(const GPU::Regs::MemoryFillConfig& config) {
|
|
|
|
return false;
|
|
|
|
}
|
2016-04-16 18:57:57 -04:00
|
|
|
|
|
|
|
/// Attempt to use a faster method to display the framebuffer to screen
|
2016-09-17 20:38:01 -04:00
|
|
|
virtual bool AccelerateDisplay(const GPU::Regs::FramebufferConfig& config,
|
|
|
|
PAddr framebuffer_addr, u32 pixel_stride,
|
|
|
|
ScreenInfo& screen_info) {
|
|
|
|
return false;
|
|
|
|
}
|
2015-05-19 00:21:33 -04:00
|
|
|
};
|
2015-12-06 22:06:12 -05:00
|
|
|
}
|