2012-11-01 16:19:01 +01:00
|
|
|
// Copyright (c) 2012- PPSSPP Project.
|
|
|
|
|
|
|
|
// This program is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
2012-11-04 23:01:49 +01:00
|
|
|
// the Free Software Foundation, version 2.0 or later versions.
|
2012-11-01 16:19:01 +01:00
|
|
|
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License 2.0 for more details.
|
|
|
|
|
|
|
|
// A copy of the GPL 2.0 should have been included with the program.
|
|
|
|
// If not, see http://www.gnu.org/licenses/
|
|
|
|
|
|
|
|
// Official git repository and contact information can be found at
|
|
|
|
// https://github.com/hrydgard/ppsspp and http://www.ppsspp.org/.
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2013-01-30 21:09:53 +01:00
|
|
|
#include <list>
|
2013-01-30 20:40:26 +01:00
|
|
|
|
2013-07-29 22:38:02 -07:00
|
|
|
#include "gfx/gl_common.h"
|
2013-01-30 21:09:53 +01:00
|
|
|
#include "gfx_es2/fbo.h"
|
|
|
|
// Keeps track of allocated FBOs.
|
|
|
|
// Also provides facilities for drawing and later converting raw
|
|
|
|
// pixel data.
|
2013-01-30 20:40:26 +01:00
|
|
|
|
2012-11-01 16:19:01 +01:00
|
|
|
|
|
|
|
#include "../Globals.h"
|
2013-02-17 01:06:06 +01:00
|
|
|
#include "GPU/GPUCommon.h"
|
2012-11-01 16:19:01 +01:00
|
|
|
|
2012-12-01 02:15:46 +01:00
|
|
|
struct GLSLProgram;
|
2013-02-01 00:18:23 +01:00
|
|
|
class TextureCache;
|
2012-12-01 02:15:46 +01:00
|
|
|
|
2013-02-21 21:37:19 +01:00
|
|
|
enum {
|
2013-03-03 13:00:21 +01:00
|
|
|
FB_USAGE_DISPLAYED_FRAMEBUFFER = 1,
|
|
|
|
FB_USAGE_RENDERTARGET = 2,
|
|
|
|
FB_USAGE_TEXTURE = 4,
|
2013-02-21 21:37:19 +01:00
|
|
|
};
|
|
|
|
|
2013-07-05 02:31:31 +01:00
|
|
|
enum {
|
|
|
|
GPU_VENDOR_NVIDIA = 1,
|
|
|
|
GPU_VENDOR_AMD = 2,
|
|
|
|
GPU_VENDOR_INTEL = 3,
|
|
|
|
GPU_VENDOR_ARM = 4,
|
2013-07-21 01:14:36 +08:00
|
|
|
GPU_VENDOR_POWERVR = 5,
|
|
|
|
GPU_VENDOR_ADRENO = 6,
|
2013-07-22 07:33:18 +08:00
|
|
|
GPU_VENDOR_UNKNOWN = 0,
|
2013-07-05 02:31:31 +01:00
|
|
|
};
|
2013-02-21 21:37:19 +01:00
|
|
|
|
2013-07-21 23:17:42 +08:00
|
|
|
enum {
|
|
|
|
FB_NON_BUFFERED_MODE = 0,
|
|
|
|
FB_BUFFERED_MODE = 1,
|
2013-07-26 20:25:11 +08:00
|
|
|
#ifndef USING_GLES2
|
2013-07-22 07:33:18 +08:00
|
|
|
FB_READFBOMEMORY_CPU = 2,
|
|
|
|
FB_READFBOMEMORY_GPU = 3,
|
2013-07-26 20:25:11 +08:00
|
|
|
#else
|
|
|
|
FB_READFBOMEMORY_GPU = 2,
|
|
|
|
#endif
|
2013-07-21 23:17:42 +08:00
|
|
|
};
|
2013-07-22 07:33:18 +08:00
|
|
|
|
2013-02-21 21:37:19 +01:00
|
|
|
struct VirtualFramebuffer {
|
|
|
|
int last_frame_used;
|
2013-09-01 11:55:03 -07:00
|
|
|
int last_frame_render;
|
2013-08-12 02:30:17 +08:00
|
|
|
bool memoryUpdated;
|
2013-02-21 21:37:19 +01:00
|
|
|
|
|
|
|
u32 fb_address;
|
|
|
|
u32 z_address;
|
|
|
|
int fb_stride;
|
|
|
|
int z_stride;
|
|
|
|
|
|
|
|
// There's also a top left of the drawing region, but meh...
|
2013-06-20 22:18:44 +02:00
|
|
|
|
|
|
|
// width/height: The detected size of the current framebuffer.
|
2013-02-21 21:37:19 +01:00
|
|
|
u16 width;
|
|
|
|
u16 height;
|
2013-06-20 22:18:44 +02:00
|
|
|
// renderWidth/renderHeight: The actual size we render at. May be scaled to render at higher resolutions.
|
2013-02-21 21:37:19 +01:00
|
|
|
u16 renderWidth;
|
|
|
|
u16 renderHeight;
|
2013-06-20 22:18:44 +02:00
|
|
|
// bufferWidth/bufferHeight: The actual (but non scaled) size of the buffer we render to. May only be bigger than width/height.
|
|
|
|
u16 bufferWidth;
|
|
|
|
u16 bufferHeight;
|
2013-02-21 21:37:19 +01:00
|
|
|
|
|
|
|
u16 usageFlags;
|
|
|
|
|
2013-07-29 23:05:59 -07:00
|
|
|
GEBufferFormat format; // virtual, right now they are all RGBA8888
|
2013-02-21 21:37:19 +01:00
|
|
|
FBOColorDepth colorDepth;
|
|
|
|
FBO *fbo;
|
2013-03-03 13:00:21 +01:00
|
|
|
|
|
|
|
bool dirtyAfterDisplay;
|
2013-08-16 01:00:26 +02:00
|
|
|
bool reallyDirtyAfterDisplay; // takes frame skipping into account
|
2013-02-21 21:37:19 +01:00
|
|
|
};
|
|
|
|
|
2013-03-15 21:22:17 +01:00
|
|
|
void CenterRect(float *x, float *y, float *w, float *h,
|
|
|
|
float origW, float origH, float frameW, float frameH);
|
2013-02-21 21:37:19 +01:00
|
|
|
|
2013-07-06 00:40:01 +02:00
|
|
|
#ifndef USING_GLES2
|
2013-06-28 14:48:36 +01:00
|
|
|
// Simple struct for asynchronous PBO readbacks
|
|
|
|
struct AsyncPBO {
|
|
|
|
GLuint handle;
|
2013-07-01 21:51:24 +01:00
|
|
|
u32 maxSize;
|
2013-06-28 14:48:36 +01:00
|
|
|
|
|
|
|
u32 fb_address;
|
|
|
|
u32 stride;
|
|
|
|
u32 height;
|
2013-07-01 21:51:24 +01:00
|
|
|
u32 size;
|
2013-07-29 23:05:59 -07:00
|
|
|
GEBufferFormat format;
|
2013-06-28 14:48:36 +01:00
|
|
|
bool reading;
|
|
|
|
};
|
|
|
|
|
2013-07-06 00:40:01 +02:00
|
|
|
#endif
|
|
|
|
|
2013-03-16 00:40:37 +01:00
|
|
|
class ShaderManager;
|
|
|
|
|
2012-12-01 02:15:46 +01:00
|
|
|
class FramebufferManager {
|
|
|
|
public:
|
|
|
|
FramebufferManager();
|
|
|
|
~FramebufferManager();
|
|
|
|
|
2013-02-01 00:18:23 +01:00
|
|
|
void SetTextureCache(TextureCache *tc) {
|
|
|
|
textureCache_ = tc;
|
|
|
|
}
|
2013-03-16 00:40:37 +01:00
|
|
|
void SetShaderManager(ShaderManager *sm) {
|
|
|
|
shaderManager_ = sm;
|
|
|
|
}
|
2013-02-01 00:18:23 +01:00
|
|
|
|
2013-07-29 23:05:59 -07:00
|
|
|
void DrawPixels(const u8 *framebuf, GEBufferFormat pixelFormat, int linesize);
|
2013-07-01 18:59:44 +01:00
|
|
|
void DrawActiveTexture(float x, float y, float w, float h, bool flip = false, float uscale = 1.0f, float vscale = 1.0f, GLSLProgram *program = 0);
|
2012-12-01 02:15:46 +01:00
|
|
|
|
2013-01-30 21:09:53 +01:00
|
|
|
void DestroyAllFBOs();
|
2013-04-12 07:00:59 -07:00
|
|
|
void DecimateFBOs();
|
2013-01-30 20:40:26 +01:00
|
|
|
|
2013-01-30 21:09:53 +01:00
|
|
|
void BeginFrame();
|
2013-03-03 13:00:21 +01:00
|
|
|
void EndFrame();
|
2013-01-31 19:14:57 +08:00
|
|
|
void Resized();
|
2013-06-11 11:28:41 +02:00
|
|
|
void DeviceLost();
|
2013-01-30 21:09:53 +01:00
|
|
|
void CopyDisplayToOutput();
|
|
|
|
void SetRenderFrameBuffer(); // Uses parameters computed from gstate
|
2013-06-08 04:37:40 -07:00
|
|
|
void UpdateFromMemory(u32 addr, int size);
|
2013-06-22 22:27:59 +02:00
|
|
|
|
2013-08-12 02:30:17 +08:00
|
|
|
#ifdef USING_GLES2
|
|
|
|
void ReadFramebufferToMemory(VirtualFramebuffer *vfb, bool sync = true);
|
|
|
|
#else
|
|
|
|
void ReadFramebufferToMemory(VirtualFramebuffer *vfb, bool sync = false);
|
|
|
|
#endif
|
2013-06-25 13:50:35 +01:00
|
|
|
|
2013-01-30 21:09:53 +01:00
|
|
|
// TODO: Break out into some form of FBO manager
|
2013-09-21 18:52:30 +02:00
|
|
|
VirtualFramebuffer *GetVFBAt(u32 addr);
|
|
|
|
VirtualFramebuffer *GetDisplayVFB() {
|
|
|
|
return GetVFBAt(displayFramebufPtr_);
|
|
|
|
}
|
2013-07-29 23:05:59 -07:00
|
|
|
void SetDisplayFramebuffer(u32 framebuf, u32 stride, GEBufferFormat format);
|
2013-01-30 21:09:53 +01:00
|
|
|
size_t NumVFBs() const { return vfbs_.size(); }
|
2013-01-30 20:40:26 +01:00
|
|
|
|
2013-02-17 01:06:06 +01:00
|
|
|
std::vector<FramebufferInfo> GetFramebufferList();
|
|
|
|
|
2013-02-01 00:18:23 +01:00
|
|
|
int GetRenderWidth() const { return currentRenderVfb_ ? currentRenderVfb_->renderWidth : 480; }
|
|
|
|
int GetRenderHeight() const { return currentRenderVfb_ ? currentRenderVfb_->renderHeight : 272; }
|
|
|
|
int GetTargetWidth() const { return currentRenderVfb_ ? currentRenderVfb_->width : 480; }
|
|
|
|
int GetTargetHeight() const { return currentRenderVfb_ ? currentRenderVfb_->height : 272; }
|
|
|
|
|
2013-06-05 23:03:23 +02:00
|
|
|
u32 PrevDisplayFramebufAddr() {
|
2013-06-06 00:01:43 +02:00
|
|
|
return prevDisplayFramebuf_ ? (0x04000000 | prevDisplayFramebuf_->fb_address) : 0;
|
2013-06-05 23:03:23 +02:00
|
|
|
}
|
2013-06-06 10:30:05 +02:00
|
|
|
u32 DisplayFramebufAddr() {
|
|
|
|
return displayFramebuf_ ? (0x04000000 | displayFramebuf_->fb_address) : 0;
|
|
|
|
}
|
2013-01-30 21:09:53 +01:00
|
|
|
|
2013-09-21 18:52:30 +02:00
|
|
|
void NotifyFramebufferCopy(u32 src, u32 dest, int size);
|
|
|
|
|
2013-06-23 08:16:22 -07:00
|
|
|
void DestroyFramebuf(VirtualFramebuffer *vfb);
|
2013-06-23 17:05:59 +02:00
|
|
|
|
2013-09-22 19:03:31 -07:00
|
|
|
bool GetCurrentFramebuffer(GPUDebugBuffer &buffer);
|
|
|
|
|
2013-06-05 23:03:23 +02:00
|
|
|
private:
|
2013-07-16 22:50:53 +02:00
|
|
|
void CompileDraw2DProgram();
|
|
|
|
|
2013-01-30 21:09:53 +01:00
|
|
|
u32 displayFramebufPtr_;
|
|
|
|
u32 displayStride_;
|
2013-07-29 23:05:59 -07:00
|
|
|
GEBufferFormat displayFormat_;
|
2013-01-30 21:09:53 +01:00
|
|
|
|
|
|
|
VirtualFramebuffer *displayFramebuf_;
|
|
|
|
VirtualFramebuffer *prevDisplayFramebuf_;
|
|
|
|
VirtualFramebuffer *prevPrevDisplayFramebuf_;
|
2013-04-12 07:00:59 -07:00
|
|
|
int frameLastFramebufUsed;
|
2013-01-30 21:09:53 +01:00
|
|
|
|
2013-06-23 08:16:22 -07:00
|
|
|
std::vector<VirtualFramebuffer *> vfbs_;
|
2013-01-30 21:09:53 +01:00
|
|
|
|
|
|
|
VirtualFramebuffer *currentRenderVfb_;
|
2012-12-01 02:15:46 +01:00
|
|
|
|
2013-06-25 13:50:35 +01:00
|
|
|
// Used by ReadFramebufferToMemory
|
2013-07-01 18:59:44 +01:00
|
|
|
void BlitFramebuffer_(VirtualFramebuffer *src, VirtualFramebuffer *dst, bool flip = false, float upscale = 1.0f, float vscale = 1.0f);
|
2013-07-06 00:40:01 +02:00
|
|
|
#ifndef USING_GLES2
|
2013-08-12 02:30:17 +08:00
|
|
|
void PackFramebufferAsync_(VirtualFramebuffer *vfb);
|
2013-07-06 00:40:01 +02:00
|
|
|
#endif
|
2013-08-12 02:30:17 +08:00
|
|
|
void PackFramebufferSync_(VirtualFramebuffer *vfb);
|
2013-07-05 02:31:31 +01:00
|
|
|
int gpuVendor;
|
2013-06-25 13:50:35 +01:00
|
|
|
std::vector<VirtualFramebuffer *> bvfbs_; // blitting FBOs
|
2013-07-06 00:40:01 +02:00
|
|
|
|
2013-09-21 18:52:30 +02:00
|
|
|
std::set<std::pair<u32, u32>> knownFramebufferCopies_;
|
|
|
|
|
2013-07-06 00:40:01 +02:00
|
|
|
#ifndef USING_GLES2
|
2013-06-28 14:48:36 +01:00
|
|
|
AsyncPBO *pixelBufObj_; //this isn't that large
|
|
|
|
u8 currentPBO_;
|
2013-07-06 00:40:01 +02:00
|
|
|
#endif
|
2013-06-25 13:50:35 +01:00
|
|
|
|
2012-12-01 02:15:46 +01:00
|
|
|
// Used by DrawPixels
|
2013-06-05 23:03:23 +02:00
|
|
|
unsigned int drawPixelsTex_;
|
2013-07-29 23:05:59 -07:00
|
|
|
GEBufferFormat drawPixelsTexFormat_;
|
2012-12-01 02:15:46 +01:00
|
|
|
|
|
|
|
u8 *convBuf;
|
|
|
|
GLSLProgram *draw2dprogram;
|
2013-02-01 00:18:23 +01:00
|
|
|
|
|
|
|
|
|
|
|
TextureCache *textureCache_;
|
2013-03-16 00:40:37 +01:00
|
|
|
ShaderManager *shaderManager_;
|
2013-02-01 00:18:23 +01:00
|
|
|
|
2013-01-30 21:09:53 +01:00
|
|
|
bool resized_;
|
2013-04-27 20:06:31 +02:00
|
|
|
bool useBufferedRendering_;
|
2013-01-31 19:14:57 +08:00
|
|
|
};
|