On 12/20/2011 01:31 PM, Ian Romanick wrote:
From: Ian Romanick<ian.d.roman...@intel.com>

This won't be used in the client-side libGL, but the xserver has to
generate a different protocol error depending on the reason context
creation failed.

Signed-off-by: Ian Romanick<ian.d.roman...@intel.com>
---
  src/gallium/include/state_tracker/st_api.h         |   14 ++++++++++++++
  .../state_trackers/dri/common/dri_context.c        |    4 +++-
  src/gallium/state_trackers/vega/vg_manager.c       |   14 +++++++++++---
  src/mesa/state_tracker/st_manager.c                |    9 ++++++++-
  4 files changed, 36 insertions(+), 5 deletions(-)

diff --git a/src/gallium/include/state_tracker/st_api.h 
b/src/gallium/include/state_tracker/st_api.h
index 3267cb2..da49dc8 100644
--- a/src/gallium/include/state_tracker/st_api.h
+++ b/src/gallium/include/state_tracker/st_api.h
@@ -80,6 +80,19 @@ enum st_profile_type
  #define ST_CONTEXT_FLAG_ROBUST_ACCESS       (1<<  2)

  /**
+ * Reasons that context creation might fail.
+ */
+enum st_context_error {
+   ST_CONTEXT_SUCCESS = 0,
+   ST_CONTEXT_ERROR_NO_MEMORY,
+   ST_CONTEXT_ERROR_BAD_API,
+   ST_CONTEXT_ERROR_BAD_VERSION,
+   ST_CONTEXT_ERROR_BAD_FLAG,
+   ST_CONTEXT_ERROR_UNKNOWN_ATTRIBUTE,
+   ST_CONTEXT_ERROR_UNKNOWN_FLAG
+};
+
+/**
   * Used in st_context_iface->teximage.
   */
  enum st_texture_type {
@@ -434,6 +447,7 @@ struct st_api
     struct st_context_iface *(*create_context)(struct st_api *stapi,
                                                struct st_manager *smapi,
                                                const struct st_context_attribs 
*attribs,
+                                              enum st_context_error *error,
                                                struct st_context_iface 
*stsharei);

     /**
diff --git a/src/gallium/state_trackers/dri/common/dri_context.c 
b/src/gallium/state_trackers/dri/common/dri_context.c
index e9e0049..3e5a040 100644
--- a/src/gallium/state_trackers/dri/common/dri_context.c
+++ b/src/gallium/state_trackers/dri/common/dri_context.c
@@ -58,6 +58,7 @@ dri_create_context(gl_api api, const struct gl_config * 
visual,
     struct dri_context *ctx = NULL;
     struct st_context_iface *st_share = NULL;
     struct st_context_attribs attribs;
+   enum st_context_error ctx_err = 0;

     memset(&attribs, 0, sizeof(attribs));
     switch (api) {
@@ -88,7 +89,8 @@ dri_create_context(gl_api api, const struct gl_config * 
visual,
                &screen->optionCache, sPriv->myNum, "dri");

     dri_fill_st_visual(&attribs.visual, screen, visual);
-   ctx->st = stapi->create_context(stapi,&screen->base,&attribs, st_share);
+   ctx->st = stapi->create_context(stapi,&screen->base,&attribs,&ctx_err,
+                                  st_share);
     if (ctx->st == NULL)
        goto fail;
     ctx->st->st_manager_private = (void *) ctx;
diff --git a/src/gallium/state_trackers/vega/vg_manager.c 
b/src/gallium/state_trackers/vega/vg_manager.c
index dec1581..e88f5f1 100644
--- a/src/gallium/state_trackers/vega/vg_manager.c
+++ b/src/gallium/state_trackers/vega/vg_manager.c
@@ -163,28 +163,36 @@ vg_context_destroy(struct st_context_iface *stctxi)
  static struct st_context_iface *
  vg_api_create_context(struct st_api *stapi, struct st_manager *smapi,
                        const struct st_context_attribs *attribs,
+                      enum st_context_error *error,
                        struct st_context_iface *shared_stctxi)
  {
     struct vg_context *shared_ctx = (struct vg_context *) shared_stctxi;
     struct vg_context *ctx;
     struct pipe_context *pipe;

-   if (!(stapi->profile_mask&  (1<<  attribs->profile)))
+   if (!(stapi->profile_mask&  (1<<  attribs->profile))) {
+      *error = ST_CONTEXT_ERROR_BAD_API;
        return NULL;
+   }

     /* only 1.0 is supported */
-   if (attribs->major>  1 || (attribs->major == 1&&  attribs->minor>  0))
+   if (attribs->major>  1 || (attribs->major == 1&&  attribs->minor>  0)) {
+      *error = ST_CONTEXT_ERROR_BAD_VERSION;
        return NULL;
+   }

     /* for VGHandle / pointer lookups */
     init_handles();

     pipe = smapi->screen->context_create(smapi->screen, NULL);
-   if (!pipe)
+   if (!pipe) {
+      *error = ST_CONTEXT_ERROR_NO_MEMORY;
        return NULL;
+   }
     ctx = vg_create_context(pipe, NULL, shared_ctx);
     if (!ctx) {
        pipe->destroy(pipe);
+      *error = ST_CONTEXT_ERROR_NO_MEMORY;
        return NULL;
     }

diff --git a/src/mesa/state_tracker/st_manager.c 
b/src/mesa/state_tracker/st_manager.c
index 55699e7..828f0d8 100644
--- a/src/mesa/state_tracker/st_manager.c
+++ b/src/mesa/state_tracker/st_manager.c
@@ -600,6 +600,7 @@ st_context_destroy(struct st_context_iface *stctxi)
  static struct st_context_iface *
  st_api_create_context(struct st_api *stapi, struct st_manager *smapi,
                        const struct st_context_attribs *attribs,
+                      enum st_context_error *error,
                        struct st_context_iface *shared_stctxi)
  {
     struct st_context *shared_ctx = (struct st_context *) shared_stctxi;
@@ -623,17 +624,21 @@ st_api_create_context(struct st_api *stapi, struct 
st_manager *smapi,
        break;
     case ST_PROFILE_OPENGL_CORE:
     default:
+      *error = ST_CONTEXT_ERROR_BAD_API;
        return NULL;
        break;
     }

The 'break' is unreachable and could be removed.



     pipe = smapi->screen->context_create(smapi->screen, NULL);
-   if (!pipe)
+   if (!pipe) {
+      *error = ST_CONTEXT_ERROR_NO_MEMORY;
        return NULL;
+   }

     st_visual_to_context_mode(&attribs->visual,&mode);
     st = st_create_context(api, pipe,&mode, shared_ctx);
     if (!st) {
+      *error = ST_CONTEXT_ERROR_NO_MEMORY;
        pipe->destroy(pipe);
        return NULL;
     }
@@ -645,6 +650,7 @@ st_api_create_context(struct st_api *stapi, struct 
st_manager *smapi,
        /* is the actual version less than the requested version? */
        if (st->ctx->VersionMajor * 10 + st->ctx->VersionMinor<
            attribs->major * 10 + attribs->minor) {
+        *error = ST_CONTEXT_ERROR_BAD_VERSION;
           st_destroy_context(st);
           return NULL;
        }
@@ -660,6 +666,7 @@ st_api_create_context(struct st_api *stapi, struct 
st_manager *smapi,
     st->iface.share = st_context_share;
     st->iface.st_context_private = (void *) smapi;

+   *error = ST_CONTEXT_SUCCESS;
     return&st->iface;
  }


Reviewed-by: Brian Paul <bri...@vmware.com>
_______________________________________________
mesa-dev mailing list
mesa-dev@lists.freedesktop.org
http://lists.freedesktop.org/mailman/listinfo/mesa-dev

Reply via email to