Minor tweaks for crazy shaders.
This commit is contained in:
parent
3a197705bb
commit
ab90e0932b
|
@ -2523,7 +2523,7 @@ bool CommandProcessor::IssueCopy() {
|
||||||
uint32_t copy_dest_number = (copy_dest_info >> 13) & 0x7;
|
uint32_t copy_dest_number = (copy_dest_info >> 13) & 0x7;
|
||||||
// assert_true(copy_dest_number == 0); // ?
|
// assert_true(copy_dest_number == 0); // ?
|
||||||
uint32_t copy_dest_bias = (copy_dest_info >> 16) & 0x3F;
|
uint32_t copy_dest_bias = (copy_dest_info >> 16) & 0x3F;
|
||||||
assert_true(copy_dest_bias == 0);
|
// assert_true(copy_dest_bias == 0);
|
||||||
uint32_t copy_dest_swap = (copy_dest_info >> 25) & 0x1;
|
uint32_t copy_dest_swap = (copy_dest_info >> 25) & 0x1;
|
||||||
|
|
||||||
uint32_t copy_dest_base = regs[XE_GPU_REG_RB_COPY_DEST_BASE].u32;
|
uint32_t copy_dest_base = regs[XE_GPU_REG_RB_COPY_DEST_BASE].u32;
|
||||||
|
@ -2586,10 +2586,18 @@ bool CommandProcessor::IssueCopy() {
|
||||||
GLenum read_format;
|
GLenum read_format;
|
||||||
GLenum read_type;
|
GLenum read_type;
|
||||||
switch (copy_dest_format) {
|
switch (copy_dest_format) {
|
||||||
|
case ColorFormat::k_2_10_10_10:
|
||||||
|
read_format = GL_RGB10_A2;
|
||||||
|
read_type = GL_UNSIGNED_INT_10_10_10_2;
|
||||||
|
break;
|
||||||
case ColorFormat::k_4_4_4_4:
|
case ColorFormat::k_4_4_4_4:
|
||||||
read_format = GL_RGBA4;
|
read_format = GL_RGBA4;
|
||||||
read_type = GL_UNSIGNED_SHORT_4_4_4_4;
|
read_type = GL_UNSIGNED_SHORT_4_4_4_4;
|
||||||
break;
|
break;
|
||||||
|
case ColorFormat::k_5_6_5:
|
||||||
|
read_format = GL_RGB565;
|
||||||
|
read_type = GL_UNSIGNED_SHORT_5_6_5;
|
||||||
|
break;
|
||||||
case ColorFormat::k_8:
|
case ColorFormat::k_8:
|
||||||
read_format = GL_R8;
|
read_format = GL_R8;
|
||||||
read_type = GL_UNSIGNED_BYTE;
|
read_type = GL_UNSIGNED_BYTE;
|
||||||
|
|
|
@ -43,7 +43,7 @@ namespace gpu {
|
||||||
using namespace xe::gpu::ucode;
|
using namespace xe::gpu::ucode;
|
||||||
using namespace xe::gpu::xenos;
|
using namespace xe::gpu::xenos;
|
||||||
|
|
||||||
const int OUTPUT_CAPACITY = 32 * 1024;
|
const int OUTPUT_CAPACITY = 256 * 1024;
|
||||||
struct Output {
|
struct Output {
|
||||||
char buffer[OUTPUT_CAPACITY];
|
char buffer[OUTPUT_CAPACITY];
|
||||||
size_t capacity;
|
size_t capacity;
|
||||||
|
@ -54,6 +54,7 @@ struct Output {
|
||||||
va_start(args, format);
|
va_start(args, format);
|
||||||
int len = vsnprintf(buffer + offset, capacity - offset, format, args);
|
int len = vsnprintf(buffer + offset, capacity - offset, format, args);
|
||||||
va_end(args);
|
va_end(args);
|
||||||
|
assert_true(offset + len < capacity);
|
||||||
offset += len;
|
offset += len;
|
||||||
buffer[offset] = 0;
|
buffer[offset] = 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue