Name
    EXT_platform_base
Name Strings
    EGL_EXT_platform_base
Contributors
    Chad Versace <chad.versace@intel.com>
    James Jones <jajones@nvidia.com>
Contacts
    Chad Versace <chad.versace@intel.com>
Status
    Complete
Version
    Version 9, 2014.01.09
Number
    EGL Extension #57
Extension Type
    EGL client extension
Dependencies
    Requires EGL 1.4.
    Requires EGL_EXT_client_extensions to query its existence without
    a display.
    This extension is written against the wording of the 2013.02.11 revision
    of the EGL 1.4 Specification.
Overview
    This extension defines functionality and behavior for EGL implementations
    that support multiple platforms at runtime. For example, on Linux an EGL
    implementation could support X11, Wayland, GBM (Generic Buffer Manager),
    Surface Flinger, and perhaps other platforms.
    In particular, this extension defines the following:
        1. A mechanism by which an EGL client can detect which platforms the
           EGL implementation supports.
        2. New functions that enable an EGL client to specify to which
           platform a native resource belongs when creating an EGL resource
           from that native resource.  For example, this extension enables an
           EGL client to specify, when creating an EGLSurface from a native
           window, that the window belongs to X11.
        3. That an EGL client is not restricted to interacting with a single
           platform per process. A client process can create and manage EGL
           resources from multiple platforms.
    The generic term 'platform' is used throughout this extension
    specification rather than 'window system' because not all EGL platforms
    are window systems. In particular, those platforms that allow headless
    rendering without a display server, such as GBM, are not window systems.
    This extension does not specify behavior specific to any platform, nor
    does it specify the set of platforms that an EGL implementation may
    support. Platform-specific details lie outside this extension's scope and
    are instead described by extensions layered atop this one.
New Types
    None
New Procedures and Functions
    EGLDisplay eglGetPlatformDisplayEXT(
        EGLenum platform,
        void *native_display,
        const EGLint *attrib_list);
    EGLSurface eglCreatePlatformWindowSurfaceEXT(
        EGLDisplay dpy,
        EGLConfig config,
        void *native_window,
        const EGLint *attrib_list);
    EGLSurface eglCreatePlatformPixmapSurfaceEXT(
        EGLDisplay dpy,
        EGLConfig config,
        void *native_pixmap,
        const EGLint *attrib_list);
New Tokens
    None
