1/* 2 * 3 * Copyright (c) International Business Machines Corp., 2001 4 * 5 * This program is free software; you can redistribute it and/or modify 6 * it under the terms of the GNU General Public License as published by 7 * the Free Software Foundation; either version 2 of the License, or 8 * (at your option) any later version. 9 * 10 * This program is distributed in the hope that it will be useful, 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See 13 * the GNU General Public License for more details. 14 * 15 * You should have received a copy of the GNU General Public License 16 * along with this program; if not, write to the Free Software 17 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 18 * 19 20 * This example module shows how a test driver 21 * can be driven through various ioctl calls in 22 * a user space program that has attained the 23 * appropriate file descriptor for this device. 24 * 25 * author: Kai Zhao 26 * date: 09/03/2003 27 * 28 * module: tdrm 29 */ 30 31#include <linux/types.h> 32#include <linux/kernel.h> 33#include <linux/fs.h> 34#include <linux/ioctl.h> 35#include <linux/module.h> 36#include <linux/init.h> 37#include <asm/uaccess.h> 38#include "str_drm.h" 39 40#include <linux/config.h> 41#include "tdrm.h" 42#include "drmP.h" 43 44#define DRIVER_AUTHOR "Kai Zhao" 45 46#define DRIVER_DESC "drm test mode" 47#define DRIVER_DATE "20030903" 48 49static drm_pci_list_t DRM(idlist)[] = 50{ 51 { 52 PCI_ANY_ID, PCI_ANY_ID}, { 53 0, 0} 54}; 55 56#define DRIVER_CARD_LIST DRM(idlist) 57 58#define DRIVER_FOPS \ 59static struct file_operations DRM(fops) = { \ 60 .owner = THIS_MODULE, \ 61 .open = DRM(open), \ 62 .flush = DRM(flush), \ 63 .release = DRM(release), \ 64 .ioctl = DRM(ioctl), \ 65 .mmap = DRM(mmap), \ 66 .read = DRM(read), \ 67 .fasync = DRM(fasync), \ 68 .poll = DRM(poll), \ 69} 70 71#include "drm_auth.h" 72#include "drm_bufs.h" 73#include "drm_context.h" 74#include "drm_dma.h" 75#include "drm_drawable.h" 76#include "drm_drv.h" 77 78static int minor = 0; 79static unsigned long alloc_pages_address = 0; 80 81int tdrm_test_stub_register(struct inode *inode, struct file *filp, 82 unsigned int cmd, unsigned long arg) 83{ 84 drm_file_t *priv = filp->private_data; 85 drm_device_t *dev = priv->dev; 86 minor = DRM(stub_register) (DEVICE_NAME, &DRM(fops), dev); 87 printk("tdrm stub register : minor = %d\n", minor); 88 return 0; 89 90} 91 92int tdrm_test_stub_unregister(struct inode *inode, struct file *filp, 93 unsigned int cmd, unsigned long arg) 94{ 95 DRM(stub_unregister) (minor); 96 return 0; 97} 98 99int tdrm_test_uninit_agp(struct inode *inode, struct file *filp, 100 unsigned int cmd, unsigned long arg) 101{ 102 DRM(agp_uninit) (); 103 return 0; 104} 105 106int tdrm_test_init_agp(struct inode *inode, struct file *filp, 107 unsigned int cmd, unsigned long arg) 108{ 109 DRM(agp_init) (); 110 return 0; 111} 112 113int tdrm_test_add_magic(struct inode *inode, struct file *filp, 114 unsigned int cmd, unsigned long arg) 115{ 116 drm_file_t *priv = filp->private_data; 117 drm_device_t *dev = priv->dev; 118 int magic = 5; 119 return (DRM(add_magic) (dev, priv, magic)); 120} 121 122int tdrm_test_remove_magic(struct inode *inode, struct file *filp, 123 unsigned int cmd, unsigned long arg) 124{ 125 drm_file_t *priv = filp->private_data; 126 drm_device_t *dev = priv->dev; 127 int magic = 5; 128 return (DRM(remove_magic) (dev, magic)); 129} 130 131int tdrm_test_ctxbitmap_init(struct inode *inode, struct file *filp, 132 unsigned int cmd, unsigned long arg) 133{ 134 drm_file_t *priv = filp->private_data; 135 drm_device_t *dev = priv->dev; 136 return (DRM(ctxbitmap_init) (dev)); 137} 138 139int tdrm_test_ctxbitmap_cleanup(struct inode *inode, struct file *filp, 140 unsigned int cmd, unsigned long arg) 141{ 142 drm_file_t *priv = filp->private_data; 143 drm_device_t *dev = priv->dev; 144 DRM(ctxbitmap_cleanup) (dev); 145 return 0; 146} 147 148int tdrm_test_alloc_pages(struct inode *inode, struct file *filp, 149 unsigned int cmd, unsigned long arg) 150{ 151 alloc_pages_address = DRM(alloc_pages) (1, 0); 152// printk("address = %ld\n",alloc_pages_address); 153 return 0; 154} 155 156int tdrm_test_free_pages(struct inode *inode, struct file *filp, 157 unsigned int cmd, unsigned long arg) 158{ 159 DRM(free_pages) (alloc_pages_address, 1, 0); 160 return 0; 161} 162 163#ifndef MODULE 164 165/* JH- We have to hand expand the string ourselves because of the cpp. If 166 * anyone can think of a way that we can fit into the __setup macro without 167 * changing it, then please send the solution my way. 168 */ 169static int __init tdrm_options(char *str) 170{ 171 DRM(parse_options) (str); 172 return 1; 173} 174 175__setup(DRIVER_NAME "=", tdrm_options); 176#endif 177 178#include "drm_fops.h" 179#include "drm_init.h" 180#include "drm_ioctl.h" 181#include "drm_lock.h" 182#include "drm_memory.h" 183#include "drm_proc.h" 184#include "drm_vm.h" 185#include "drm_stub.h" 186#include "drm_agpsupport.h" 187