1 /**************************************************************************
2  *
3  * Copyright 2009 VMware, Inc.
4  * All Rights Reserved.
5  *
6  * Permission is hereby granted, free of charge, to any person obtaining a
7  * copy of this software and associated documentation files (the
8  * "Software"), to deal in the Software without restriction, including
9  * without limitation the rights to use, copy, modify, merge, publish,
10  * distribute, sub license, and/or sell copies of the Software, and to
11  * permit persons to whom the Software is furnished to do so, subject to
12  * the following conditions:
13  *
14  * The above copyright notice and this permission notice (including the
15  * next paragraph) shall be included in all copies or substantial portions
16  * of the Software.
17  *
18  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
19  * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
20  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
21  * IN NO EVENT SHALL VMWARE AND/OR ITS SUPPLIERS BE LIABLE FOR
22  * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
23  * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
24  * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
25  *
26  **************************************************************************/
27 
28 #include "util/u_inlines.h"
29 #include "util/u_memory.h"
30 
31 #include "id_screen.h"
32 #include "id_objects.h"
33 #include "id_context.h"
34 
35 
36 
37 struct pipe_resource *
identity_resource_create(struct identity_screen * id_screen,struct pipe_resource * resource)38 identity_resource_create(struct identity_screen *id_screen,
39                         struct pipe_resource *resource)
40 {
41    struct identity_resource *id_resource;
42 
43    if(!resource)
44       goto error;
45 
46    assert(resource->screen == id_screen->screen);
47 
48    id_resource = CALLOC_STRUCT(identity_resource);
49    if(!id_resource)
50       goto error;
51 
52    memcpy(&id_resource->base, resource, sizeof(struct pipe_resource));
53 
54    pipe_reference_init(&id_resource->base.reference, 1);
55    id_resource->base.screen = &id_screen->base;
56    id_resource->resource = resource;
57 
58    return &id_resource->base;
59 
60 error:
61    pipe_resource_reference(&resource, NULL);
62    return NULL;
63 }
64 
65 void
identity_resource_destroy(struct identity_resource * id_resource)66 identity_resource_destroy(struct identity_resource *id_resource)
67 {
68    pipe_resource_reference(&id_resource->resource, NULL);
69    FREE(id_resource);
70 }
71 
72 
73 struct pipe_surface *
identity_surface_create(struct identity_context * id_context,struct identity_resource * id_resource,struct pipe_surface * surface)74 identity_surface_create(struct identity_context *id_context,
75                         struct identity_resource *id_resource,
76                         struct pipe_surface *surface)
77 {
78    struct identity_surface *id_surface;
79 
80    if(!surface)
81       goto error;
82 
83    assert(surface->texture == id_resource->resource);
84 
85    id_surface = CALLOC_STRUCT(identity_surface);
86    if(!id_surface)
87       goto error;
88 
89    memcpy(&id_surface->base, surface, sizeof(struct pipe_surface));
90 
91    pipe_reference_init(&id_surface->base.reference, 1);
92    id_surface->base.texture = NULL;
93    pipe_resource_reference(&id_surface->base.texture, &id_resource->base);
94    id_surface->surface = surface;
95 
96    return &id_surface->base;
97 
98 error:
99    pipe_surface_reference(&surface, NULL);
100    return NULL;
101 }
102 
103 void
identity_surface_destroy(struct identity_context * id_context,struct identity_surface * id_surface)104 identity_surface_destroy(struct identity_context *id_context,
105                          struct identity_surface *id_surface)
106 {
107    pipe_resource_reference(&id_surface->base.texture, NULL);
108    id_context->pipe->surface_destroy(id_context->pipe,
109                                      id_surface->surface);
110    FREE(id_surface);
111 }
112 
113 
114 struct pipe_sampler_view *
identity_sampler_view_create(struct identity_context * id_context,struct identity_resource * id_resource,struct pipe_sampler_view * view)115 identity_sampler_view_create(struct identity_context *id_context,
116                              struct identity_resource *id_resource,
117                              struct pipe_sampler_view *view)
118 {
119    struct identity_sampler_view *id_view;
120 
121    if (!view)
122       goto error;
123 
124    assert(view->texture == id_resource->resource);
125 
126    id_view = CALLOC_STRUCT(identity_sampler_view);
127 
128    id_view->base = *view;
129    id_view->base.reference.count = 1;
130    id_view->base.texture = NULL;
131    pipe_resource_reference(&id_view->base.texture, id_resource->resource);
132    id_view->base.context = id_context->pipe;
133    id_view->sampler_view = view;
134 
135    return &id_view->base;
136 error:
137    return NULL;
138 }
139 
140 void
identity_sampler_view_destroy(struct identity_context * id_context,struct identity_sampler_view * id_view)141 identity_sampler_view_destroy(struct identity_context *id_context,
142                               struct identity_sampler_view *id_view)
143 {
144    pipe_resource_reference(&id_view->base.texture, NULL);
145    id_context->pipe->sampler_view_destroy(id_context->pipe,
146                                           id_view->sampler_view);
147    FREE(id_view);
148 }
149 
150 
151 struct pipe_transfer *
identity_transfer_create(struct identity_context * id_context,struct identity_resource * id_resource,struct pipe_transfer * transfer)152 identity_transfer_create(struct identity_context *id_context,
153                          struct identity_resource *id_resource,
154                          struct pipe_transfer *transfer)
155 {
156    struct identity_transfer *id_transfer;
157 
158    if(!transfer)
159       goto error;
160 
161    assert(transfer->resource == id_resource->resource);
162 
163    id_transfer = CALLOC_STRUCT(identity_transfer);
164    if(!id_transfer)
165       goto error;
166 
167    memcpy(&id_transfer->base, transfer, sizeof(struct pipe_transfer));
168 
169    id_transfer->base.resource = NULL;
170    id_transfer->transfer = transfer;
171 
172    pipe_resource_reference(&id_transfer->base.resource, &id_resource->base);
173    assert(id_transfer->base.resource == &id_resource->base);
174 
175    return &id_transfer->base;
176 
177 error:
178    id_context->pipe->transfer_destroy(id_context->pipe, transfer);
179    return NULL;
180 }
181 
182 void
identity_transfer_destroy(struct identity_context * id_context,struct identity_transfer * id_transfer)183 identity_transfer_destroy(struct identity_context *id_context,
184                           struct identity_transfer *id_transfer)
185 {
186    pipe_resource_reference(&id_transfer->base.resource, NULL);
187    id_context->pipe->transfer_destroy(id_context->pipe,
188                                       id_transfer->transfer);
189    FREE(id_transfer);
190 }
191 
192