Additions to the EGL 1.4 Specification
    Replace each occurence of the term "window system" with "platform".  The
    rationale behind this change is that not all platforms are window systems,
    yet the EGL 1.4 specification uses the two terms interchangeably.  In
    particular, platforms that allow headless rendering without a display
    server, such as GBM, are not window systems.
    Append the following paragraph to the initial, unnamed subsection of
    section 2.1 "Native Window System and Rendering APIs".
    "This specification does not define the set of platforms that may be
    supported by the EGL implementation, nor does it specify behavior specific
    to any platform. The set of supported platforms and their behavior is
    defined by extensions. To detect if a particular platform is supported,
    clients should query the EGL_EXTENSIONS string of EGL_NO_DISPLAY using
    eglQueryString.
    Replace the text of section 3.2 "Initialization", from the start of the
    section and up to and excluding the phrase "EGL may be intialized on
    a display", with the following:
    "A display can be obtained by calling
        EGLDisplay eglGetPlatformDisplayEXT(
            EGLenum platform,
            void *native_display,
            const EGLint *attrib_list);
    EGL considers the returned EGLDisplay as belonging to the native platform
    specified by <platform>.  This specification defines no valid value for
    <platform>. Any specification that does define a valid value for
    <platform> will also define requirements for the <native_display>
    parameter. For example, an extension specification that defines support
    for the X11 platform may require that <native_display> be a pointer to an
    X11 Display, and an extension specification that defines support for the
    Microsoft Windows platform may require that <native_display> be a pointer
    to a Windows Device Context.
    All attribute names in <attrib_list> are immediately followed by the
    corresponding desired value. The list is terminated with EGL_NONE. The
    <attrib_list> is considered empty if either <attrib_list> is NULL or if
    its first element is EGL_NONE. This specification defines no valid
    attribute names for <attrib_list>.
    Multiple calls made to eglGetPlatformDisplayEXT with the same <platform>
    and <native_display> will return the same EGLDisplay handle.
    An EGL_BAD_PARAMETER error is generated if <platform> has an invalid value.
    If <platform> is valid but no display matching <native_display> is
    available, then EGL_NO_DISPLAY is returned; no error condition is raised
    in this case.
    A display can also be obtained by calling
        EGLDisplay eglGetDisplay(EGLNativeDisplayType display_id);
    The behavior of eglGetDisplay is similar to that of
    eglGetPlatformDisplayEXT, but is specifided in terms of implementation-
    specific behavior rather than platform-specific extensions.
    As for eglGetPlatformDisplayEXT, EGL considers the returned EGLDisplay
    as belonging to the same platform as <display_id>. However, the set of
    platforms to which <display_id> is permitted to belong, as well as the
    actual type of <display_id>, are implementation-specific.  If <display_id>
    is EGL_DEFAULT_DISPLAY, a default display is returned.  Multiple calls
    made to eglGetDisplay with the same <display_id> will return the same
    EGLDisplay handle.  If no display matching <display_id> is available,
    EGL_NO_DISPLAY is returned; no error condition is raised in this case."
    In section 3.5.1 "Creating On-Screen Rendering Surfaces", replace the
    second paragraph, which begins with "Using the platform-specific type" and
    ends with "render into this surface", with the following:
    "Then call
        EGLSurface eglCreatePlatformWindowSurfaceEXT(
            EGLDisplay dpy,
            EGLConfig config,
            void *native_window,
            const EGLint *attrib_list);
    eglCreatePlatformWindowSurfaceEXT creates an onscreen EGLSurface and
    returns a handle to it. Any EGL context created with a compatible
    EGLConfig can be used to render into this surface.
    <native_window> must belong to the same platform as <dpy>, and EGL
    considers the returned EGLSurface as belonging to that same platform.  The
    extension that defines the platform to which <dpy> belongs also defines
    the requirements for the <native_window> parameter."
    In the remainder of section 3.5.1, replace each occurrence of
    'eglCreateWindowSurface' with 'eglCreatePlatformWindowSurfaceEXT'.
    Insert the sentence below after the first sentence of the last paragraph
    of section 3.5.1:
    "If <dpy> and <native_window> do not belong to the same platform, then
    undefined behavior occurs. [1]"
    Add the following footnote to section 3.5.1:
    "[1] See section 3.1.0.2 "Parameter Validation".
    Append the following to section 3.5.1:
    "An on-screen rendering surface may also be created by calling
        EGLSurface eglCreateWindowSurface(
            EGLDisplay dpy,
            EGLConfig config,
            EGLNativeWindowType win,
            const EGLint *attrib_list);
    The behavior of eglCreateWindowSurface is identical to that of
    eglCreatePlatformWindowSurfaceEXT except that the set of platforms to
    which <dpy> is permitted to belong, as well as the actual type of <win>,
    are implementation specific.
    In section 3.5.4 "Creating Native Pixmap Rendering Surfaces", replace the
    third paragraph, which begins with "Using the platform-specific type" and
    ends with "render into this surface", with the following:
    "Then call
        EGLSurface eglCreatePlatformPixmapSurfaceEXT(
            EGLDisplay dpy,
            EGLConfig config,
            void *native_pixmap,
            const EGLint *attrib_list);
    eglCreatePlatformPixmapSurfaceEXT creates an offscreen EGLSurface and
    returns a handle to it. Any EGL context created with a compatible
    EGLConfig can be used to render into this surface.
    <native_pixmap> must belong to the same platform as <dpy>, and EGL
    considers the returned EGLSurface as belonging to that same platform.  The
    extension that defines the platform to which <dpy> belongs also defines
    the requirements for the <native_pixmap> parameter."
    In the remainder of section 3.5.4, replace each occurrence of
    'eglCreatePixmapSurface' with 'eglCreatePlatformPixmapSurfaceEXT' and each
    occurence of 'eglCreateWindowSurface' with
    'eglCreatePlatformWindowSurfaceEXT'.
    Insert the sentence below after the first sentence of the last paragraph
    of section 3.5.4:
    "If <dpy> and <native_pixmap> do not belong to the same platform, then
    undefined behavior occurs. [1]"
    Add the following footnote to section 3.5.3:
    "[1] See section 3.1.0.2 "Parameter Validation".
    Append the following to section 3.5.2:
    "An offscreen rendering surface may also be created by calling
        EGLSurface eglCreatePixmapSurface(
            EGLDisplay dpy,
            EGLConfig config,
            EGLNativePixmapType pixmap,
            const EGLint *attrib_list);
    The behavior of eglCreatePixmapSurface is identical to that of
    eglCreatePlatformPixmapSurfaceEXT except that the set of platforms to
    which <dpy> is permitted to belong, as well as the actual type of
    <pixmap>, are implementation specific.
