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 49 static 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 \ 59 static 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 78 static int minor = 0; 79 static unsigned long alloc_pages_address = 0; 80 81 int 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 92 int 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 99 int 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 106 int 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 113 int 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 122 int 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 131 int 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 139 int 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 148 int 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 156 int 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 */ 169 static 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