122944501Smrg/* sis_drv.h -- Private header for sis driver -*- linux-c -*- */
222944501Smrg/*
322944501Smrg * Copyright 2005 Eric Anholt
422944501Smrg * All Rights Reserved.
522944501Smrg *
622944501Smrg * Permission is hereby granted, free of charge, to any person obtaining a
722944501Smrg * copy of this software and associated documentation files (the "Software"),
822944501Smrg * to deal in the Software without restriction, including without limitation
922944501Smrg * the rights to use, copy, modify, merge, publish, distribute, sublicense,
1022944501Smrg * and/or sell copies of the Software, and to permit persons to whom the
1122944501Smrg * Software is furnished to do so, subject to the following conditions:
1222944501Smrg *
1322944501Smrg * The above copyright notice and this permission notice (including the next
1422944501Smrg * paragraph) shall be included in all copies or substantial portions of the
1522944501Smrg * Software.
1622944501Smrg *
1722944501Smrg * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
1822944501Smrg * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
1922944501Smrg * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
2022944501Smrg * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
2122944501Smrg * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
2222944501Smrg * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
2322944501Smrg * SOFTWARE.
2422944501Smrg *
2522944501Smrg */
2622944501Smrg
2722944501Smrg#ifndef __SIS_DRM_H__
2822944501Smrg#define __SIS_DRM_H__
2922944501Smrg
3000a23bdaSmrg#include "drm.h"
3100a23bdaSmrg
3200a23bdaSmrg#if defined(__cplusplus)
3300a23bdaSmrgextern "C" {
3400a23bdaSmrg#endif
3500a23bdaSmrg
3622944501Smrg/* SiS specific ioctls */
3722944501Smrg#define NOT_USED_0_3
3822944501Smrg#define DRM_SIS_FB_ALLOC	0x04
3922944501Smrg#define DRM_SIS_FB_FREE	        0x05
4022944501Smrg#define NOT_USED_6_12
4122944501Smrg#define DRM_SIS_AGP_INIT	0x13
4222944501Smrg#define DRM_SIS_AGP_ALLOC	0x14
4322944501Smrg#define DRM_SIS_AGP_FREE	0x15
4422944501Smrg#define DRM_SIS_FB_INIT	        0x16
4522944501Smrg
4622944501Smrg#define DRM_IOCTL_SIS_FB_ALLOC		DRM_IOWR(DRM_COMMAND_BASE + DRM_SIS_FB_ALLOC, drm_sis_mem_t)
4722944501Smrg#define DRM_IOCTL_SIS_FB_FREE		DRM_IOW( DRM_COMMAND_BASE + DRM_SIS_FB_FREE, drm_sis_mem_t)
4822944501Smrg#define DRM_IOCTL_SIS_AGP_INIT		DRM_IOWR(DRM_COMMAND_BASE + DRM_SIS_AGP_INIT, drm_sis_agp_t)
4922944501Smrg#define DRM_IOCTL_SIS_AGP_ALLOC		DRM_IOWR(DRM_COMMAND_BASE + DRM_SIS_AGP_ALLOC, drm_sis_mem_t)
5022944501Smrg#define DRM_IOCTL_SIS_AGP_FREE		DRM_IOW( DRM_COMMAND_BASE + DRM_SIS_AGP_FREE, drm_sis_mem_t)
5122944501Smrg#define DRM_IOCTL_SIS_FB_INIT		DRM_IOW( DRM_COMMAND_BASE + DRM_SIS_FB_INIT, drm_sis_fb_t)
5222944501Smrg/*
5322944501Smrg#define DRM_IOCTL_SIS_FLIP		DRM_IOW( 0x48, drm_sis_flip_t)
5422944501Smrg#define DRM_IOCTL_SIS_FLIP_INIT		DRM_IO(  0x49)
5522944501Smrg#define DRM_IOCTL_SIS_FLIP_FINAL	DRM_IO(  0x50)
5622944501Smrg*/
5722944501Smrg
5822944501Smrgtypedef struct {
5922944501Smrg	int context;
6022944501Smrg	unsigned int offset;
6122944501Smrg	unsigned int size;
6222944501Smrg	unsigned long free;
6322944501Smrg} drm_sis_mem_t;
6422944501Smrg
6522944501Smrgtypedef struct {
6622944501Smrg	unsigned int offset, size;
6722944501Smrg} drm_sis_agp_t;
6822944501Smrg
6922944501Smrgtypedef struct {
7022944501Smrg	unsigned int offset, size;
7122944501Smrg} drm_sis_fb_t;
7222944501Smrg
7300a23bdaSmrg#if defined(__cplusplus)
7400a23bdaSmrg}
7500a23bdaSmrg#endif
7600a23bdaSmrg
7722944501Smrg#endif				/* __SIS_DRM_H__ */
78