diff options
author | Ian Romanick <[email protected]> | 2011-12-13 15:46:20 -0800 |
---|---|---|
committer | Ian Romanick <[email protected]> | 2011-12-23 08:49:50 -0800 |
commit | d18152028e1825c05c7de33acacee3336350a096 (patch) | |
tree | cbfe88a4d0c18ff5e1c2d5ec4a4cf9eaf74875f2 /src/gallium/state_trackers/vega | |
parent | 358ecff1ea0fa8432fd46bd3deeb8d2d694b5550 (diff) |
st-api: Have context_create explain why creation failed
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 <[email protected]>
Reviewed-by: Brian Paul <[email protected]>
Reviewed-by: Chia-I Wu <[email protected]>
Diffstat (limited to 'src/gallium/state_trackers/vega')
-rw-r--r-- | src/gallium/state_trackers/vega/vg_manager.c | 14 |
1 files changed, 11 insertions, 3 deletions
diff --git a/src/gallium/state_trackers/vega/vg_manager.c b/src/gallium/state_trackers/vega/vg_manager.c index dec1581fb84..e88f5f17fe5 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; } |