mirror of
https://github.com/wheremyfoodat/Panda3DS.git
synced 2025-04-06 22:25:41 +12:00
Update GL ES patch to work with latest changes
This commit is contained in:
parent
a3886a948f
commit
fe566e960b
1 changed files with 19 additions and 84 deletions
103
.github/gles.patch
vendored
103
.github/gles.patch
vendored
|
@ -1,52 +1,3 @@
|
||||||
diff --git a/src/core/renderer_gl/renderer_gl.cpp b/src/core/renderer_gl/renderer_gl.cpp
|
|
||||||
index a11a6ffa..77486a09 100644
|
|
||||||
--- a/src/core/renderer_gl/renderer_gl.cpp
|
|
||||||
+++ b/src/core/renderer_gl/renderer_gl.cpp
|
|
||||||
@@ -357,27 +357,27 @@ void RendererGL::bindTexturesToSlots() {
|
|
||||||
}
|
|
||||||
|
|
||||||
glActiveTexture(GL_TEXTURE0 + 3);
|
|
||||||
- glBindTexture(GL_TEXTURE_1D_ARRAY, lightLUTTextureArray);
|
|
||||||
+ // glBindTexture(GL_TEXTURE_1D_ARRAY, lightLUTTextureArray);
|
|
||||||
glActiveTexture(GL_TEXTURE0);
|
|
||||||
}
|
|
||||||
|
|
||||||
void RendererGL::updateLightingLUT() {
|
|
||||||
- gpu.lightingLUTDirty = false;
|
|
||||||
- std::array<u16, GPU::LightingLutSize> u16_lightinglut;
|
|
||||||
-
|
|
||||||
- for (int i = 0; i < gpu.lightingLUT.size(); i++) {
|
|
||||||
- uint64_t value = gpu.lightingLUT[i] & ((1 << 12) - 1);
|
|
||||||
- u16_lightinglut[i] = value * 65535 / 4095;
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
- glActiveTexture(GL_TEXTURE0 + 3);
|
|
||||||
- glBindTexture(GL_TEXTURE_1D_ARRAY, lightLUTTextureArray);
|
|
||||||
- glTexImage2D(GL_TEXTURE_1D_ARRAY, 0, GL_R16, 256, Lights::LUT_Count, 0, GL_RED, GL_UNSIGNED_SHORT, u16_lightinglut.data());
|
|
||||||
- glTexParameteri(GL_TEXTURE_1D_ARRAY, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
|
|
||||||
- glTexParameteri(GL_TEXTURE_1D_ARRAY, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
|
|
||||||
- glTexParameteri(GL_TEXTURE_1D_ARRAY, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE);
|
|
||||||
- glTexParameteri(GL_TEXTURE_1D_ARRAY, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
|
|
||||||
- glActiveTexture(GL_TEXTURE0);
|
|
||||||
+ // gpu.lightingLUTDirty = false;
|
|
||||||
+ // std::array<u16, GPU::LightingLutSize> u16_lightinglut;
|
|
||||||
+
|
|
||||||
+ // for (int i = 0; i < gpu.lightingLUT.size(); i++) {
|
|
||||||
+ // uint64_t value = gpu.lightingLUT[i] & ((1 << 12) - 1);
|
|
||||||
+ // u16_lightinglut[i] = value * 65535 / 4095;
|
|
||||||
+ // }
|
|
||||||
+
|
|
||||||
+ // glActiveTexture(GL_TEXTURE0 + 3);
|
|
||||||
+ // glBindTexture(GL_TEXTURE_1D_ARRAY, lightLUTTextureArray);
|
|
||||||
+ // glTexImage2D(GL_TEXTURE_1D_ARRAY, 0, GL_R16, 256, Lights::LUT_Count, 0, GL_RED, GL_UNSIGNED_SHORT, u16_lightinglut.data());
|
|
||||||
+ // glTexParameteri(GL_TEXTURE_1D_ARRAY, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
|
|
||||||
+ // glTexParameteri(GL_TEXTURE_1D_ARRAY, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
|
|
||||||
+ // glTexParameteri(GL_TEXTURE_1D_ARRAY, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE);
|
|
||||||
+ // glTexParameteri(GL_TEXTURE_1D_ARRAY, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
|
|
||||||
+ // glActiveTexture(GL_TEXTURE0);
|
|
||||||
}
|
|
||||||
|
|
||||||
void RendererGL::drawVertices(PICA::PrimType primType, std::span<const Vertex> vertices) {
|
|
||||||
diff --git a/src/host_shaders/opengl_display.frag b/src/host_shaders/opengl_display.frag
|
diff --git a/src/host_shaders/opengl_display.frag b/src/host_shaders/opengl_display.frag
|
||||||
index 612671c8..1937f711 100644
|
index 612671c8..1937f711 100644
|
||||||
--- a/src/host_shaders/opengl_display.frag
|
--- a/src/host_shaders/opengl_display.frag
|
||||||
|
@ -70,7 +21,7 @@ index 990e2f80..2e7842ac 100644
|
||||||
|
|
||||||
void main() {
|
void main() {
|
||||||
diff --git a/src/host_shaders/opengl_fragment_shader.frag b/src/host_shaders/opengl_fragment_shader.frag
|
diff --git a/src/host_shaders/opengl_fragment_shader.frag b/src/host_shaders/opengl_fragment_shader.frag
|
||||||
index f6fa6c55..bb88e278 100644
|
index 6b728ace..eaac1484 100644
|
||||||
--- a/src/host_shaders/opengl_fragment_shader.frag
|
--- a/src/host_shaders/opengl_fragment_shader.frag
|
||||||
+++ b/src/host_shaders/opengl_fragment_shader.frag
|
+++ b/src/host_shaders/opengl_fragment_shader.frag
|
||||||
@@ -1,4 +1,5 @@
|
@@ -1,4 +1,5 @@
|
||||||
|
@ -80,34 +31,16 @@ index f6fa6c55..bb88e278 100644
|
||||||
|
|
||||||
in vec3 v_tangent;
|
in vec3 v_tangent;
|
||||||
in vec3 v_normal;
|
in vec3 v_normal;
|
||||||
@@ -27,7 +28,7 @@ uniform bool u_depthmapEnable;
|
@@ -150,11 +151,17 @@ float lutLookup(uint lut, uint light, float value) {
|
||||||
uniform sampler2D u_tex0;
|
return texelFetch(u_tex_lighting_lut, ivec2(int(value * 256.0), lut), 0).r;
|
||||||
uniform sampler2D u_tex1;
|
}
|
||||||
uniform sampler2D u_tex2;
|
|
||||||
-uniform sampler1DArray u_tex_lighting_lut;
|
|
||||||
+// uniform sampler1DArray u_tex_lighting_lut;
|
|
||||||
|
|
||||||
uniform uint u_picaRegs[0x200 - 0x48];
|
|
||||||
|
|
||||||
@@ -145,16 +146,23 @@ vec4 tevCalculateCombiner(int tev_id) {
|
|
||||||
#define RR_LUT 6u
|
|
||||||
|
|
||||||
float lutLookup(uint lut, uint light, float value) {
|
|
||||||
- if (lut >= FR_LUT && lut <= RR_LUT) lut -= 1;
|
|
||||||
- if (lut == SP_LUT) lut = light + 8;
|
|
||||||
- return texture(u_tex_lighting_lut, vec2(value, lut)).r;
|
|
||||||
+ // if (lut >= FR_LUT && lut <= RR_LUT) lut -= 1;
|
|
||||||
+ // if (lut == SP_LUT) lut = light + 8;
|
|
||||||
+ // return texture(u_tex_lighting_lut, vec2(value, lut)).r;
|
|
||||||
+ return 0.0;
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+// some gles versions have bitfieldExtract and complain if you redefine it, some don't and compile error, using this instead
|
+// some gles versions have bitfieldExtract and complain if you redefine it, some don't and compile error, using this instead
|
||||||
+uint bitfieldExtractCompat(uint val, int off, int size) {
|
+uint bitfieldExtractCompat(uint val, int off, int size) {
|
||||||
+ uint mask = uint((1 << size) - 1);
|
+ uint mask = uint((1 << size) - 1);
|
||||||
+ return uint(val >> off) & mask;
|
+ return uint(val >> off) & mask;
|
||||||
}
|
+}
|
||||||
|
+
|
||||||
vec3 regToColor(uint reg) {
|
vec3 regToColor(uint reg) {
|
||||||
// Normalization scale to convert from [0...255] to [0.0...1.0]
|
// Normalization scale to convert from [0...255] to [0.0...1.0]
|
||||||
const float scale = 1.0 / 255.0;
|
const float scale = 1.0 / 255.0;
|
||||||
|
@ -117,7 +50,7 @@ index f6fa6c55..bb88e278 100644
|
||||||
}
|
}
|
||||||
|
|
||||||
// Convert an arbitrary-width floating point literal to an f32
|
// Convert an arbitrary-width floating point literal to an f32
|
||||||
@@ -189,7 +197,7 @@ void calcLighting(out vec4 primary_color, out vec4 secondary_color) {
|
@@ -189,7 +196,7 @@ void calcLighting(out vec4 primary_color, out vec4 secondary_color) {
|
||||||
vec3 view = normalize(v_view);
|
vec3 view = normalize(v_view);
|
||||||
|
|
||||||
uint GPUREG_LIGHTING_ENABLE = readPicaReg(0x008Fu);
|
uint GPUREG_LIGHTING_ENABLE = readPicaReg(0x008Fu);
|
||||||
|
@ -126,7 +59,7 @@ index f6fa6c55..bb88e278 100644
|
||||||
primary_color = secondary_color = vec4(1.0);
|
primary_color = secondary_color = vec4(1.0);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -213,7 +221,7 @@ void calcLighting(out vec4 primary_color, out vec4 secondary_color) {
|
@@ -213,7 +220,7 @@ void calcLighting(out vec4 primary_color, out vec4 secondary_color) {
|
||||||
bool error_unimpl = false;
|
bool error_unimpl = false;
|
||||||
|
|
||||||
for (uint i = 0u; i < GPUREG_LIGHTING_NUM_LIGHTS; i++) {
|
for (uint i = 0u; i < GPUREG_LIGHTING_NUM_LIGHTS; i++) {
|
||||||
|
@ -135,7 +68,7 @@ index f6fa6c55..bb88e278 100644
|
||||||
|
|
||||||
uint GPUREG_LIGHTi_SPECULAR0 = readPicaReg(0x0140u + 0x10u * light_id);
|
uint GPUREG_LIGHTi_SPECULAR0 = readPicaReg(0x0140u + 0x10u * light_id);
|
||||||
uint GPUREG_LIGHTi_SPECULAR1 = readPicaReg(0x0141u + 0x10u * light_id);
|
uint GPUREG_LIGHTi_SPECULAR1 = readPicaReg(0x0141u + 0x10u * light_id);
|
||||||
@@ -224,14 +232,14 @@ void calcLighting(out vec4 primary_color, out vec4 secondary_color) {
|
@@ -224,14 +231,14 @@ void calcLighting(out vec4 primary_color, out vec4 secondary_color) {
|
||||||
uint GPUREG_LIGHTi_CONFIG = readPicaReg(0x0149u + 0x10u * light_id);
|
uint GPUREG_LIGHTi_CONFIG = readPicaReg(0x0149u + 0x10u * light_id);
|
||||||
|
|
||||||
vec3 light_vector = normalize(vec3(
|
vec3 light_vector = normalize(vec3(
|
||||||
|
@ -153,7 +86,7 @@ index f6fa6c55..bb88e278 100644
|
||||||
// error_unimpl = true;
|
// error_unimpl = true;
|
||||||
half_vector = normalize(normalize(light_vector + v_view) + view);
|
half_vector = normalize(normalize(light_vector + v_view) + view);
|
||||||
}
|
}
|
||||||
@@ -242,12 +250,12 @@ void calcLighting(out vec4 primary_color, out vec4 secondary_color) {
|
@@ -242,12 +249,12 @@ void calcLighting(out vec4 primary_color, out vec4 secondary_color) {
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int c = 0; c < 7; c++) {
|
for (int c = 0; c < 7; c++) {
|
||||||
|
@ -169,7 +102,7 @@ index f6fa6c55..bb88e278 100644
|
||||||
if (input_id == 0u)
|
if (input_id == 0u)
|
||||||
d[c] = dot(normal, half_vector);
|
d[c] = dot(normal, half_vector);
|
||||||
else if (input_id == 1u)
|
else if (input_id == 1u)
|
||||||
@@ -260,9 +268,9 @@ void calcLighting(out vec4 primary_color, out vec4 secondary_color) {
|
@@ -260,9 +267,9 @@ void calcLighting(out vec4 primary_color, out vec4 secondary_color) {
|
||||||
uint GPUREG_LIGHTi_SPOTDIR_LOW = readPicaReg(0x0146u + 0x10u * light_id);
|
uint GPUREG_LIGHTi_SPOTDIR_LOW = readPicaReg(0x0146u + 0x10u * light_id);
|
||||||
uint GPUREG_LIGHTi_SPOTDIR_HIGH = readPicaReg(0x0147u + 0x10u * light_id);
|
uint GPUREG_LIGHTi_SPOTDIR_HIGH = readPicaReg(0x0147u + 0x10u * light_id);
|
||||||
vec3 spot_light_vector = normalize(vec3(
|
vec3 spot_light_vector = normalize(vec3(
|
||||||
|
@ -182,7 +115,7 @@ index f6fa6c55..bb88e278 100644
|
||||||
));
|
));
|
||||||
d[c] = dot(-light_vector, spot_light_vector); // -L dot P (aka Spotlight aka SP);
|
d[c] = dot(-light_vector, spot_light_vector); // -L dot P (aka Spotlight aka SP);
|
||||||
} else if (input_id == 5u) {
|
} else if (input_id == 5u) {
|
||||||
@@ -273,13 +281,13 @@ void calcLighting(out vec4 primary_color, out vec4 secondary_color) {
|
@@ -273,13 +280,13 @@ void calcLighting(out vec4 primary_color, out vec4 secondary_color) {
|
||||||
}
|
}
|
||||||
|
|
||||||
d[c] = lutLookup(uint(c), light_id, d[c] * 0.5 + 0.5) * scale;
|
d[c] = lutLookup(uint(c), light_id, d[c] * 0.5 + 0.5) * scale;
|
||||||
|
@ -198,7 +131,7 @@ index f6fa6c55..bb88e278 100644
|
||||||
if (lookup_config == 0u) {
|
if (lookup_config == 0u) {
|
||||||
d[D1_LUT] = 0.0;
|
d[D1_LUT] = 0.0;
|
||||||
d[FR_LUT] = 0.0;
|
d[FR_LUT] = 0.0;
|
||||||
@@ -310,7 +318,7 @@ void calcLighting(out vec4 primary_color, out vec4 secondary_color) {
|
@@ -310,7 +317,7 @@ void calcLighting(out vec4 primary_color, out vec4 secondary_color) {
|
||||||
float NdotL = dot(normal, light_vector); // Li dot N
|
float NdotL = dot(normal, light_vector); // Li dot N
|
||||||
|
|
||||||
// Two sided diffuse
|
// Two sided diffuse
|
||||||
|
@ -207,7 +140,7 @@ index f6fa6c55..bb88e278 100644
|
||||||
NdotL = max(0.0, NdotL);
|
NdotL = max(0.0, NdotL);
|
||||||
else
|
else
|
||||||
NdotL = abs(NdotL);
|
NdotL = abs(NdotL);
|
||||||
@@ -321,8 +329,8 @@ void calcLighting(out vec4 primary_color, out vec4 secondary_color) {
|
@@ -321,8 +328,8 @@ void calcLighting(out vec4 primary_color, out vec4 secondary_color) {
|
||||||
secondary_color.rgb += light_factor * (regToColor(GPUREG_LIGHTi_SPECULAR0) * d[D0_LUT] +
|
secondary_color.rgb += light_factor * (regToColor(GPUREG_LIGHTi_SPECULAR0) * d[D0_LUT] +
|
||||||
regToColor(GPUREG_LIGHTi_SPECULAR1) * d[D1_LUT] * vec3(d[RR_LUT], d[RG_LUT], d[RB_LUT]));
|
regToColor(GPUREG_LIGHTi_SPECULAR1) * d[D1_LUT] * vec3(d[RR_LUT], d[RG_LUT], d[RB_LUT]));
|
||||||
}
|
}
|
||||||
|
@ -249,14 +182,16 @@ index a25d7a6d..7cf40398 100644
|
||||||
+ // gl_ClipDistance[1] = dot(clipData, a_coords);
|
+ // gl_ClipDistance[1] = dot(clipData, a_coords);
|
||||||
}
|
}
|
||||||
diff --git a/third_party/opengl/opengl.hpp b/third_party/opengl/opengl.hpp
|
diff --git a/third_party/opengl/opengl.hpp b/third_party/opengl/opengl.hpp
|
||||||
index f368f573..5ead7f63 100644
|
index 9997e63b..5d9d7804 100644
|
||||||
--- a/third_party/opengl/opengl.hpp
|
--- a/third_party/opengl/opengl.hpp
|
||||||
+++ b/third_party/opengl/opengl.hpp
|
+++ b/third_party/opengl/opengl.hpp
|
||||||
@@ -520,21 +520,21 @@ namespace OpenGL {
|
@@ -561,22 +561,22 @@ namespace OpenGL {
|
||||||
|
static void disableScissor() { glDisable(GL_SCISSOR_TEST); }
|
||||||
static void enableBlend() { glEnable(GL_BLEND); }
|
static void enableBlend() { glEnable(GL_BLEND); }
|
||||||
static void disableBlend() { glDisable(GL_BLEND); }
|
static void disableBlend() { glDisable(GL_BLEND); }
|
||||||
static void enableLogicOp() { glEnable(GL_COLOR_LOGIC_OP); }
|
- static void enableLogicOp() { glEnable(GL_COLOR_LOGIC_OP); }
|
||||||
- static void disableLogicOp() { glDisable(GL_COLOR_LOGIC_OP); }
|
- static void disableLogicOp() { glDisable(GL_COLOR_LOGIC_OP); }
|
||||||
|
+ static void enableLogicOp() { /* glEnable(GL_COLOR_LOGIC_OP); */ }
|
||||||
+ static void disableLogicOp() { /* glDisable(GL_COLOR_LOGIC_OP); */ }
|
+ static void disableLogicOp() { /* glDisable(GL_COLOR_LOGIC_OP); */ }
|
||||||
static void enableDepth() { glEnable(GL_DEPTH_TEST); }
|
static void enableDepth() { glEnable(GL_DEPTH_TEST); }
|
||||||
static void disableDepth() { glDisable(GL_DEPTH_TEST); }
|
static void disableDepth() { glDisable(GL_DEPTH_TEST); }
|
||||||
|
|
Loading…
Add table
Reference in a new issue