| /* $XFree86$ */ /* -*- mode: c; c-basic-offset: 3 -*- */ |
| /* |
| * Copyright 2000 Gareth Hughes |
| * 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, 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 |
| * GARETH HUGHES 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: |
| * Gareth Hughes <gareth@valinux.com> |
| * Leif Delgass <ldelgass@retinalburn.net> |
| */ |
| |
| #ifndef __MACH64_DRI_H__ |
| #define __MACH64_DRI_H__ 1 |
| |
| #include "xf86drm.h" |
| |
| typedef struct { |
| drm_handle_t fbHandle; |
| |
| drm_handle_t regsHandle; |
| drmSize regsSize; |
| |
| int IsPCI; |
| |
| drm_handle_t agpHandle; /* Handle from drmAgpAlloc */ |
| unsigned long agpOffset; |
| drmSize agpSize; |
| int agpMode; |
| |
| /* DMA descriptor ring */ |
| unsigned long ringStart; /* Offset into AGP space */ |
| drm_handle_t ringHandle; /* Handle from drmAddMap */ |
| drmSize ringMapSize; /* Size of map */ |
| int ringSize; /* Size of ring (in kB) */ |
| drmAddress ringMap; /* Map */ |
| |
| /* vertex buffer data */ |
| unsigned long bufferStart; /* Offset into AGP space */ |
| drm_handle_t bufferHandle; /* Handle from drmAddMap */ |
| drmSize bufferMapSize; /* Size of map */ |
| int bufferSize; /* Size of buffers (in MB) */ |
| drmAddress bufferMap; /* Map */ |
| |
| drmBufMapPtr drmBuffers; /* Buffer map */ |
| int numBuffers; /* Number of buffers */ |
| |
| /* AGP Texture data */ |
| unsigned long agpTexStart; /* Offset into AGP space */ |
| drm_handle_t agpTexHandle; /* Handle from drmAddMap */ |
| drmSize agpTexMapSize; /* Size of map */ |
| int agpTexSize; /* Size of AGP tex space (in MB) */ |
| drmAddress agpTexMap; /* Map */ |
| int log2AGPTexGran; |
| |
| int fbX; |
| int fbY; |
| int backX; |
| int backY; |
| int depthX; |
| int depthY; |
| |
| int frontOffset; |
| int frontPitch; |
| int backOffset; |
| int backPitch; |
| int depthOffset; |
| int depthPitch; |
| |
| int textureOffset; |
| int textureSize; |
| int logTextureGranularity; |
| } ATIDRIServerInfoRec, *ATIDRIServerInfoPtr; |
| |
| typedef struct { |
| int chipset; |
| int width; |
| int height; |
| int mem; |
| int cpp; |
| |
| int IsPCI; |
| int AGPMode; |
| |
| unsigned int frontOffset; |
| unsigned int frontPitch; |
| |
| unsigned int backOffset; |
| unsigned int backPitch; |
| |
| unsigned int depthOffset; |
| unsigned int depthPitch; |
| |
| unsigned int textureOffset; |
| unsigned int textureSize; |
| int logTextureGranularity; |
| |
| drm_handle_t regs; |
| drmSize regsSize; |
| |
| drm_handle_t agp; |
| drmSize agpSize; |
| unsigned int agpTextureOffset; |
| unsigned int agpTextureSize; |
| int logAgpTextureGranularity; |
| } ATIDRIRec, *ATIDRIPtr; |
| |
| #endif /* __MACH64_DRI_H__ */ |