41 lines
1.3 KiB
C
Raw Normal View History

2017-05-29 17:02:09 -05:00
#pragma once
#include <memory>
#include "VideoBackends/Software/SWTexture.h"
#include "VideoBackends/Software/TextureEncoder.h"
2017-05-29 17:02:09 -05:00
#include "VideoCommon/TextureCacheBase.h"
namespace SW
{
class TextureCache : public TextureCacheBase
{
public:
bool CompileShaders() override { return true; }
void DeleteShaders() override {}
void ConvertTexture(TCacheEntry* entry, TCacheEntry* unconverted, const void* palette,
2017-09-02 21:30:34 -05:00
TLUTFormat format) override
2017-05-29 17:02:09 -05:00
{
}
void CopyEFB(u8* dst, const EFBCopyParams& params, u32 native_width, u32 bytes_per_row,
u32 num_blocks_y, u32 memory_stride, const EFBRectangle& src_rect,
bool scale_by_half) override
{
2017-09-02 21:30:34 -05:00
TextureEncoder::Encode(dst, params, native_width, bytes_per_row, num_blocks_y, memory_stride,
src_rect, scale_by_half);
2017-05-29 17:02:09 -05:00
}
private:
std::unique_ptr<AbstractTexture> CreateTexture(const TextureConfig& config) override
{
return std::make_unique<SWTexture>(config);
}
2017-09-02 21:30:34 -05:00
2017-05-29 17:02:09 -05:00
void CopyEFBToCacheEntry(TCacheEntry* entry, bool is_depth_copy, const EFBRectangle& src_rect,
bool scale_by_half, unsigned int cbuf_id, const float* colmat) override
{
// TODO: If we ever want to "fake" vram textures, we would need to implement this
2017-05-29 17:02:09 -05:00
}
};
2017-09-02 21:30:34 -05:00
} // namespace SW