This discussion has been locked.
You can no longer post new replies to this discussion. If you have a question you can start a new discussion

Shader language version in ARM GLES3.1 Emulator ver 2.2?

Please confirm shader language version used in ARM GLES 3.1 emulator version 2.2? User guide attached with emulator(Mali OpenGL ES Emulator 2.2 User Guide.pdf, Page 19) suggests that it support 3.1

===========================================

Shading Language Version

For OpenGL ES 2.0 contexts, the Mali OpenGL ES Emulator supports up to version 1.2 of the OpenGL

ES Shader Language.

For OpenGL ES 3.0 contexts, OpenGL ES Shader Language version 3.0 is supported. For OpenGL ES

3.1 contexts, OpenGL ES Shader Language 3.1 is supported.

==================================================

Whereas when I compile shader with ;#version 310 es' as first line it gives following compilation error.

==========================================

Log START:

Error: 0:1: P0007: Language version '310' unknown, this compiler only supports up to version '300 es'
Error: 0:1: P0007: Unexpected text found after #version directive
Error: 0:3: L0001: Typename expected, found 'in'

Log END

================================================

Note: If current compiler supports upto version 300 es only, when can I expect next release with version '310 es'


Regards

Sunil

Parents
  • Hi Sunil,

    thanks for details, it helped a lot in finding the actual issue.

    The #version 310 es is supported and your shaders should be correctly compiled (means - not error flag set), linked and can be used to run GL ES 3.1 programs on the Emulator.

    However, there is misleading log message for this case only (version 310 es), which you've observed.

    We've captured this one issue and there will be a fix for it making next release free from the inconvenience.

    As a work-around, please take GL_NO_ERROR returned from glGetError() in the first place as indication whether shader compilation succeeded, and a bit less rely on text log analysis, if possible for the time being.

    If you have ES 3.1 shader that set an error code on compilation attempt, then please have a look to the log to see whether the reason of it is indicated there. Don't hesitate to share your concerns if any expected language feature seems to be unsupported.

    These two lines you can ignore for now:

    Error: 0:1: P0007: Language version '310' unknown, this compiler only supports up to version '300 es'

    Error: 0:1: P0007: Unexpected text found after #version directive

    The shader compilation results and the support for ES 3.1 language features in the Emulator have been tested with official conformance tests suite therefore I'm convinced you should be able to use the Emulator productively. However, the exact compilation log content, as vendor specific - was not part of the that detailed check

    So, well spotted!

    Thanks,

    Adam

Reply
  • Hi Sunil,

    thanks for details, it helped a lot in finding the actual issue.

    The #version 310 es is supported and your shaders should be correctly compiled (means - not error flag set), linked and can be used to run GL ES 3.1 programs on the Emulator.

    However, there is misleading log message for this case only (version 310 es), which you've observed.

    We've captured this one issue and there will be a fix for it making next release free from the inconvenience.

    As a work-around, please take GL_NO_ERROR returned from glGetError() in the first place as indication whether shader compilation succeeded, and a bit less rely on text log analysis, if possible for the time being.

    If you have ES 3.1 shader that set an error code on compilation attempt, then please have a look to the log to see whether the reason of it is indicated there. Don't hesitate to share your concerns if any expected language feature seems to be unsupported.

    These two lines you can ignore for now:

    Error: 0:1: P0007: Language version '310' unknown, this compiler only supports up to version '300 es'

    Error: 0:1: P0007: Unexpected text found after #version directive

    The shader compilation results and the support for ES 3.1 language features in the Emulator have been tested with official conformance tests suite therefore I'm convinced you should be able to use the Emulator productively. However, the exact compilation log content, as vendor specific - was not part of the that detailed check

    So, well spotted!

    Thanks,

    Adam

Children
  • Hi Adam,

    Thanks for quick update, Actually GLSL built in function 'mix' is causing problem. Linking log hints at this. 

    error C1115: unable to find compatible overloaded function "mix(float, float, float)"

    error C1115: unable to find compatible overloaded function "mix(vec3, vec3, float)"

    Removing 'mix' from fragment shader compiles/links successfully. Please suggest if there is any workaround.

  • Hi Sunil,

    Let's see. We are aware about some issues with 'mix' using uvec types.

    As 'mix' comes with overloaded versions, can you point which particular one is troublesome in your case?

    Is it possible you share the whole shader source that causes the problem?

    cheers,

    Adam

  • Hi Adam,


    Built in function 'mix' is not working even for very basic example of mixing colors from two textures., it works if I remove outColor = mix(texture(tex1, texOut),texture(tex2,texOut),0.5f); by outColor = texture(tex1, texOut); It means problem lies with 'mix' function only.

    ----------------------------------------------

    #version 310 es

    precision highp float;

    in vec3 vv3colour;

    in vec2 texOut;

    out vec4 outColor;

    uniform sampler2D tex1;

    uniform sampler2D tex2;

    void main() {

      outColor = mix(texture(tex1, texOut),texture(tex2,texOut),0.5f);

    }

    ----------------------------------------

    In another case where I can not share other share shader codes, I created sample fragment shader to reproduce. It seems mix(vec4,vec4,float) is not working and gives following error while linking

    error C1115: unable to find compatible overloaded function "mix(vec3, vec3, float)" as shared in my above post.

    -------------------------------------------------

    #version 310 es

    precision highp float;

    in vec3 vv3colour;

    out vec4 outColor;

    void main() {

      outColor = mix(vec4(vv3colour,1.0),vec4(0.0,0.0,0.0,1.0),1.0);

    }

    --------------------------------------------------

    Please let me know if it helps, and you can run above shaders successfully.

  • Hi Sunil,

    it was helpful indeed, and we have reproduction for the problem.

    I confirm this is a valid issue for the Emulator and we'll prepare a fix for it.

    The not-so-convenient and temporary workaround for the moment would be dropping the built-in and switching to custom mix(vec4,vec4,float) function in your shader, by declaring it:

    -------------------

    vec4 mix(vec4 x, vec4 y, float a) { return (1-a)*x + a*y; }

    -------------------

    You can expect announcement on this thread when this issue gets resolution and the workaround is no longer necessary.

    Thanks for your report,

    Adam

  • Hi Sunil,

    Thanks again for your report.
    We have just released a new version of Mali OpenGL ES Emulator and the problems you have reported should now be fixed.
    You can download the latest Emulator 2.2.1 from http://malideveloper.arm.com/resources/tools/opengl-es-emulator/


    Could you please try it and confirm that the problems are gone?

    Thanks,

    Jacek