r600g/llvm: Don't feed LLVM output through r600_bytecode_build()
[mesa.git] / src / gallium / drivers / r600 / r600_resource.c
index d9aa1df04f0369ad01c075dee6af5152de9bc3a2..5962f8ac1993b835cc14b19ff3be37f719af8330 100644 (file)
  * USE OR OTHER DEALINGS IN THE SOFTWARE.
  */
 
-#include "r600_context.h"
-#include "r600_resource.h"
-#include "r600_screen.h"
-#include "r600_texture.h"
+#include "r600_pipe.h"
+#include "evergreen_compute.h"
 
-static struct pipe_resource *
-r600_resource_create(struct pipe_screen *screen,
-                    const struct pipe_resource *templ)
+static struct pipe_resource *r600_resource_create(struct pipe_screen *screen,
+                                               const struct pipe_resource *templ)
 {
-   if (templ->target == PIPE_BUFFER)
-      return r600_buffer_create(screen, templ);
-   else
-      return r600_texture_create(screen, templ);
+       if (templ->target == PIPE_BUFFER) {
+               if (templ->bind & PIPE_BIND_GLOBAL) {
+                   return r600_compute_global_buffer_create(screen, templ);
+               }
+               else {
+                   return r600_buffer_create(screen, templ, 4096);
+               }
+       } else {
+               return r600_texture_create(screen, templ);
+       }
 }
 
-static struct pipe_resource *
-r600_resource_from_handle(struct pipe_screen * screen,
-                        const struct pipe_resource *templ,
-                        struct winsys_handle *whandle)
+static struct pipe_resource *r600_resource_from_handle(struct pipe_screen * screen,
+                                                       const struct pipe_resource *templ,
+                                                       struct winsys_handle *whandle)
 {
-   if (templ->target == PIPE_BUFFER)
-      return NULL;
-   else
-      return r600_texture_from_handle(screen, templ, whandle);
+       if (templ->target == PIPE_BUFFER) {
+               return NULL;
+       } else {
+               return r600_texture_from_handle(screen, templ, whandle);
+       }
 }
 
-void r600_init_context_resource_functions(struct r600_context *r600)
+void r600_resource_destroy(struct pipe_screen *screen, struct pipe_resource *res)
 {
-   r600->context.get_transfer = u_get_transfer_vtbl;
-   r600->context.transfer_map = u_transfer_map_vtbl;
-   r600->context.transfer_flush_region = u_transfer_flush_region_vtbl;
-   r600->context.transfer_unmap = u_transfer_unmap_vtbl;
-   r600->context.transfer_destroy = u_transfer_destroy_vtbl;
-   r600->context.transfer_inline_write = u_transfer_inline_write_vtbl;
-   r600->context.is_resource_referenced = u_is_resource_referenced_vtbl;
+       if (res->target == PIPE_BUFFER && (res->bind & PIPE_BIND_GLOBAL)) {
+               r600_compute_global_buffer_destroy(screen, res);
+       } else {
+               u_resource_destroy_vtbl(screen, res);
+       }
 }
 
-void r600_init_screen_resource_functions(struct r600_screen *r600screen)
+void r600_init_screen_resource_functions(struct pipe_screen *screen)
+{
+       screen->resource_create = r600_resource_create;
+       screen->resource_from_handle = r600_resource_from_handle;
+       screen->resource_get_handle = u_resource_get_handle_vtbl;
+       screen->resource_destroy = r600_resource_destroy;
+}
+
+void r600_init_context_resource_functions(struct r600_context *r600)
 {
-   r600screen->screen.resource_create = r600_resource_create;
-   r600screen->screen.resource_from_handle = r600_resource_from_handle;
-   r600screen->screen.resource_get_handle = u_resource_get_handle_vtbl;
-   r600screen->screen.resource_destroy = u_resource_destroy_vtbl;
-   r600screen->screen.user_buffer_create = r600_user_buffer_create;
+       r600->context.transfer_map = u_transfer_map_vtbl;
+       r600->context.transfer_flush_region = u_default_transfer_flush_region;
+       r600->context.transfer_unmap = u_transfer_unmap_vtbl;
+       r600->context.transfer_inline_write = u_default_transfer_inline_write;
 }