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

Basic Graphics Questions , How GPU works and achieves Parallesim.

Dear Experts,

I have some basic graphics questions here, my interest is basically with ARM MALI 400 MP2.

Please provide your inputs

  1. Open VG/GL/GLES APIs generates any commands for GPU(VP and PP) to process? Are they defined by Khronous?
  2. Is every Open VG/GL/GLES API generates some commands?  Few of them may just configure the GPU registers to set the inputs and GPU state.

   3 .  Does the GPU works like some state machine processing the commands generated by OpenGL/ES APIs?  
   4.   Does Mali 400MP has any Instruction-set like ARM Cortex CPUs? I think few GPGPUs have like NVIDIA, ATI/AMD.

   5.   What happens to Shader programs after they gets compiled? the compiled out put is some instructions for Shader-HW?
          Or some commands OR what ?

   6.How the parallelism is achieved in ARM MALI 400 MP GPU? Does it because we have multiple Pixel processors?

      I am not interested with GPGPU or GPComputing , Interested only Graphics content rendering case.
      I am trying to understand how GPU is performing better than CPU for graphics content creation?
      does GPU do some SIMD instruction execution like DSP?

Thanks,

Ravinder Are

Parents Reply Children
  • No no you don't get my point. I don't care about the insights of GPU design. I want to know if the Mali GPU was tailor towards the needs to support OpenGL ES? What can a GPU do to pass the "conformance tests"? I thought any GPU could be interfaced using OpenGL ES independent of its design.

  • What can a GPU do to pass the "conformance tests"?

    Implement the specification correctly.

    I thought any GPU could be interfaced using OpenGL ES independent of its design.

    Most GPUs are designed to meet the specifications they need to support (OpenGL, OpenGL ES, OpenCL, DirectX, etc). There is no point having hardware exposing features the APIs don't support, and a GPU which doesn't do what the specifications require isn't usable.

    You can't really separate the GPU design and the API specification - one is built to meet the needs of the other.

  • Peter Harris schrieb:

    You can't really separate the GPU design and the API specification - one is built to meet the needs of the other.

    Thank you, that is what I was looking for.

    I guess my assumptions where considerable in the beginning of openGL, where the HW was released before the first version of the API.

    Anyway, this topic is now clearer to me!

  • Peter Harris wrote:

    There is no point having hardware exposing features the APIs don't support

    I would just add that when the hardware supports functionality which is not exposed through the core GLES API, we and other vendors do sometimes expose new features via extensions, which are published and available at Khronos OpenGL ES Registry. Some of these extensions are vendor specific, while others are supported by multiple vendors.

    Hth,

    Chris

  • I'd add too that the GPU is also used more and more nowadays as a compute engine as well as for graphics. The requirements for things like OpenCL mean that for instance floating point is now IEEE conformant whereas when they were only used for graphics many GPUs did not bother doing rounding in accordance with the standard. This also provides extra impetus to the drive for memory coherence as in HSA between the GPU and the CPU.