diff --git a/.cvsignore b/.cvsignore index 930ee6c..71baad4 100644 --- a/.cvsignore +++ b/.cvsignore @@ -1 +1 @@ -libdrm-20080930.tar.bz2 +libdrm-2.4.3.tar.bz2 diff --git a/libdrm-2.4.0-intel-handle.patch b/libdrm-2.4.0-intel-handle.patch deleted file mode 100644 index f9bb5a8..0000000 --- a/libdrm-2.4.0-intel-handle.patch +++ /dev/null @@ -1,44 +0,0 @@ -From af2323b4b3b76070fb453531147a8956161b3718 Mon Sep 17 00:00:00 2001 -From: Jesse Barnes -Date: Tue, 30 Sep 2008 16:35:26 -0700 -Subject: [PATCH] intel bufmgr: reinstate buffer handle tracking - -We need a way of getting at the underlying handle for use with mode -setting. We can either export it in the dri_bo object or provide a new -callback to get it. ---- - libdrm/intel/intel_bufmgr.h | 4 ++++ - libdrm/intel/intel_bufmgr_gem.c | 2 +- - 2 files changed, 5 insertions(+), 1 deletions(-) - -diff --git a/libdrm/intel/intel_bufmgr.h b/libdrm/intel/intel_bufmgr.h -index c44d596..67dba6a 100644 ---- a/libdrm/intel/intel_bufmgr.h -+++ b/libdrm/intel/intel_bufmgr.h -@@ -59,6 +59,10 @@ struct _dri_bo { - - /** Buffer manager context associated with this buffer object */ - dri_bufmgr *bufmgr; -+ /** -+ * MM-specific handle for accessing object -+ */ -+ int handle; - }; - - dri_bo *dri_bo_alloc(dri_bufmgr *bufmgr, const char *name, unsigned long size, -diff --git a/libdrm/intel/intel_bufmgr_gem.c b/libdrm/intel/intel_bufmgr_gem.c -index 4ca49d0..70cdca7 100644 ---- a/libdrm/intel/intel_bufmgr_gem.c -+++ b/libdrm/intel/intel_bufmgr_gem.c -@@ -316,7 +316,7 @@ dri_gem_bo_alloc(dri_bufmgr *bufmgr, const char *name, - - ret = ioctl(bufmgr_gem->fd, DRM_IOCTL_I915_GEM_CREATE, &create); - bo_gem->gem_handle = create.handle; -- //bo_gem->bo.handle = bo_gem->gem_handle; -+ bo_gem->bo.handle = bo_gem->gem_handle; - if (ret != 0) { - free(bo_gem); - return NULL; --- -1.5.5.1 - diff --git a/libdrm-fix-link.patch b/libdrm-fix-link.patch deleted file mode 100644 index e4c6a94..0000000 --- a/libdrm-fix-link.patch +++ /dev/null @@ -1,11 +0,0 @@ -diff -up libdrm-20080930/libdrm/Makefile.am.fixlink libdrm-20080930/libdrm/Makefile.am ---- libdrm-20080930/libdrm/Makefile.am.fixlink 2008-10-01 11:18:36.000000000 +1000 -+++ libdrm-20080930/libdrm/Makefile.am 2008-10-01 11:18:44.000000000 +1000 -@@ -27,7 +27,6 @@ libdrm_la_LDFLAGS = -version-number 2:3: - AM_CFLAGS = -I$(top_srcdir)/shared-core - libdrm_la_SOURCES = xf86drm.c xf86drmHash.c xf86drmRandom.c xf86drmSL.c \ - xf86drmMode.c --libdrm_la_LIBADD = intel/libdrm_intel.la - - libdrmincludedir = ${includedir} - libdrminclude_HEADERS = xf86drm.h xf86drmMode.h diff --git a/libdrm-gtt-map-support-3.patch b/libdrm-gtt-map-support-3.patch deleted file mode 100644 index dcaa920..0000000 --- a/libdrm-gtt-map-support-3.patch +++ /dev/null @@ -1,252 +0,0 @@ -diff -up libdrm-20080930/libdrm/intel/intel_bufmgr_gem.c.gttmap libdrm-20080930/libdrm/intel/intel_bufmgr_gem.c ---- libdrm-20080930/libdrm/intel/intel_bufmgr_gem.c.gttmap 2008-09-30 14:17:27.000000000 +1000 -+++ libdrm-20080930/libdrm/intel/intel_bufmgr_gem.c 2008-09-30 17:35:51.000000000 +1000 -@@ -39,6 +39,7 @@ - #endif - - #include -+#include - #include - #include - #include -@@ -46,6 +47,8 @@ - #include - #include - #include -+#include -+#include - - #include "errno.h" - #include "intel_bufmgr.h" -@@ -518,6 +521,90 @@ dri_gem_bo_map(dri_bo *bo, int write_ena - return 0; - } - -+int -+dri_gem_bo_map_gtt(dri_bo *bo) -+{ -+ dri_bufmgr_gem *bufmgr_gem; -+ dri_bo_gem *bo_gem = (dri_bo_gem *)bo; -+ struct drm_i915_gem_set_domain set_domain; -+ int ret; -+ int fd; -+ -+ bufmgr_gem = (dri_bufmgr_gem *)bo->bufmgr; -+ -+ /* Allow recursive mapping. Mesa may recursively map buffers with -+ * nested display loops. -+ */ -+ if (!bo_gem->mapped) { -+ -+ assert(bo->virtual == NULL); -+ -+ DBG("bo_map_gtt: %d (%s)\n", bo_gem->gem_handle, bo_gem->name); -+ -+ if (bo_gem->virtual == NULL) { -+ struct drm_i915_gem_mmap_gtt mmap_arg; -+ -+ memset(&mmap_arg, 0, sizeof(mmap_arg)); -+ mmap_arg.handle = bo_gem->gem_handle; -+ mmap_arg.offset = 0; -+ mmap_arg.size = bo->size; -+ ret = ioctl(bufmgr_gem->fd, DRM_IOCTL_I915_GEM_MMAP_GTT, -+ &mmap_arg); -+ if (ret != 0) { -+ fprintf(stderr, -+ "%s:%d: Error mapping buffer %d (%s): %s .\n", -+ __FILE__, __LINE__, -+ bo_gem->gem_handle, bo_gem->name, -+ strerror(errno)); -+ return ret; -+ } -+ bo_gem->virtual = (void *)(uintptr_t)mmap_arg.addr_ptr; -+ } -+#if 0 -+ if (bo_gem->virtual == NULL) { -+ fd = open("/sys/devices/pci0000:00/0000:00:02.0/resource2_wc", -+ O_RDWR); -+ if (fd == -1) { -+ fprintf(stderr, "failed to open GTT: %s\n", -+ strerror(errno)); -+ return errno; -+ } -+ -+ bo_gem->virtual = mmap(NULL, bo->size, PROT_READ | PROT_WRITE, -+ MAP_SHARED, fd, bo->offset); -+ if (bo_gem->virtual == MAP_FAILED) { -+ fprintf(stderr, "failed to map GTT: %s\n", -+ strerror(errno)); -+ return errno; -+ } -+ close(fd); -+ } -+#endif -+ bo->virtual = bo_gem->virtual; -+ bo_gem->swrast = 0; -+ bo_gem->mapped = 1; -+ DBG("bo_map: %d (%s) -> %p\n", bo_gem->gem_handle, bo_gem->name, -+ bo_gem->virtual); -+ } -+ -+ if (!bo_gem->swrast) { -+ set_domain.handle = bo_gem->gem_handle; -+ set_domain.read_domains = I915_GEM_DOMAIN_GTT; -+ set_domain.write_domain = I915_GEM_DOMAIN_GTT; -+ do { -+ ret = ioctl(bufmgr_gem->fd, DRM_IOCTL_I915_GEM_SET_DOMAIN, -+ &set_domain); -+ } while (ret == -1 && errno == EINTR); -+ if (ret != 0) { -+ fprintf (stderr, "%s:%d: Error setting swrast %d: %s\n", -+ __FILE__, __LINE__, bo_gem->gem_handle, strerror (errno)); -+ } -+ bo_gem->swrast = 1; -+ } -+ -+ return 0; -+} -+ - static int - dri_gem_bo_unmap(dri_bo *bo) - { -@@ -594,7 +681,7 @@ dri_gem_bo_get_subdata (dri_bo *bo, unsi - return 0; - } - --static void -+void - dri_gem_bo_wait_rendering(dri_bo *bo) - { - dri_bufmgr_gem *bufmgr_gem = (dri_bufmgr_gem *)bo->bufmgr; -diff -up libdrm-20080930/libdrm/intel/intel_bufmgr.h.gttmap libdrm-20080930/libdrm/intel/intel_bufmgr.h ---- libdrm-20080930/libdrm/intel/intel_bufmgr.h.gttmap 2008-09-30 14:17:27.000000000 +1000 -+++ libdrm-20080930/libdrm/intel/intel_bufmgr.h 2008-09-30 17:34:10.000000000 +1000 -@@ -89,6 +89,8 @@ int dri_bo_unpin(dri_bo *buf); - int dri_bo_set_tiling(dri_bo *buf, uint32_t *tiling_mode); - int dri_bo_flink(dri_bo *buf, uint32_t *name); - -+int dri_gem_bo_map_gtt(dri_bo *bo); -+ - /* intel_bufmgr_gem.c */ - dri_bufmgr *intel_bufmgr_gem_init(int fd, int batch_size); - dri_bo *intel_bo_gem_create_from_name(dri_bufmgr *bufmgr, const char *name, -diff -up libdrm-20080930/shared-core/i915_drm.h.gttmap libdrm-20080930/shared-core/i915_drm.h ---- libdrm-20080930/shared-core/i915_drm.h.gttmap 2008-09-30 14:17:27.000000000 +1000 -+++ libdrm-20080930/shared-core/i915_drm.h 2008-09-30 17:01:13.000000000 +1000 -@@ -99,7 +99,7 @@ typedef struct drm_i915_sarea { - int tex_size; - int log_tex_granularity; - int pitch; -- int rotation; /* 0, 90, 180 or 270 */ -+ int rotation; /* 0, 90, 180 or 270 */ - int rotated_offset; - int rotated_size; - int rotated_pitch; -@@ -149,8 +149,8 @@ typedef struct drm_i915_sarea { - /* Flags for perf_boxes - */ - #define I915_BOX_RING_EMPTY 0x1 --#define I915_BOX_FLIP 0x2 --#define I915_BOX_WAIT 0x4 -+#define I915_BOX_FLIP 0x2 -+#define I915_BOX_WAIT 0x4 - #define I915_BOX_TEXTURE_LOAD 0x8 - #define I915_BOX_LOST_CONTEXT 0x10 - -@@ -192,24 +192,25 @@ typedef struct drm_i915_sarea { - #define DRM_I915_GEM_SW_FINISH 0x20 - #define DRM_I915_GEM_SET_TILING 0x21 - #define DRM_I915_GEM_GET_TILING 0x22 -+#define DRM_I915_GEM_MMAP_GTT 0x23 - - #define DRM_IOCTL_I915_INIT DRM_IOW( DRM_COMMAND_BASE + DRM_I915_INIT, drm_i915_init_t) - #define DRM_IOCTL_I915_FLUSH DRM_IO ( DRM_COMMAND_BASE + DRM_I915_FLUSH) - #define DRM_IOCTL_I915_FLIP DRM_IOW( DRM_COMMAND_BASE + DRM_I915_FLIP, drm_i915_flip_t) - #define DRM_IOCTL_I915_BATCHBUFFER DRM_IOW( DRM_COMMAND_BASE + DRM_I915_BATCHBUFFER, drm_i915_batchbuffer_t) --#define DRM_IOCTL_I915_IRQ_EMIT DRM_IOWR(DRM_COMMAND_BASE + DRM_I915_IRQ_EMIT, drm_i915_irq_emit_t) --#define DRM_IOCTL_I915_IRQ_WAIT DRM_IOW( DRM_COMMAND_BASE + DRM_I915_IRQ_WAIT, drm_i915_irq_wait_t) --#define DRM_IOCTL_I915_GETPARAM DRM_IOWR(DRM_COMMAND_BASE + DRM_I915_GETPARAM, drm_i915_getparam_t) --#define DRM_IOCTL_I915_SETPARAM DRM_IOW( DRM_COMMAND_BASE + DRM_I915_SETPARAM, drm_i915_setparam_t) --#define DRM_IOCTL_I915_ALLOC DRM_IOWR(DRM_COMMAND_BASE + DRM_I915_ALLOC, drm_i915_mem_alloc_t) --#define DRM_IOCTL_I915_FREE DRM_IOW( DRM_COMMAND_BASE + DRM_I915_FREE, drm_i915_mem_free_t) --#define DRM_IOCTL_I915_INIT_HEAP DRM_IOW( DRM_COMMAND_BASE + DRM_I915_INIT_HEAP, drm_i915_mem_init_heap_t) -+#define DRM_IOCTL_I915_IRQ_EMIT DRM_IOWR(DRM_COMMAND_BASE + DRM_I915_IRQ_EMIT, drm_i915_irq_emit_t) -+#define DRM_IOCTL_I915_IRQ_WAIT DRM_IOW( DRM_COMMAND_BASE + DRM_I915_IRQ_WAIT, drm_i915_irq_wait_t) -+#define DRM_IOCTL_I915_GETPARAM DRM_IOWR(DRM_COMMAND_BASE + DRM_I915_GETPARAM, drm_i915_getparam_t) -+#define DRM_IOCTL_I915_SETPARAM DRM_IOW( DRM_COMMAND_BASE + DRM_I915_SETPARAM, drm_i915_setparam_t) -+#define DRM_IOCTL_I915_ALLOC DRM_IOWR(DRM_COMMAND_BASE + DRM_I915_ALLOC, drm_i915_mem_alloc_t) -+#define DRM_IOCTL_I915_FREE DRM_IOW( DRM_COMMAND_BASE + DRM_I915_FREE, drm_i915_mem_free_t) -+#define DRM_IOCTL_I915_INIT_HEAP DRM_IOW( DRM_COMMAND_BASE + DRM_I915_INIT_HEAP, drm_i915_mem_init_heap_t) - #define DRM_IOCTL_I915_CMDBUFFER DRM_IOW( DRM_COMMAND_BASE + DRM_I915_CMDBUFFER, drm_i915_cmdbuffer_t) - #define DRM_IOCTL_I915_DESTROY_HEAP DRM_IOW( DRM_COMMAND_BASE + DRM_I915_DESTROY_HEAP, drm_i915_mem_destroy_heap_t) - #define DRM_IOCTL_I915_SET_VBLANK_PIPE DRM_IOW( DRM_COMMAND_BASE + DRM_I915_SET_VBLANK_PIPE, drm_i915_vblank_pipe_t) - #define DRM_IOCTL_I915_GET_VBLANK_PIPE DRM_IOR( DRM_COMMAND_BASE + DRM_I915_GET_VBLANK_PIPE, drm_i915_vblank_pipe_t) - #define DRM_IOCTL_I915_VBLANK_SWAP DRM_IOWR(DRM_COMMAND_BASE + DRM_I915_VBLANK_SWAP, drm_i915_vblank_swap_t) --#define DRM_IOCTL_I915_MMIO DRM_IOWR(DRM_COMMAND_BASE + DRM_I915_MMIO, drm_i915_mmio) -+#define DRM_IOCTL_I915_MMIO DRM_IOWR(DRM_COMMAND_BASE + DRM_I915_MMIO, drm_i915_mmio) - #define DRM_IOCTL_I915_EXECBUFFER DRM_IOWR(DRM_COMMAND_BASE + DRM_I915_EXECBUFFER, struct drm_i915_execbuffer) - #define DRM_IOCTL_I915_GEM_INIT DRM_IOW(DRM_COMMAND_BASE + DRM_I915_GEM_INIT, struct drm_i915_gem_init) - #define DRM_IOCTL_I915_GEM_EXECBUFFER DRM_IOW(DRM_COMMAND_BASE + DRM_I915_GEM_EXECBUFFER, struct drm_i915_gem_execbuffer) -@@ -223,6 +224,7 @@ typedef struct drm_i915_sarea { - #define DRM_IOCTL_I915_GEM_PREAD DRM_IOW (DRM_COMMAND_BASE + DRM_I915_GEM_PREAD, struct drm_i915_gem_pread) - #define DRM_IOCTL_I915_GEM_PWRITE DRM_IOW (DRM_COMMAND_BASE + DRM_I915_GEM_PWRITE, struct drm_i915_gem_pwrite) - #define DRM_IOCTL_I915_GEM_MMAP DRM_IOWR(DRM_COMMAND_BASE + DRM_I915_GEM_MMAP, struct drm_i915_gem_mmap) -+#define DRM_IOCTL_I915_GEM_MMAP_GTT DRM_IOWR(DRM_COMMAND_BASE + DRM_I915_GEM_MMAP_GTT, struct drm_i915_gem_mmap_gtt) - #define DRM_IOCTL_I915_GEM_SET_DOMAIN DRM_IOW (DRM_COMMAND_BASE + DRM_I915_GEM_SET_DOMAIN, struct drm_i915_gem_set_domain) - #define DRM_IOCTL_I915_GEM_SW_FINISH DRM_IOW (DRM_COMMAND_BASE + DRM_I915_GEM_SW_FINISH, struct drm_i915_gem_sw_finish) - #define DRM_IOCTL_I915_GEM_SET_TILING DRM_IOWR (DRM_COMMAND_BASE + DRM_I915_GEM_SET_TILING, struct drm_i915_gem_set_tiling) -@@ -276,11 +278,11 @@ typedef struct drm_i915_irq_wait { - - /* Ioctl to query kernel params: - */ --#define I915_PARAM_IRQ_ACTIVE 1 -+#define I915_PARAM_IRQ_ACTIVE 1 - #define I915_PARAM_ALLOW_BATCHBUFFER 2 --#define I915_PARAM_LAST_DISPATCH 3 --#define I915_PARAM_CHIPSET_ID 4 --#define I915_PARAM_HAS_GEM 5 -+#define I915_PARAM_LAST_DISPATCH 3 -+#define I915_PARAM_CHIPSET_ID 4 -+#define I915_PARAM_HAS_GEM 5 - - typedef struct drm_i915_getparam { - int param; -@@ -289,9 +291,9 @@ typedef struct drm_i915_getparam { - - /* Ioctl to set kernel params: - */ --#define I915_SETPARAM_USE_MI_BATCHBUFFER_START 1 --#define I915_SETPARAM_TEX_LRU_LOG_GRANULARITY 2 --#define I915_SETPARAM_ALLOW_BATCHBUFFER 3 -+#define I915_SETPARAM_USE_MI_BATCHBUFFER_START 1 -+#define I915_SETPARAM_TEX_LRU_LOG_GRANULARITY 2 -+#define I915_SETPARAM_ALLOW_BATCHBUFFER 3 - - typedef struct drm_i915_setparam { - int param; -@@ -460,6 +462,25 @@ struct drm_i915_gem_set_domain { - uint32_t write_domain; - }; - -+struct drm_i915_gem_mmap_gtt { -+ /** Handle for the object being mapped. */ -+ uint32_t handle; -+ uint32_t pad; -+ /** Offset in the object to map. */ -+ uint64_t offset; -+ /** -+ * Length of data to map. -+ * -+ * The value will be page-aligned. -+ */ -+ uint64_t size; -+ /** Returned pointer the data was mapped at */ -+ uint64_t addr_ptr; /* void *, but pointers are not 32/64 compatible -+ */ -+ uint32_t flags; -+}; -+ -+ - struct drm_i915_gem_sw_finish { - /** Handle for the object */ - uint32_t handle; diff --git a/libdrm-radeon.patch b/libdrm-radeon.patch new file mode 100644 index 0000000..999fac7 --- /dev/null +++ b/libdrm-radeon.patch @@ -0,0 +1,1527 @@ +diff -up libdrm-2.4.3/configure.ac.radeon libdrm-2.4.3/configure.ac +--- libdrm-2.4.3/configure.ac.radeon 2008-12-19 16:41:39.000000000 +1000 ++++ libdrm-2.4.3/configure.ac 2008-12-19 16:41:41.000000000 +1000 +@@ -117,6 +117,7 @@ AC_OUTPUT([ + Makefile + libdrm/Makefile + libdrm/intel/Makefile ++ libdrm/radeon/Makefile + shared-core/Makefile + tests/Makefile + tests/modeprint/Makefile +diff -up libdrm-2.4.3/libdrm/Makefile.am.radeon libdrm-2.4.3/libdrm/Makefile.am +--- libdrm-2.4.3/libdrm/Makefile.am.radeon 2008-12-19 14:33:38.000000000 +1000 ++++ libdrm-2.4.3/libdrm/Makefile.am 2008-12-19 16:41:07.000000000 +1000 +@@ -18,7 +18,7 @@ + # IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN + # CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + +-SUBDIRS = . intel ++SUBDIRS = . intel radeon + + libdrm_la_LTLIBRARIES = libdrm.la + libdrm_ladir = $(libdir) +diff -up /dev/null libdrm-2.4.3/libdrm/radeon/Makefile.am +--- /dev/null 2008-12-18 14:22:13.823022429 +1000 ++++ libdrm-2.4.3/libdrm/radeon/Makefile.am 2008-12-19 16:41:07.000000000 +1000 +@@ -0,0 +1,48 @@ ++# Copyright © 2008 Jérôme Glisse ++# ++# Permission is hereby granted, free of charge, to any person obtaining a ++# copy of this software and associated documentation files (the "Software"), ++# to deal in the Software without restriction, including without limitation ++# the rights to use, copy, modify, merge, publish, distribute, sublicense, ++# and/or sell copies of the Software, and to permit persons to whom the ++# Software is furnished to do so, subject to the following conditions: ++# ++# The above copyright notice and this permission notice (including the next ++# paragraph) shall be included in all copies or substantial portions of the ++# Software. ++# ++# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR ++# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, ++# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL ++# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER ++# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING ++# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS ++# IN THE SOFTWARE. ++# ++# Authors: ++# Jérôme Glisse ++ ++AM_CFLAGS = \ ++ $(WARN_CFLAGS) \ ++ -I$(top_srcdir)/libdrm \ ++ -I$(top_srcdir)/libdrm/radeon \ ++ $(PTHREADSTUBS_CFLAGS) \ ++ -I$(top_srcdir)/shared-core ++ ++libdrm_radeon_la_LTLIBRARIES = libdrm_radeon.la ++libdrm_radeon_ladir = $(libdir) ++libdrm_radeon_la_LDFLAGS = -version-number 1:0:0 -no-undefined ++libdrm_radeon_la_LIBADD = ../libdrm.la @PTHREADSTUBS_LIBS@ ++ ++libdrm_radeon_la_SOURCES = \ ++ radeon_bo_gem.c \ ++ radeon_cs_gem.c \ ++ radeon_track.c ++ ++libdrm_radeonincludedir = ${includedir}/drm ++libdrm_radeoninclude_HEADERS = \ ++ radeon_bo.h \ ++ radeon_cs.h \ ++ radeon_bo_gem.h \ ++ radeon_cs_gem.h \ ++ radeon_track.h +diff -up /dev/null libdrm-2.4.3/libdrm/radeon/radeon_bo_gem.c +--- /dev/null 2008-12-18 14:22:13.823022429 +1000 ++++ libdrm-2.4.3/libdrm/radeon/radeon_bo_gem.c 2008-12-19 16:41:07.000000000 +1000 +@@ -0,0 +1,208 @@ ++/* ++ * Copyright © 2008 Dave Airlie ++ * Copyright © 2008 Jérôme Glisse ++ * All Rights Reserved. ++ * ++ * Permission is hereby granted, free of charge, to any person obtaining ++ * a copy of this software and associated documentation files (the ++ * "Software"), to deal in the Software without restriction, including ++ * without limitation the rights to use, copy, modify, merge, publish, ++ * distribute, sub license, and/or sell copies of the Software, and to ++ * permit persons to whom the Software is furnished to do so, subject to ++ * the following conditions: ++ * ++ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, ++ * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES ++ * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND ++ * NON-INFRINGEMENT. IN NO EVENT SHALL THE COPYRIGHT HOLDERS, AUTHORS ++ * AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER ++ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ++ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE ++ * USE OR OTHER DEALINGS IN THE SOFTWARE. ++ * ++ * The above copyright notice and this permission notice (including the ++ * next paragraph) shall be included in all copies or substantial portions ++ * of the Software. ++ */ ++/* ++ * Authors: ++ * Dave Airlie ++ * Jérôme Glisse ++ */ ++#include ++#include ++#include ++#include ++#include ++#include ++#include "xf86drm.h" ++#include "drm.h" ++#include "radeon_drm.h" ++#include "radeon_bo.h" ++#include "radeon_bo_gem.h" ++ ++struct radeon_bo_gem { ++ struct radeon_bo base; ++ uint32_t name; ++ int map_count; ++}; ++ ++struct bo_manager_gem { ++ struct radeon_bo_manager base; ++}; ++ ++static struct radeon_bo *bo_open(struct radeon_bo_manager *bom, ++ uint32_t handle, ++ uint32_t size, ++ uint32_t alignment, ++ uint32_t domains, ++ uint32_t flags) ++{ ++ struct radeon_bo_gem *bo; ++ int r; ++ ++ bo = (struct radeon_bo_gem*)calloc(1, sizeof(struct radeon_bo_gem)); ++ if (bo == NULL) { ++ return NULL; ++ } ++ ++ bo->base.bom = bom; ++ bo->base.handle = 0; ++ bo->base.size = size; ++ bo->base.alignment = alignment; ++ bo->base.domains = domains; ++ bo->base.flags = flags; ++ bo->base.ptr = NULL; ++ bo->map_count = 0; ++ if (handle) { ++ struct drm_gem_open open_arg; ++ ++ memset(&open_arg, 0, sizeof(open_arg)); ++ open_arg.name = handle; ++ r = ioctl(bom->fd, DRM_IOCTL_GEM_OPEN, &open_arg); ++ if (r != 0) { ++ free(bo); ++ return NULL; ++ } ++ bo->base.handle = open_arg.handle; ++ bo->base.size = open_arg.size; ++ bo->name = handle; ++ } else { ++ struct drm_radeon_gem_create args; ++ ++ args.size = size; ++ args.alignment = alignment; ++ args.initial_domain = bo->base.domains; ++ args.no_backing_store = 0; ++ args.handle = 0; ++ r = drmCommandWriteRead(bom->fd, DRM_RADEON_GEM_CREATE, ++ &args, sizeof(args)); ++ bo->base.handle = args.handle; ++ if (r) { ++ fprintf(stderr, "Failed to allocate :\n"); ++ fprintf(stderr, " size : %d bytes\n", size); ++ fprintf(stderr, " alignment : %d bytes\n", alignment); ++ fprintf(stderr, " domains : %d\n", bo->base.domains); ++ free(bo); ++ return NULL; ++ } ++ } ++ radeon_bo_ref((struct radeon_bo*)bo); ++ return (struct radeon_bo*)bo; ++} ++ ++static void bo_ref(struct radeon_bo *bo) ++{ ++} ++ ++static struct radeon_bo *bo_unref(struct radeon_bo *bo) ++{ ++ struct radeon_bo_gem *bo_gem = (struct radeon_bo_gem*)bo; ++ struct drm_gem_close args; ++ ++ if (bo == NULL) { ++ return NULL; ++ } ++ if (bo->cref) { ++ return bo; ++ } ++ if (bo_gem->map_count) { ++ munmap(bo->ptr, bo->size); ++ } ++ ++ /* close object */ ++ args.handle = bo->handle; ++ ioctl(bo->bom->fd, DRM_IOCTL_GEM_CLOSE, &args); ++ memset(bo_gem, 0, sizeof(struct radeon_bo_gem)); ++ free(bo_gem); ++ return NULL; ++} ++ ++static int bo_map(struct radeon_bo *bo, int write) ++{ ++ struct radeon_bo_gem *bo_gem = (struct radeon_bo_gem*)bo; ++ struct drm_radeon_gem_mmap args; ++ int r; ++ ++ if (bo_gem->map_count++ != 0) { ++ return 0; ++ } ++ bo->ptr = NULL; ++ args.handle = bo->handle; ++ args.offset = 0; ++ args.size = (uint64_t)bo->size; ++ r = drmCommandWriteRead(bo->bom->fd, ++ DRM_RADEON_GEM_MMAP, ++ &args, ++ sizeof(args)); ++ if (!r) { ++ bo->ptr = (void *)(unsigned long)args.addr_ptr; ++ } else { ++ fprintf(stderr, "error mapping %p 0x%08X (error = %d)\n", ++ bo, bo->handle, r); ++ } ++ return r; ++} ++ ++static int bo_unmap(struct radeon_bo *bo) ++{ ++ struct radeon_bo_gem *bo_gem = (struct radeon_bo_gem*)bo; ++ ++ if (--bo_gem->map_count > 0) { ++ return 0; ++ } ++ munmap(bo->ptr, bo->size); ++ bo->ptr = NULL; ++ return 0; ++} ++ ++static struct radeon_bo_funcs bo_gem_funcs = { ++ bo_open, ++ bo_ref, ++ bo_unref, ++ bo_map, ++ bo_unmap ++}; ++ ++struct radeon_bo_manager *radeon_bo_manager_gem_ctor(int fd) ++{ ++ struct bo_manager_gem *bomg; ++ ++ bomg = (struct bo_manager_gem*)calloc(1, sizeof(struct bo_manager_gem)); ++ if (bomg == NULL) { ++ return NULL; ++ } ++ bomg->base.funcs = &bo_gem_funcs; ++ bomg->base.fd = fd; ++ return (struct radeon_bo_manager*)bomg; ++} ++ ++void radeon_bo_manager_gem_dtor(struct radeon_bo_manager *bom) ++{ ++ struct bo_manager_gem *bomg = (struct bo_manager_gem*)bom; ++ ++ if (bom == NULL) { ++ return; ++ } ++ free(bomg); ++} +diff -up /dev/null libdrm-2.4.3/libdrm/radeon/radeon_bo_gem.h +--- /dev/null 2008-12-18 14:22:13.823022429 +1000 ++++ libdrm-2.4.3/libdrm/radeon/radeon_bo_gem.h 2008-12-19 16:41:07.000000000 +1000 +@@ -0,0 +1,40 @@ ++/* ++ * Copyright © 2008 Dave Airlie ++ * Copyright © 2008 Jérôme Glisse ++ * All Rights Reserved. ++ * ++ * Permission is hereby granted, free of charge, to any person obtaining ++ * a copy of this software and associated documentation files (the ++ * "Software"), to deal in the Software without restriction, including ++ * without limitation the rights to use, copy, modify, merge, publish, ++ * distribute, sub license, and/or sell copies of the Software, and to ++ * permit persons to whom the Software is furnished to do so, subject to ++ * the following conditions: ++ * ++ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, ++ * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES ++ * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND ++ * NON-INFRINGEMENT. IN NO EVENT SHALL THE COPYRIGHT HOLDERS, AUTHORS ++ * AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER ++ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ++ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE ++ * USE OR OTHER DEALINGS IN THE SOFTWARE. ++ * ++ * The above copyright notice and this permission notice (including the ++ * next paragraph) shall be included in all copies or substantial portions ++ * of the Software. ++ */ ++/* ++ * Authors: ++ * Dave Airlie ++ * Jérôme Glisse ++ */ ++#ifndef RADEON_BO_GEM_H ++#define RADEON_BO_GEM_H ++ ++#include "radeon_bo.h" ++ ++struct radeon_bo_manager *radeon_bo_manager_gem_ctor(int fd); ++void radeon_bo_manager_gem_dtor(struct radeon_bo_manager *bom); ++ ++#endif +diff -up /dev/null libdrm-2.4.3/libdrm/radeon/radeon_bo.h +--- /dev/null 2008-12-18 14:22:13.823022429 +1000 ++++ libdrm-2.4.3/libdrm/radeon/radeon_bo.h 2008-12-19 16:41:07.000000000 +1000 +@@ -0,0 +1,167 @@ ++/* ++ * Copyright © 2008 Jérôme Glisse ++ * All Rights Reserved. ++ * ++ * Permission is hereby granted, free of charge, to any person obtaining ++ * a copy of this software and associated documentation files (the ++ * "Software"), to deal in the Software without restriction, including ++ * without limitation the rights to use, copy, modify, merge, publish, ++ * distribute, sub license, and/or sell copies of the Software, and to ++ * permit persons to whom the Software is furnished to do so, subject to ++ * the following conditions: ++ * ++ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, ++ * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES ++ * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND ++ * NON-INFRINGEMENT. IN NO EVENT SHALL THE COPYRIGHT HOLDERS, AUTHORS ++ * AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER ++ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ++ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE ++ * USE OR OTHER DEALINGS IN THE SOFTWARE. ++ * ++ * The above copyright notice and this permission notice (including the ++ * next paragraph) shall be included in all copies or substantial portions ++ * of the Software. ++ */ ++/* ++ * Authors: ++ * Jérôme Glisse ++ */ ++#ifndef RADEON_BO_H ++#define RADEON_BO_H ++ ++#include ++#include ++#include "radeon_track.h" ++ ++/* bo object */ ++#define RADEON_BO_FLAGS_MACRO_TILE 1 ++#define RADEON_BO_FLAGS_MICRO_TILE 2 ++ ++struct radeon_bo_manager; ++ ++struct radeon_bo { ++ uint32_t alignment; ++ uint32_t handle; ++ uint32_t size; ++ uint32_t domains; ++ uint32_t flags; ++ unsigned cref; ++#ifdef RADEON_BO_TRACK ++ struct radeon_track *track; ++#endif ++ void *ptr; ++ struct radeon_bo_manager *bom; ++}; ++ ++/* bo functions */ ++struct radeon_bo_funcs { ++ struct radeon_bo *(*bo_open)(struct radeon_bo_manager *bom, ++ uint32_t handle, ++ uint32_t size, ++ uint32_t alignment, ++ uint32_t domains, ++ uint32_t flags); ++ void (*bo_ref)(struct radeon_bo *bo); ++ struct radeon_bo *(*bo_unref)(struct radeon_bo *bo); ++ int (*bo_map)(struct radeon_bo *bo, int write); ++ int (*bo_unmap)(struct radeon_bo *bo); ++}; ++ ++struct radeon_bo_manager { ++ struct radeon_bo_funcs *funcs; ++ int fd; ++ struct radeon_tracker tracker; ++}; ++ ++static inline void _radeon_bo_debug(struct radeon_bo *bo, ++ const char *op, ++ const char *file, ++ const char *func, ++ int line) ++{ ++ fprintf(stderr, "%s %p 0x%08X 0x%08X 0x%08X [%s %s %d]\n", ++ op, bo, bo->handle, bo->size, bo->cref, file, func, line); ++} ++ ++static inline struct radeon_bo *_radeon_bo_open(struct radeon_bo_manager *bom, ++ uint32_t handle, ++ uint32_t size, ++ uint32_t alignment, ++ uint32_t domains, ++ uint32_t flags, ++ const char *file, ++ const char *func, ++ int line) ++{ ++ struct radeon_bo *bo; ++ ++ bo = bom->funcs->bo_open(bom, handle, size, alignment, domains, flags); ++#ifdef RADEON_BO_TRACK ++ if (bo) { ++ bo->track = radeon_tracker_add_track(&bom->tracker, bo->handle); ++ radeon_track_add_event(bo->track, file, func, "open", line); ++ } ++#endif ++ return bo; ++} ++ ++static inline void _radeon_bo_ref(struct radeon_bo *bo, ++ const char *file, ++ const char *func, ++ int line) ++{ ++ bo->cref++; ++#ifdef RADEON_BO_TRACK ++ radeon_track_add_event(bo->track, file, func, "ref", line); ++#endif ++ bo->bom->funcs->bo_ref(bo); ++} ++ ++static inline struct radeon_bo *_radeon_bo_unref(struct radeon_bo *bo, ++ const char *file, ++ const char *func, ++ int line) ++{ ++ bo->cref--; ++#ifdef RADEON_BO_TRACK ++ radeon_track_add_event(bo->track, file, func, "unref", line); ++ if (bo->cref <= 0) { ++ radeon_tracker_remove_track(&bo->bom->tracker, bo->track); ++ bo->track = NULL; ++ } ++#endif ++ return bo->bom->funcs->bo_unref(bo); ++} ++ ++static inline int _radeon_bo_map(struct radeon_bo *bo, ++ int write, ++ const char *file, ++ const char *func, ++ int line) ++{ ++ return bo->bom->funcs->bo_map(bo, write); ++} ++ ++static inline int _radeon_bo_unmap(struct radeon_bo *bo, ++ const char *file, ++ const char *func, ++ int line) ++{ ++ return bo->bom->funcs->bo_unmap(bo); ++} ++ ++#define radeon_bo_open(bom, h, s, a, d, f)\ ++ _radeon_bo_open(bom, h, s, a, d, f, __FILE__, __FUNCTION__, __LINE__) ++#define radeon_bo_ref(bo)\ ++ _radeon_bo_ref(bo, __FILE__, __FUNCTION__, __LINE__) ++#define radeon_bo_unref(bo)\ ++ _radeon_bo_unref(bo, __FILE__, __FUNCTION__, __LINE__) ++#define radeon_bo_map(bo, w)\ ++ _radeon_bo_map(bo, w, __FILE__, __FUNCTION__, __LINE__) ++#define radeon_bo_unmap(bo)\ ++ _radeon_bo_unmap(bo, __FILE__, __FUNCTION__, __LINE__) ++#define radeon_bo_debug(bo, opcode)\ ++ _radeon_bo_debug(bo, opcode, __FILE__, __FUNCTION__, __LINE__) ++ ++#endif +diff -up /dev/null libdrm-2.4.3/libdrm/radeon/radeon_cs_gem.c +--- /dev/null 2008-12-18 14:22:13.823022429 +1000 ++++ libdrm-2.4.3/libdrm/radeon/radeon_cs_gem.c 2008-12-19 16:41:07.000000000 +1000 +@@ -0,0 +1,418 @@ ++/* ++ * Copyright © 2008 Jérôme Glisse ++ * All Rights Reserved. ++ * ++ * Permission is hereby granted, free of charge, to any person obtaining ++ * a copy of this software and associated documentation files (the ++ * "Software"), to deal in the Software without restriction, including ++ * without limitation the rights to use, copy, modify, merge, publish, ++ * distribute, sub license, and/or sell copies of the Software, and to ++ * permit persons to whom the Software is furnished to do so, subject to ++ * the following conditions: ++ * ++ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, ++ * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES ++ * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND ++ * NON-INFRINGEMENT. IN NO EVENT SHALL THE COPYRIGHT HOLDERS, AUTHORS ++ * AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER ++ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ++ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE ++ * USE OR OTHER DEALINGS IN THE SOFTWARE. ++ * ++ * The above copyright notice and this permission notice (including the ++ * next paragraph) shall be included in all copies or substantial portions ++ * of the Software. ++ */ ++/* ++ * Authors: ++ * Aapo Tahkola ++ * Nicolai Haehnle ++ * Jérôme Glisse ++ */ ++#include ++#include ++#include ++#include ++#include "radeon_cs.h" ++#include "radeon_cs_gem.h" ++#include "radeon_bo_gem.h" ++#include "drm.h" ++#include "xf86drm.h" ++#include "radeon_drm.h" ++ ++#pragma pack(1) ++struct cs_reloc_gem { ++ uint32_t handle; ++ uint32_t read_domain; ++ uint32_t write_domain; ++ uint32_t flags; ++}; ++#pragma pack() ++ ++struct cs_gem { ++ struct radeon_cs base; ++ struct drm_radeon_cs cs; ++ struct drm_radeon_cs_chunk chunks[2]; ++ unsigned nrelocs; ++ uint32_t *relocs; ++ struct radeon_bo **relocs_bo; ++}; ++ ++static struct radeon_cs *cs_gem_create(struct radeon_cs_manager *csm, ++ uint32_t ndw) ++{ ++ struct cs_gem *csg; ++ ++ /* max cmd buffer size is 64Kb */ ++ if (ndw > (64 * 1024 / 4)) { ++ return NULL; ++ } ++ csg = (struct cs_gem*)calloc(1, sizeof(struct cs_gem)); ++ if (csg == NULL) { ++ return NULL; ++ } ++ csg->base.csm = csm; ++ csg->base.ndw = 64 * 1024 / 4; ++ csg->base.packets = (uint32_t*)calloc(1, 64 * 1024); ++ if (csg->base.packets == NULL) { ++ free(csg); ++ return NULL; ++ } ++ csg->base.relocs_total_size = 0; ++ csg->base.crelocs = 0; ++ csg->nrelocs = 4096 / (4 * 4) ; ++ csg->relocs_bo = (struct radeon_bo**)calloc(1, ++ csg->nrelocs*sizeof(void*)); ++ if (csg->relocs_bo == NULL) { ++ free(csg->base.packets); ++ free(csg); ++ return NULL; ++ } ++ csg->base.relocs = csg->relocs = (uint32_t*)calloc(1, 4096); ++ if (csg->relocs == NULL) { ++ free(csg->relocs_bo); ++ free(csg->base.packets); ++ free(csg); ++ return NULL; ++ } ++ csg->chunks[0].chunk_id = RADEON_CHUNK_ID_IB; ++ csg->chunks[0].length_dw = 0; ++ csg->chunks[0].chunk_data = (uint64_t)(intptr_t)csg->base.packets; ++ csg->chunks[1].chunk_id = RADEON_CHUNK_ID_RELOCS; ++ csg->chunks[1].length_dw = 0; ++ csg->chunks[1].chunk_data = (uint64_t)(intptr_t)csg->relocs; ++ return (struct radeon_cs*)csg; ++} ++ ++static int cs_gem_write_dword(struct radeon_cs *cs, uint32_t dword) ++{ ++ struct cs_gem *csg = (struct cs_gem*)cs; ++ if (cs->cdw >= cs->ndw) { ++ uint32_t tmp, *ptr; ++ tmp = (cs->cdw + 1 + 0x3FF) & (~0x3FF); ++ ptr = (uint32_t*)realloc(cs->packets, 4 * tmp); ++ if (ptr == NULL) { ++ return -ENOMEM; ++ } ++ cs->packets = ptr; ++ cs->ndw = tmp; ++ csg->chunks[0].chunk_data = (uint64_t)(intptr_t)csg->base.packets; ++ } ++ cs->packets[cs->cdw++] = dword; ++ csg->chunks[0].length_dw += 1; ++ return 0; ++} ++ ++static int cs_gem_write_reloc(struct radeon_cs *cs, ++ struct radeon_bo *bo, ++ uint32_t read_domain, ++ uint32_t write_domain, ++ uint32_t flags) ++{ ++ struct cs_gem *csg = (struct cs_gem*)cs; ++ struct cs_reloc_gem *reloc; ++ uint32_t idx; ++ unsigned i; ++ ++ /* check domains */ ++ if ((read_domain && write_domain) || (!read_domain && !write_domain)) { ++ /* in one CS a bo can only be in read or write domain but not ++ * in read & write domain at the same sime ++ */ ++ return -EINVAL; ++ } ++ if (read_domain == RADEON_GEM_DOMAIN_CPU) { ++ return -EINVAL; ++ } ++ if (write_domain == RADEON_GEM_DOMAIN_CPU) { ++ return -EINVAL; ++ } ++ /* check if bo is already referenced */ ++ for(i = 0; i < cs->crelocs; i++) { ++ idx = i * 6; ++ reloc = (struct cs_reloc_gem*)&csg->relocs[idx]; ++ if (reloc->handle == bo->handle) { ++ /* Check domains must be in read or write. As we check already ++ * checked that in argument one of the read or write domain was ++ * set we only need to check that if previous reloc as the read ++ * domain set then the read_domain should also be set for this ++ * new relocation. ++ */ ++ if (reloc->read_domain && !read_domain) { ++ return -EINVAL; ++ } ++ if (reloc->write_domain && !write_domain) { ++ return -EINVAL; ++ } ++ reloc->read_domain |= read_domain; ++ reloc->write_domain |= write_domain; ++ /* update flags */ ++ reloc->flags |= (flags & reloc->flags); ++ /* write relocation packet */ ++ cs_gem_write_dword(cs, 0xc0001000); ++ cs_gem_write_dword(cs, idx); ++ return 0; ++ } ++ } ++ /* new relocation */ ++ if (csg->base.crelocs >= csg->nrelocs) { ++ /* allocate more memory (TODO: should use a slab allocatore maybe) */ ++ uint32_t *tmp, size; ++ size = ((csg->nrelocs + 1) * sizeof(struct radeon_bo*)); ++ tmp = (uint32_t*)realloc(csg->relocs_bo, size); ++ if (tmp == NULL) { ++ return -ENOMEM; ++ } ++ csg->relocs_bo = (struct radeon_bo**)tmp; ++ size = ((csg->nrelocs + 1) * 6 * 4); ++ tmp = (uint32_t*)realloc(csg->relocs, size); ++ if (tmp == NULL) { ++ return -ENOMEM; ++ } ++ cs->relocs = csg->relocs = tmp; ++ csg->nrelocs += 1; ++ csg->chunks[1].chunk_data = (uint64_t)(intptr_t)csg->relocs; ++ } ++ csg->relocs_bo[csg->base.crelocs] = bo; ++ idx = (csg->base.crelocs++) * 6; ++ reloc = (struct cs_reloc_gem*)&csg->relocs[idx]; ++ reloc->handle = bo->handle; ++ reloc->read_domain = read_domain; ++ reloc->write_domain = write_domain; ++ reloc->flags = flags; ++ csg->chunks[1].length_dw += 6; ++ radeon_bo_ref(bo); ++ cs->relocs_total_size += bo->size; ++ cs_gem_write_dword(cs, 0xc0001000); ++ cs_gem_write_dword(cs, idx); ++ return 0; ++} ++ ++static int cs_gem_begin(struct radeon_cs *cs, ++ uint32_t ndw, ++ const char *file, ++ const char *func, ++ int line) ++{ ++ return 0; ++} ++ ++static int cs_gem_end(struct radeon_cs *cs, ++ const char *file, ++ const char *func, ++ int line) ++ ++{ ++ cs->section = 0; ++ return 0; ++} ++ ++static int cs_gem_emit(struct radeon_cs *cs) ++{ ++ struct cs_gem *csg = (struct cs_gem*)cs; ++ uint64_t chunk_array[2]; ++ unsigned i; ++ int r; ++ ++ csg->chunks[0].length_dw = cs->cdw; ++ ++ chunk_array[0] = (uint64_t)(intptr_t)&csg->chunks[0]; ++ chunk_array[1] = (uint64_t)(intptr_t)&csg->chunks[1]; ++ ++ csg->cs.num_chunks = 2; ++ csg->cs.chunks = (uint64_t)(intptr_t)chunk_array; ++ ++ r = drmCommandWriteRead(cs->csm->fd, DRM_RADEON_CS, ++ &csg->cs, sizeof(struct drm_radeon_cs)); ++ for (i = 0; i < csg->base.crelocs; i++) { ++ radeon_bo_unref(csg->relocs_bo[i]); ++ csg->relocs_bo[i] = NULL; ++ } ++ return r; ++} ++ ++static int cs_gem_destroy(struct radeon_cs *cs) ++{ ++ struct cs_gem *csg = (struct cs_gem*)cs; ++ ++ free(csg->relocs_bo); ++ free(cs->relocs); ++ free(cs->packets); ++ free(cs); ++ return 0; ++} ++ ++static int cs_gem_erase(struct radeon_cs *cs) ++{ ++ struct cs_gem *csg = (struct cs_gem*)cs; ++ unsigned i; ++ ++ if (csg->relocs_bo) { ++ for (i = 0; i < csg->base.crelocs; i++) { ++ if (csg->relocs_bo[i]) { ++ radeon_bo_unref(csg->relocs_bo[i]); ++ csg->relocs_bo[i] = NULL; ++ } ++ } ++ } ++ cs->relocs_total_size = 0; ++ cs->cdw = 0; ++ cs->section = 0; ++ cs->crelocs = 0; ++ csg->chunks[0].length_dw = 0; ++ csg->chunks[1].length_dw = 0; ++ return 0; ++} ++ ++static int cs_gem_need_flush(struct radeon_cs *cs) ++{ ++ return (cs->relocs_total_size > (32*1024*1024)); ++} ++ ++#define PACKET_TYPE0 0 ++#define PACKET_TYPE1 1 ++#define PACKET_TYPE2 2 ++#define PACKET_TYPE3 3 ++ ++#define PACKET3_NOP 0x10 ++#define PACKET3_SET_SCISSORS 0x1E ++#define PACKET3_3D_DRAW_VBUF 0x28 ++#define PACKET3_3D_DRAW_IMMD 0x29 ++#define PACKET3_3D_DRAW_INDX 0x2A ++#define PACKET3_3D_LOAD_VBPNTR 0x2F ++#define PACKET3_INDX_BUFFER 0x33 ++#define PACKET3_3D_DRAW_VBUF_2 0x34 ++#define PACKET3_3D_DRAW_IMMD_2 0x35 ++#define PACKET3_3D_DRAW_INDX_2 0x36 ++ ++#define CP_PACKET_GET_TYPE(h) (((h) >> 30) & 3) ++#define CP_PACKET_GET_COUNT(h) (((h) >> 16) & 0x3FFF) ++#define CP_PACKET0_GET_REG(h) (((h) & 0x1FFF) << 2) ++#define CP_PACKET0_GET_ONE_REG_WR(h) (((h) >> 15) & 1) ++#define CP_PACKET3_GET_OPCODE(h) (((h) >> 8) & 0xFF) ++ ++static void cs_gem_print(struct radeon_cs *cs, FILE *file) ++{ ++ unsigned opcode; ++ unsigned reg; ++ unsigned cnt; ++ int i, j; ++ ++ for (i = 0; i < cs->cdw;) { ++ cnt = CP_PACKET_GET_COUNT(cs->packets[i]); ++ switch (CP_PACKET_GET_TYPE(cs->packets[i])) { ++ case PACKET_TYPE0: ++ fprintf(file, "Pkt0 at %d (%d dwords):\n", i, cnt + 1); ++ reg = CP_PACKET0_GET_REG(cs->packets[i]); ++ if (CP_PACKET0_GET_ONE_REG_WR(cs->packets[i++])) { ++ for (j = 0; j <= cnt; j++) { ++ fprintf(file, " 0x%08X -> 0x%04X\n", ++ cs->packets[i++], reg); ++ } ++ } else { ++ for (j = 0; j <= cnt; j++) { ++ fprintf(file, " 0x%08X -> 0x%04X\n", ++ cs->packets[i++], reg); ++ reg += 4; ++ } ++ } ++ break; ++ case PACKET_TYPE3: ++ fprintf(file, "Pkt3 at %d :\n", i); ++ opcode = CP_PACKET3_GET_OPCODE(cs->packets[i++]); ++ switch (opcode) { ++ case PACKET3_NOP: ++ fprintf(file, " PACKET3_NOP:\n"); ++ break; ++ case PACKET3_3D_DRAW_VBUF: ++ fprintf(file, " PACKET3_3D_DRAW_VBUF:\n"); ++ break; ++ case PACKET3_3D_DRAW_IMMD: ++ fprintf(file, " PACKET3_3D_DRAW_IMMD:\n"); ++ break; ++ case PACKET3_3D_DRAW_INDX: ++ fprintf(file, " PACKET3_3D_DRAW_INDX:\n"); ++ break; ++ case PACKET3_3D_LOAD_VBPNTR: ++ fprintf(file, " PACKET3_3D_LOAD_VBPNTR:\n"); ++ break; ++ case PACKET3_INDX_BUFFER: ++ fprintf(file, " PACKET3_INDX_BUFFER:\n"); ++ break; ++ case PACKET3_3D_DRAW_VBUF_2: ++ fprintf(file, " PACKET3_3D_DRAW_VBUF_2:\n"); ++ break; ++ case PACKET3_3D_DRAW_IMMD_2: ++ fprintf(file, " PACKET3_3D_DRAW_IMMD_2:\n"); ++ break; ++ case PACKET3_3D_DRAW_INDX_2: ++ fprintf(file, " PACKET3_3D_DRAW_INDX_2:\n"); ++ break; ++ default: ++ fprintf(file, "Unknow opcode 0x%02X at %d\n", opcode, i); ++ return; ++ } ++ for (j = 0; j <= cnt; j++) { ++ fprintf(file, " 0x%08X\n", cs->packets[i++]); ++ } ++ break; ++ case PACKET_TYPE1: ++ case PACKET_TYPE2: ++ default: ++ fprintf(file, "Unknow packet 0x%08X at %d\n", cs->packets[i], i); ++ return; ++ } ++ } ++} ++ ++static struct radeon_cs_funcs radeon_cs_gem_funcs = { ++ cs_gem_create, ++ cs_gem_write_dword, ++ cs_gem_write_reloc, ++ cs_gem_begin, ++ cs_gem_end, ++ cs_gem_emit, ++ cs_gem_destroy, ++ cs_gem_erase, ++ cs_gem_need_flush, ++ cs_gem_print ++}; ++ ++struct radeon_cs_manager *radeon_cs_manager_gem_ctor(int fd) ++{ ++ struct radeon_cs_manager *csm; ++ ++ csm = (struct radeon_cs_manager*)calloc(1, ++ sizeof(struct radeon_cs_manager)); ++ if (csm == NULL) { ++ return NULL; ++ } ++ csm->funcs = &radeon_cs_gem_funcs; ++ csm->fd = fd; ++ return csm; ++} ++ ++void radeon_cs_manager_gem_dtor(struct radeon_cs_manager *csm) ++{ ++ free(csm); ++} +diff -up /dev/null libdrm-2.4.3/libdrm/radeon/radeon_cs_gem.h +--- /dev/null 2008-12-18 14:22:13.823022429 +1000 ++++ libdrm-2.4.3/libdrm/radeon/radeon_cs_gem.h 2008-12-19 16:41:07.000000000 +1000 +@@ -0,0 +1,41 @@ ++/* ++ * Copyright © 2008 Nicolai Haehnle ++ * Copyright © 2008 Jérôme Glisse ++ * All Rights Reserved. ++ * ++ * Permission is hereby granted, free of charge, to any person obtaining ++ * a copy of this software and associated documentation files (the ++ * "Software"), to deal in the Software without restriction, including ++ * without limitation the rights to use, copy, modify, merge, publish, ++ * distribute, sub license, and/or sell copies of the Software, and to ++ * permit persons to whom the Software is furnished to do so, subject to ++ * the following conditions: ++ * ++ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, ++ * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES ++ * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND ++ * NON-INFRINGEMENT. IN NO EVENT SHALL THE COPYRIGHT HOLDERS, AUTHORS ++ * AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER ++ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ++ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE ++ * USE OR OTHER DEALINGS IN THE SOFTWARE. ++ * ++ * The above copyright notice and this permission notice (including the ++ * next paragraph) shall be included in all copies or substantial portions ++ * of the Software. ++ */ ++/* ++ * Authors: ++ * Aapo Tahkola ++ * Nicolai Haehnle ++ * Jérôme Glisse ++ */ ++#ifndef RADEON_CS_GEM_H ++#define RADEON_CS_GEM_H ++ ++#include "radeon_cs.h" ++ ++struct radeon_cs_manager *radeon_cs_manager_gem_ctor(int fd); ++void radeon_cs_manager_gem_dtor(struct radeon_cs_manager *csm); ++ ++#endif +diff -up /dev/null libdrm-2.4.3/libdrm/radeon/radeon_cs.h +--- /dev/null 2008-12-18 14:22:13.823022429 +1000 ++++ libdrm-2.4.3/libdrm/radeon/radeon_cs.h 2008-12-19 16:41:07.000000000 +1000 +@@ -0,0 +1,160 @@ ++/* ++ * Copyright © 2008 Nicolai Haehnle ++ * Copyright © 2008 Jérôme Glisse ++ * All Rights Reserved. ++ * ++ * Permission is hereby granted, free of charge, to any person obtaining a ++ * copy of this software and associated documentation files (the ++ * "Software"), to deal in the Software without restriction, including ++ * without limitation the rights to use, copy, modify, merge, publish, ++ * distribute, sub license, and/or sell copies of the Software, and to ++ * permit persons to whom the Software is furnished to do so, subject to ++ * the following conditions: ++ * ++ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR ++ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, ++ * FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL ++ * THE COPYRIGHT HOLDERS, AUTHORS AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, ++ * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR ++ * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE ++ * USE OR OTHER DEALINGS IN THE SOFTWARE. ++ * ++ * The above copyright notice and this permission notice (including the ++ * next paragraph) shall be included in all copies or substantial portions ++ * of the Software. ++ */ ++/* ++ * Authors: ++ * Aapo Tahkola ++ * Nicolai Haehnle ++ * Jérôme Glisse ++ */ ++#ifndef RADEON_CS_H ++#define RADEON_CS_H ++ ++#include ++#include "radeon_bo.h" ++ ++struct radeon_cs_reloc { ++ struct radeon_bo *bo; ++ uint32_t read_domain; ++ uint32_t write_domain; ++ uint32_t flags; ++}; ++ ++struct radeon_cs_manager; ++ ++struct radeon_cs { ++ struct radeon_cs_manager *csm; ++ void *relocs; ++ uint32_t *packets; ++ unsigned crelocs; ++ unsigned relocs_total_size; ++ unsigned cdw; ++ unsigned ndw; ++ int section; ++ unsigned section_ndw; ++ unsigned section_cdw; ++ const char *section_file; ++ const char *section_func; ++ int section_line; ++}; ++ ++/* cs functions */ ++struct radeon_cs_funcs { ++ struct radeon_cs *(*cs_create)(struct radeon_cs_manager *csm, ++ uint32_t ndw); ++ int (*cs_write_dword)(struct radeon_cs *cs, uint32_t dword); ++ int (*cs_write_reloc)(struct radeon_cs *cs, ++ struct radeon_bo *bo, ++ uint32_t read_domain, ++ uint32_t write_domain, ++ uint32_t flags); ++ int (*cs_begin)(struct radeon_cs *cs, ++ uint32_t ndw, ++ const char *file, ++ const char *func, ++ int line); ++ int (*cs_end)(struct radeon_cs *cs, ++ const char *file, ++ const char *func, ++ int line); ++ int (*cs_emit)(struct radeon_cs *cs); ++ int (*cs_destroy)(struct radeon_cs *cs); ++ int (*cs_erase)(struct radeon_cs *cs); ++ int (*cs_need_flush)(struct radeon_cs *cs); ++ void (*cs_print)(struct radeon_cs *cs, FILE *file); ++}; ++ ++struct radeon_cs_manager { ++ struct radeon_cs_funcs *funcs; ++ int fd; ++}; ++ ++static inline struct radeon_cs *radeon_cs_create(struct radeon_cs_manager *csm, ++ uint32_t ndw) ++{ ++ return csm->funcs->cs_create(csm, ndw); ++} ++ ++static inline int radeon_cs_write_dword(struct radeon_cs *cs, uint32_t dword) ++{ ++ return cs->csm->funcs->cs_write_dword(cs, dword); ++} ++ ++static inline int radeon_cs_write_reloc(struct radeon_cs *cs, ++ struct radeon_bo *bo, ++ uint32_t read_domain, ++ uint32_t write_domain, ++ uint32_t flags) ++{ ++ return cs->csm->funcs->cs_write_reloc(cs, ++ bo, ++ read_domain, ++ write_domain, ++ flags); ++} ++ ++static inline int radeon_cs_begin(struct radeon_cs *cs, ++ uint32_t ndw, ++ const char *file, ++ const char *func, ++ int line) ++{ ++ return cs->csm->funcs->cs_begin(cs, ndw, file, func, line); ++} ++ ++static inline int radeon_cs_end(struct radeon_cs *cs, ++ const char *file, ++ const char *func, ++ int line) ++{ ++ return cs->csm->funcs->cs_end(cs, file, func, line); ++} ++ ++static inline int radeon_cs_emit(struct radeon_cs *cs) ++{ ++ return cs->csm->funcs->cs_emit(cs); ++} ++ ++static inline int radeon_cs_destroy(struct radeon_cs *cs) ++{ ++ return cs->csm->funcs->cs_destroy(cs); ++} ++ ++static inline int radeon_cs_erase(struct radeon_cs *cs) ++{ ++ return cs->csm->funcs->cs_erase(cs); ++} ++ ++static inline int radeon_cs_need_flush(struct radeon_cs *cs) ++{ ++ return cs->csm->funcs->cs_need_flush(cs); ++} ++ ++static inline void radeon_cs_print(struct radeon_cs *cs, FILE *file) ++{ ++ cs->csm->funcs->cs_print(cs, file); ++} ++ ++#endif +diff -up /dev/null libdrm-2.4.3/libdrm/radeon/radeon_track.c +--- /dev/null 2008-12-18 14:22:13.823022429 +1000 ++++ libdrm-2.4.3/libdrm/radeon/radeon_track.c 2008-12-19 16:41:07.000000000 +1000 +@@ -0,0 +1,140 @@ ++/* ++ * Copyright © 2008 Jérôme Glisse ++ * All Rights Reserved. ++ * ++ * Permission is hereby granted, free of charge, to any person obtaining ++ * a copy of this software and associated documentation files (the ++ * "Software"), to deal in the Software without restriction, including ++ * without limitation the rights to use, copy, modify, merge, publish, ++ * distribute, sub license, and/or sell copies of the Software, and to ++ * permit persons to whom the Software is furnished to do so, subject to ++ * the following conditions: ++ * ++ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, ++ * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES ++ * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND ++ * NON-INFRINGEMENT. IN NO EVENT SHALL THE COPYRIGHT HOLDERS, AUTHORS ++ * AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER ++ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ++ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE ++ * USE OR OTHER DEALINGS IN THE SOFTWARE. ++ * ++ * The above copyright notice and this permission notice (including the ++ * next paragraph) shall be included in all copies or substantial portions ++ * of the Software. ++ */ ++/* ++ * Authors: ++ * Jérôme Glisse ++ */ ++#include ++#include ++#include ++#include "radeon_track.h" ++ ++void radeon_track_add_event(struct radeon_track *track, ++ const char *file, ++ const char *func, ++ const char *op, ++ unsigned line) ++{ ++ struct radeon_track_event *event; ++ ++ if (track == NULL) { ++ return; ++ } ++ event = (void*)calloc(1,sizeof(struct radeon_track_event)); ++ if (event == NULL) { ++ return; ++ } ++ event->line = line; ++ event->file = strdup(file); ++ event->func = strdup(func); ++ event->op = strdup(op); ++ if (event->file == NULL || event->func == NULL || event->op == NULL) { ++ free(event->file); ++ free(event->func); ++ free(event->op); ++ free(event); ++ return; ++ } ++ event->next = track->events; ++ track->events = event; ++} ++ ++struct radeon_track *radeon_tracker_add_track(struct radeon_tracker *tracker, ++ unsigned key) ++{ ++ struct radeon_track *track; ++ ++ track = (struct radeon_track*)calloc(1, sizeof(struct radeon_track)); ++ if (track) { ++ track->next = tracker->tracks.next; ++ track->prev = &tracker->tracks; ++ tracker->tracks.next = track; ++ if (track->next) { ++ track->next->prev = track; ++ } ++ track->key = key; ++ track->events = NULL; ++ } ++ return track; ++} ++ ++void radeon_tracker_remove_track(struct radeon_tracker *tracker, ++ struct radeon_track *track) ++{ ++ struct radeon_track_event *event; ++ void *tmp; ++ ++ if (track == NULL) { ++ return; ++ } ++ track->prev->next = track->next; ++ if (track->next) { ++ track->next->prev = track->prev; ++ } ++ track->next = track->prev = NULL; ++ event = track->events; ++ while (event) { ++ tmp = event; ++ free(event->file); ++ free(event->func); ++ free(event->op); ++ event = event->next; ++ free(tmp); ++ } ++ track->events = NULL; ++ free(track); ++} ++ ++void radeon_tracker_print(struct radeon_tracker *tracker, FILE *file) ++{ ++ struct radeon_track *track; ++ struct radeon_track_event *event; ++ void *tmp; ++ ++ track = tracker->tracks.next; ++ while (track) { ++ event = track->events; ++ fprintf(file, "[0x%08X] :\n", track->key); ++ while (event) { ++ tmp = event; ++ fprintf(file, " [0x%08X:%s](%s:%s:%d)\n", ++ track->key, event->op, event->file, ++ event->func, event->line); ++ free(event->file); ++ free(event->func); ++ free(event->op); ++ event->file = NULL; ++ event->func = NULL; ++ event->op = NULL; ++ event = event->next; ++ free(tmp); ++ } ++ track->events = NULL; ++ tmp = track; ++ track = track->next; ++ free(tmp); ++ } ++} +diff -up /dev/null libdrm-2.4.3/libdrm/radeon/radeon_track.h +--- /dev/null 2008-12-18 14:22:13.823022429 +1000 ++++ libdrm-2.4.3/libdrm/radeon/radeon_track.h 2008-12-19 16:41:07.000000000 +1000 +@@ -0,0 +1,64 @@ ++/* ++ * Copyright © 2008 Jérôme Glisse ++ * All Rights Reserved. ++ * ++ * Permission is hereby granted, free of charge, to any person obtaining ++ * a copy of this software and associated documentation files (the ++ * "Software"), to deal in the Software without restriction, including ++ * without limitation the rights to use, copy, modify, merge, publish, ++ * distribute, sub license, and/or sell copies of the Software, and to ++ * permit persons to whom the Software is furnished to do so, subject to ++ * the following conditions: ++ * ++ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, ++ * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES ++ * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND ++ * NON-INFRINGEMENT. IN NO EVENT SHALL THE COPYRIGHT HOLDERS, AUTHORS ++ * AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER ++ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ++ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE ++ * USE OR OTHER DEALINGS IN THE SOFTWARE. ++ * ++ * The above copyright notice and this permission notice (including the ++ * next paragraph) shall be included in all copies or substantial portions ++ * of the Software. ++ */ ++/* ++ * Authors: ++ * Jérôme Glisse ++ */ ++#ifndef RADEON_TRACK_H ++#define RADEON_TRACK_H ++ ++struct radeon_track_event { ++ struct radeon_track_event *next; ++ char *file; ++ char *func; ++ char *op; ++ unsigned line; ++}; ++ ++struct radeon_track { ++ struct radeon_track *next; ++ struct radeon_track *prev; ++ unsigned key; ++ struct radeon_track_event *events; ++}; ++ ++struct radeon_tracker { ++ struct radeon_track tracks; ++}; ++ ++void radeon_track_add_event(struct radeon_track *track, ++ const char *file, ++ const char *func, ++ const char *op, ++ unsigned line); ++struct radeon_track *radeon_tracker_add_track(struct radeon_tracker *tracker, ++ unsigned key); ++void radeon_tracker_remove_track(struct radeon_tracker *tracker, ++ struct radeon_track *track); ++void radeon_tracker_print(struct radeon_tracker *tracker, ++ FILE *file); ++ ++#endif +diff -up libdrm-2.4.3/shared-core/radeon_drm.h.radeon libdrm-2.4.3/shared-core/radeon_drm.h +--- libdrm-2.4.3/shared-core/radeon_drm.h.radeon 2008-12-19 14:33:38.000000000 +1000 ++++ libdrm-2.4.3/shared-core/radeon_drm.h 2008-12-19 16:41:07.000000000 +1000 +@@ -453,8 +453,18 @@ typedef struct { + int pfCurrentPage; /* which buffer is being displayed? */ + int crtc2_base; /* CRTC2 frame offset */ + int tiling_enabled; /* set by drm, read by 2d + 3d clients */ ++ ++ unsigned int last_fence; ++ ++ uint32_t front_handle; ++ uint32_t back_handle; ++ uint32_t depth_handle; ++ uint32_t front_pitch; ++ uint32_t back_pitch; ++ uint32_t depth_pitch; + } drm_radeon_sarea_t; + ++ + /* WARNING: If you change any of these defines, make sure to change the + * defines in the Xserver file (xf86drmRadeon.h) + * +@@ -493,6 +503,18 @@ typedef struct { + #define DRM_RADEON_SURF_ALLOC 0x1a + #define DRM_RADEON_SURF_FREE 0x1b + ++#define DRM_RADEON_GEM_INFO 0x1c ++#define DRM_RADEON_GEM_CREATE 0x1d ++#define DRM_RADEON_GEM_MMAP 0x1e ++#define DRM_RADEON_GEM_PIN 0x1f ++#define DRM_RADEON_GEM_UNPIN 0x20 ++#define DRM_RADEON_GEM_PREAD 0x21 ++#define DRM_RADEON_GEM_PWRITE 0x22 ++#define DRM_RADEON_GEM_SET_DOMAIN 0x23 ++#define DRM_RADEON_GEM_WAIT_RENDERING 0x24 ++ ++#define DRM_RADEON_CS 0x26 ++ + #define DRM_IOCTL_RADEON_CP_INIT DRM_IOW( DRM_COMMAND_BASE + DRM_RADEON_CP_INIT, drm_radeon_init_t) + #define DRM_IOCTL_RADEON_CP_START DRM_IO( DRM_COMMAND_BASE + DRM_RADEON_CP_START) + #define DRM_IOCTL_RADEON_CP_STOP DRM_IOW( DRM_COMMAND_BASE + DRM_RADEON_CP_STOP, drm_radeon_cp_stop_t) +@@ -521,6 +543,17 @@ typedef struct { + #define DRM_IOCTL_RADEON_SURF_ALLOC DRM_IOW( DRM_COMMAND_BASE + DRM_RADEON_SURF_ALLOC, drm_radeon_surface_alloc_t) + #define DRM_IOCTL_RADEON_SURF_FREE DRM_IOW( DRM_COMMAND_BASE + DRM_RADEON_SURF_FREE, drm_radeon_surface_free_t) + ++#define DRM_IOCTL_RADEON_GEM_INFO DRM_IOWR(DRM_COMMAND_BASE + DRM_RADEON_GEM_INFO, struct drm_radeon_gem_info) ++#define DRM_IOCTL_RADEON_GEM_CREATE DRM_IOWR(DRM_COMMAND_BASE + DRM_RADEON_GEM_CREATE, struct drm_radeon_gem_create) ++#define DRM_IOCTL_RADEON_GEM_MMAP DRM_IOWR(DRM_COMMAND_BASE + DRM_RADEON_GEM_MMAP, struct drm_radeon_gem_mmap) ++#define DRM_IOCTL_RADEON_GEM_PIN DRM_IOWR(DRM_COMMAND_BASE + DRM_RADEON_GEM_PIN, struct drm_radeon_gem_pin) ++#define DRM_IOCTL_RADEON_GEM_UNPIN DRM_IOWR(DRM_COMMAND_BASE + DRM_RADEON_GEM_UNPIN, struct drm_radeon_gem_unpin) ++#define DRM_IOCTL_RADEON_GEM_PREAD DRM_IOWR(DRM_COMMAND_BASE + DRM_RADEON_GEM_PREAD, struct drm_radeon_gem_pread) ++#define DRM_IOCTL_RADEON_GEM_PWRITE DRM_IOWR(DRM_COMMAND_BASE + DRM_RADEON_GEM_PWRITE, struct drm_radeon_gem_pwrite) ++#define DRM_IOCTL_RADEON_GEM_SET_DOMAIN DRM_IOWR(DRM_COMMAND_BASE + DRM_RADEON_GEM_SET_DOMAIN, struct drm_radeon_gem_set_domain) ++#define DRM_IOCTL_RADEON_GEM_WAIT_RENDERING DRM_IOW(DRM_COMMAND_BASE + DRM_RADEON_GEM_WAIT_RENDERING, struct drm_radeon_gem_wait_rendering) ++#define DRM_IOCTL_RADEON_CS DRM_IOWR(DRM_COMMAND_BASE + DRM_RADEON_CS, struct drm_radeon_cs) ++ + typedef struct drm_radeon_init { + enum { + RADEON_INIT_CP = 0x01, +@@ -677,6 +710,7 @@ typedef struct drm_radeon_indirect { + #define RADEON_PARAM_VBLANK_CRTC 13 /* VBLANK CRTC */ + #define RADEON_PARAM_FB_LOCATION 14 /* FB location */ + #define RADEON_PARAM_NUM_GB_PIPES 15 /* num GB pipes */ ++#define RADEON_PARAM_KERNEL_MM 16 + + typedef struct drm_radeon_getparam { + int param; +@@ -732,6 +766,7 @@ typedef struct drm_radeon_setparam { + #define RADEON_SETPARAM_NEW_MEMMAP 4 /* Use new memory map */ + #define RADEON_SETPARAM_PCIGART_TABLE_SIZE 5 /* PCI GART Table Size */ + #define RADEON_SETPARAM_VBLANK_CRTC 6 /* VBLANK CRTC */ ++#define RADEON_SETPARAM_MM_INIT 7 /* Initialise the mm */ + /* 1.14: Clients can allocate/free a surface + */ + typedef struct drm_radeon_surface_alloc { +@@ -747,4 +782,106 @@ typedef struct drm_radeon_surface_free { + #define DRM_RADEON_VBLANK_CRTC1 1 + #define DRM_RADEON_VBLANK_CRTC2 2 + ++#define RADEON_GEM_DOMAIN_CPU 0x1 // Cached CPU domain ++#define RADEON_GEM_DOMAIN_GTT 0x2 // GTT or cache flushed ++#define RADEON_GEM_DOMAIN_VRAM 0x4 // VRAM domain ++ ++/* return to userspace start/size of gtt and vram apertures */ ++struct drm_radeon_gem_info { ++ uint64_t gart_start; ++ uint64_t gart_size; ++ uint64_t vram_start; ++ uint64_t vram_size; ++ uint64_t vram_visible; ++}; ++ ++struct drm_radeon_gem_create { ++ uint64_t size; ++ uint64_t alignment; ++ uint32_t handle; ++ uint32_t initial_domain; // to allow VRAM to be created ++ uint32_t no_backing_store; // for VRAM objects - select whether they need backing store ++ // pretty much front/back/depth don't need it - other things do ++}; ++ ++struct drm_radeon_gem_mmap { ++ uint32_t handle; ++ uint32_t pad; ++ uint64_t offset; ++ uint64_t size; ++ uint64_t addr_ptr; ++}; ++ ++struct drm_radeon_gem_set_domain { ++ uint32_t handle; ++ uint32_t read_domains; ++ uint32_t write_domain; ++}; ++ ++struct drm_radeon_gem_wait_rendering { ++ uint32_t handle; ++}; ++ ++struct drm_radeon_gem_pin { ++ uint32_t handle; ++ uint32_t pin_domain; ++ uint64_t alignment; ++ uint64_t offset; ++}; ++ ++struct drm_radeon_gem_unpin { ++ uint32_t handle; ++ uint32_t pad; ++}; ++ ++struct drm_radeon_gem_busy { ++ uint32_t handle; ++ uint32_t busy; ++}; ++ ++struct drm_radeon_gem_pread { ++ /** Handle for the object being read. */ ++ uint32_t handle; ++ uint32_t pad; ++ /** Offset into the object to read from */ ++ uint64_t offset; ++ /** Length of data to read */ ++ uint64_t size; ++ /** Pointer to write the data into. */ ++ uint64_t data_ptr; /* void *, but pointers are not 32/64 compatible */ ++}; ++ ++struct drm_radeon_gem_pwrite { ++ /** Handle for the object being written to. */ ++ uint32_t handle; ++ uint32_t pad; ++ /** Offset into the object to write to */ ++ uint64_t offset; ++ /** Length of data to write */ ++ uint64_t size; ++ /** Pointer to read the data from. */ ++ uint64_t data_ptr; /* void *, but pointers are not 32/64 compatible */ ++}; ++ ++ ++/* New interface which obsolete all previous interface. ++ */ ++ ++#define RADEON_CHUNK_ID_RELOCS 0x01 ++#define RADEON_CHUNK_ID_IB 0x02 ++ ++struct drm_radeon_cs_chunk { ++ uint32_t chunk_id; ++ uint32_t length_dw; ++ uint64_t chunk_data; ++}; ++ ++struct drm_radeon_cs { ++ uint32_t num_chunks; ++ uint32_t cs_id; ++ uint64_t chunks; /* this points to uint64_t * which point to ++ cs chunks */ ++}; ++ ++ + #endif diff --git a/libdrm.spec b/libdrm.spec index 34b408a..ee06fdb 100644 --- a/libdrm.spec +++ b/libdrm.spec @@ -16,6 +16,8 @@ BuildRequires: pkgconfig automake autoconf libtool BuildRequires: kernel-headers >= 2.6.27-0.317.rc5.git10.fc10 +BuildRequires: libxcb-devel + Source2: 91-drm-modeset.rules Source3: i915modeset diff --git a/sources b/sources index 41033f2..55c3345 100644 --- a/sources +++ b/sources @@ -1 +1 @@ -30049dfd7ad96e0beb5edf01f0af422e libdrm-20080930.tar.bz2 +e6c89878001cb2c25b2dce411b40eb3a libdrm-2.4.3.tar.bz2