我目前在nexus 6上遇到问题导致编译着色器时出现OpenGL崩溃。我的着色器通过检查扩展名是否为#defined然后在glCompileShader期间崩溃的过程来启用GL_OES_standard_derivatives扩展。该设备支持扩展,并在其他Android / iOS设备和版本上正常工作。
是否有其他人遇到此问题并找到解决方案/替代解决方案?
堆栈跟踪
03-18 12:41:26.350: I/DEBUG(343): *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
03-18 12:41:26.350: I/DEBUG(343): Build fingerprint: 'google/shamu/shamu:5.0/LRX21O/1570415:user/release-keys'
03-18 12:41:26.350: I/DEBUG(343): Revision: '33696'
03-18 12:41:26.350: I/DEBUG(343): ABI: 'arm'
03-18 12:41:26.350: I/DEBUG(343): pid: 17572, tid: 17613, name: Render Thread >>> com.ninjakiwi.monkeycity <<<
03-18 12:41:26.351: I/DEBUG(343): signal 11 (SIGSEGV), code 1 (SEGV_MAPERR), fault addr 0x11
03-18 12:41:26.405: I/DEBUG(343): r0 9ec5f900 r1 00000031 r2 9ec8aa00 r3 00000000
03-18 12:41:26.405: I/DEBUG(343): r4 9ecccd80 r5 00000002 r6 00000000 r7 ab474f50
03-18 12:41:26.405: I/DEBUG(343): r8 00000000 r9 00000001 sl 9ee00744 fp 00000001
03-18 12:41:26.405: I/DEBUG(343): ip 9ecf9c04 sp 9ee00728 lr ab3a1c0d pc ab39e0ae cpsr 200f0030
03-18 12:41:26.405: I/DEBUG(343): backtrace:
03-18 12:41:26.406: I/DEBUG(343): #00 pc 005c40ae /system/vendor/lib/libllvm-glnext.so (CPPStruct::UpdateExtBehavior(char const*, char const*)+545)
03-18 12:41:26.406: I/DEBUG(343): #01 pc 005c42a1 /system/vendor/lib/libllvm-glnext.so (CPPStruct::CPPextension(yystypepp*)+232)
03-18 12:41:26.406: I/DEBUG(343): #02 pc 005c60dd /system/vendor/lib/libllvm-glnext.so (CPPStruct::DispatchCPPline(yystypepp*, int)+696)
03-18 12:41:26.406: I/DEBUG(343): #03 pc 005c8a6f /system/vendor/lib/libllvm-glnext.so (YYParser::GetLexToken(char*, unsigned int)+150)
03-18 12:41:26.406: I/DEBUG(343): #04 pc 005c0bd5 /system/vendor/lib/libllvm-glnext.so (yy2_input(char*, int, TParseContext*)+12)
03-18 12:41:26.406: I/DEBUG(343): #05 pc 005c0d27 /system/vendor/lib/libllvm-glnext.so
03-18 12:41:26.406: I/DEBUG(343): #06 pc 005c212d /system/vendor/lib/libllvm-glnext.so (yy2lex(YYSTYPE*, TParseContext&)+3968)
03-18 12:41:26.406: I/DEBUG(343): #07 pc 005bb0a5 /system/vendor/lib/libllvm-glnext.so (yy2parse(TParseContext&)+328)
03-18 12:41:26.406: I/DEBUG(343): #08 pc 005c0e9d /system/vendor/lib/libllvm-glnext.so (yy2PaYYParse(TParseContext&)+16)
03-18 12:41:26.406: I/DEBUG(343): #09 pc 005c8981 /system/vendor/lib/libllvm-glnext.so (YYParser::ParseStrings(char**, long*, int, TParseContext&, int)+276)
03-18 12:41:26.406: I/DEBUG(343): #10 pc 005975b9 /system/vendor/lib/libllvm-glnext.so (ShCompile+1316)
03-18 12:41:26.406: I/DEBUG(343): #11 pc 005405cb /system/vendor/lib/libllvm-glnext.so (LLVMCompiler::parse(QGLC_SRCSHADER*)+1094)
03-18 12:41:26.406: I/DEBUG(343): #12 pc 0054380d /system/vendor/lib/libllvm-glnext.so (CompilerContext::CompileToIRShader(QGLC_SRCSHADER*, QGLC_COMPILETOIR_RESULT*)+168)
03-18 12:41:26.406: I/DEBUG(343): #13 pc 000f7ead /system/vendor/lib/egl/libGLESv2_adreno.so (EsxShaderCompiler::CompileShader(EsxShader const*, EsxInfoLog*)+476)
03-18 12:41:26.406: I/DEBUG(343): #14 pc 000f6a09 /system/vendor/lib/egl/libGLESv2_adreno.so (EsxShader::Compile(EsxContext*)+68)
03-18 12:41:26.406: I/DEBUG(343): #15 pc 000a8951 /system/vendor/lib/egl/libGLESv2_adreno.so (EsxContext::GlCompileShader(unsigned int)+60)
03-18 12:41:26.406: I/DEBUG(343): #16 pc 000d9cc1 /system/vendor/lib/egl/libGLESv2_adreno.so (EsxGlApiParamValidate::GlCompileShader(EsxDispatch*, unsigned int)+40)
03-18 12:41:26.406: I/DEBUG(343): #17 pc 0009fc13 /system/vendor/lib/egl/libGLESv2_adreno.so (glCompileShader+26)
03-18 12:41:26.406: I/DEBUG(343): #18 pc 0130c308 [REDACTED]
03-18 12:41:26.406: I/DEBUG(343): #19 pc 0130bb28 [REDACTED]
03-18 12:41:26.406: I/DEBUG(343): #20 pc 0130b85c [REDACTED]
03-18 12:41:26.406: I/DEBUG(343): #21 pc 011e5614 [REDACTED]
03-18 12:41:26.406: I/DEBUG(343): #22 pc 0130831c [REDACTED]
03-18 12:41:26.406: I/DEBUG(343): #23 pc 01308978 [REDACTED]
03-18 12:41:26.406: I/DEBUG(343): #24 pc 01308160 [REDACTED]
03-18 12:41:26.406: I/DEBUG(343): #25 pc 01113a0c [REDACTED]
03-18 12:41:26.406: I/DEBUG(343): #26 pc 011137e8 [REDACTED]
03-18 12:41:26.406: I/DEBUG(343): #27 pc 0111353c [REDACTED]
03-18 12:41:26.406: I/DEBUG(343): #28 pc 0169a8bf [REDACTED]
03-18 12:41:26.406: I/DEBUG(343): #29 pc 000162e3 /system/lib/libc.so (__pthread_start(void*)+30)
03-18 12:41:26.406: I/DEBUG(343): #30 pc 000142d3 /system/lib/libc.so (__start_thread+6)
设备详情
型号:Nexus 6
内部编号:LRX210
OpenGL版本:OpenGL ES 3.0V@95.0(GIT @ I86da836d38)
OpenGL渲染器:Adreno(TM)420
GLSL版本:OpenGL ES GLSL ES 3.10
支持的扩展:GL_EXT_debug_marker GL_OES_EGL_image GL_OES_EGL_image_external GL_OES_EGL_sync GL_OES_vertex_half_float GL_OES_framebuffer_object GL_OES_rgb8_rgba8 GL_OES_compressed_ETC1_RGB8_texture GL_AMD_compressed_ATC_texture GL_KHR_texture_compression_astc_ldr GL_OES_texture_npot GL_EXT_texture_filter_anisotropic GL_EXT_texture_format_BGRA8888 GL_OES_texture_3D GL_EXT_color_buffer_float GL_EXT_color_buffer_half_float GL_QCOM_alpha_test GL_OES_depth24 GL_OES_packed_depth_stencil GL_OES_depth_texture GL_OES_depth_texture_cube_map GL_EXT_sRGB GL_OES_texture_float GL_OES_texture_float_linear GL_OES_texture_half_float GL_OES_texture_half_float_linear GL_EXT_texture_type_2_10_10_10_REV GL_EXT_texture_sRGB_decode GL_OES_element_index_uint GL_EXT_copy_image GL_EXT_geometry_shader GL_EXT_tessellation_shader GL_OES_texture_stencil8 GL_EXT_shader_io_blocks GL_OES_shader_image_atomic GL_OES_sample_variables GL_EXT_texture_border_clamp GL_EXT_multisampled_render_to_texture GL_OES_shader_ multisample_interpolation GL_EXT_draw_buffers_indexed GL_EXT_gpu_shader5 GL_EXT_robustness GL_EXT_texture_buffer GL_OES_texture_storage_multisample_2d_array GL_OES_sample_shading GL_OES_get_program_binary GL_EXT_debug_label GL_KHR_blend_equation_advanced GL_KHR_blend_equation_advanced_coherent GL_QCOM_tiled_rendering GL_ANDROID_extension_pack_es31a GL_EXT_primitive_bounding_box GL_OES_standard_derivatives GL_OES_vertex_array_object GL_KHR_debug
Repro vertex shader
attribute highp vec4 Pos;
uniform mat4 ModelViewProj;
void main(void)
{
gl_Position = ModelViewProj * Pos;
}
Repro片段着色器
#if GL_OES_standard_derivatives
# extension GL_OES_standard_derivatives : enable
#endif // GL_OES_standard_derivatives
void main(void)
{
gl_FragColor = vec4(1.0, 1.0, 1.0, 1.0);
}
答案 0 :(得分:1)
我对这个问题的主要观察是,通过查看gl细节,我的GL版本为3.0,GLSL为3.1,这听起来不应该是可能的。我已经构建了一个工作,我检查OpenGL版本并加载没有扩展代码的着色器来尝试补偿它。然后,我只是硬编码一些值来代替扩展代码。它适用于我正在使用的着色器类型,但我可以想象其他人没有合适的值可以使用的情况。
然而,在发布游戏后,通过谷歌播放从其他设备(Android 5.0上的三星Galaxy Note4 / S5和Android 5.1上的Nexus 6)报告了相同的callstack,这是我目前无法访问的。
编辑:找到问题的实际解决方案。
扩展宏的#if检查不正确,应使用#ifdef或#if defined()进行检查。
此代码将正确编译,不会导致崩溃:
#ifdef GL_OES_standard_derivatives
# extension GL_OES_standard_derivatives : enable
#endif // GL_OES_standard_derivatives
void main(void)
{
gl_FragColor = vec4(1.0, 1.0, 1.0, 1.0);
}
来自GLSL Specification,第12页:
除了以下内容之外,#if,#iff,#ifnf,#else,#ifif和#endif被定义为与C ++一样运行:
- #if和#elif之后的表达式仅限于在文字整数常量上运行的表达式,以及定义的运算符所使用的标识符。
- 未定义的运算符未使用的未定义标识符 默认为'0'。使用此类标识符会导致错误。
- 不支持字符常量。
但是在一些实验中我发现以下代码无法编译但在glCompileShader期间不会崩溃:
#if GL_OES_standard_derivatives
//# extension GL_OES_standard_derivatives : enable
#endif // GL_OES_standard_derivatives
void main(void)
{
gl_FragColor = vec4(1.0, 1.0, 1.0, 1.0);
}