Issues
    1. What rules define how EGL resources are shared among displays belonging
       to different platforms?
       RESOLVED: Neither the EGL 1.4 specification nor any extension allow EGL
       resources to be shared among displays. This extension does not remove
       that restriction.
    2. Rather than define the new function eglGetPlatformDisplayEXT(), should
       this extension instead define new thread-local state for the currently
       bound platform and an associated binding function, such as
       eglBindPlatformEXT()?
       RESOLVED: No, for the following reasons.
            - A current trend among the Khronos workgroups is to remove use of
              global state by introducing bindless objects. Introducing a new
              thread-local binding point defies that trend.
            - Additional specification language would be required to define
              the interactions between the currently bound platform and all
              EGL functions that accept an EGLDisplay. (For example, if the
              currently bound platform is Wayland, then what is the result of
              calling eglCreateWindowSurface() with a display and native
              window belonging to X11?) By choosing to not introduce the
              notion of a "currently bound platform", we obtain a cleaner
              extension specification and eliminate for EGL users a class of
              potential bugs.
    3. Should this extension define the notion of a default platform?
       RESOLVED: No. eglGetDisplay() can be used if a default platform is
       needed.
    4. Rather than define the new functions
       eglCreatePlatform{Window,Pixmap}SurfaceEXT(), should we instead
       redefine the EGLNative* types in eglplatform.h as void*?
       RESOLVED: No, this introduces problems for X11 applications.
       Suppose that a 64-bit X11 application is compiled against an old EGL
       library (where EGLNativeWindowType is a typedef for XID, which is in
       turn a typedef for a 64-bit unsigned integer on Fedora 18) and then
       attempts to run against a new EGL library (where EGLNativeType is
       a typedef for void*).  To preserve the ABI of eglCreateWindowSurface()
       in this situation, the new EGL library must re-interpret the
       <native_window> parameter as an integer.
       However, this preservation of the ABI breaks source compatibility for
       existing X11 applications. To successfully compile, each call to
            eglCreateWindowSurface(dpy, window, attribs)
       in existing X11 application source code would need to be replaced with
            eglCreateWindowSurface(dpy, (void*) window, attribs) .
       Requiring such widespread code modifications would be an unnecessary
       burden to developers and Linux package maintainers.
Revision History
    Version 9, 2014.01.09 (Jon Leech)
        - Fix typo eglGetDisplayPlatformEXT -> eglGetPlatformDisplayEXT
    Version 8, 2013.07.03 (Chad Versace)
        - Add "Extension Type" section, required by EGL_EXT_client_extensions v9.
    Version 7, 2013.06.07 (Chad Versace)
        - Fix some awkward text (s/the EGL/EGL/).
        - Remove text "attribute names are defined by platform-specific
          extensions".
    Version 6, 2013.06.07 (Chad Versace)
        - To "Dependencies" section, expand text that discusses
          EGL_EXT_client_extensions.
    Version 5, 2013.05.18 (Chad Versace)
        - Removed restriction that "attribute names are defined only by
          platform-specific extensions".
        - Resolve issue 3 as NO.
        - Clarified some text and fixed grammatical errors.
    Version 4, 2013.05.14 (Chad Versace)
        - Add <attrib_list> parameter to eglGetPlatformDisplayEXT, per
          feedback at the April Khronos F2F.
    Version 3, 2013.04.26 (Chad Versace)
        - Add issues 2, 3, 4.
    Version 2, 2013.03.24 (Chad Versace)
        - Complete draft by adding text for pixmaps.
        - The footnotes regarding undefined behavior, simplify them by
          simply referring to section 3.1.0.2.
        - Add issue 1 from Eric Anholt <eric@anholt.net>.
        - Fix spelling and formatting errors.
    Version 1, 2013.03.13 (Chad Versace)
        - Incomplete draft posted for review