2005-04-16 15:20:36 -07:00
/* i810_drv.c -- I810 driver -*- linux-c -*-
* Created : Mon Dec 13 01 : 56 : 22 1999 by jhartmann @ precisioninsight . com
*
* Copyright 1999 Precision Insight , Inc . , Cedar Park , Texas .
* Copyright 2000 VA Linux Systems , Inc . , Sunnyvale , California .
* 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
* VA LINUX SYSTEMS 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 .
*
* Authors :
* Rickard E . ( Rik ) Faith < faith @ valinux . com >
* Jeff Hartmann < jhartmann @ valinux . com >
* Gareth Hughes < gareth @ valinux . com >
*/
2011-08-30 11:04:30 -04:00
# include <linux/module.h>
2012-10-02 18:01:07 +01:00
# include <drm/drmP.h>
# include <drm/i810_drm.h>
2005-04-16 15:20:36 -07:00
# include "i810_drv.h"
2012-10-02 18:01:07 +01:00
# include <drm/drm_pciids.h>
2005-04-16 15:20:36 -07:00
static struct pci_device_id pciidlist [ ] = {
i810_PCI_IDS
} ;
2011-10-31 07:28:57 -07:00
static const struct file_operations i810_driver_fops = {
. owner = THIS_MODULE ,
. open = drm_open ,
. release = drm_release ,
. unlocked_ioctl = drm_ioctl ,
2014-09-23 15:46:49 +02:00
. mmap = drm_legacy_mmap ,
2011-10-31 07:28:57 -07:00
. poll = drm_poll ,
2012-07-09 15:40:07 -07:00
# ifdef CONFIG_COMPAT
. compat_ioctl = drm_compat_ioctl ,
# endif
2011-10-31 07:28:57 -07:00
. llseek = noop_llseek ,
} ;
2005-04-16 15:20:36 -07:00
static struct drm_driver driver = {
2005-09-25 14:28:13 +10:00
. driver_features =
2013-12-11 11:34:33 +01:00
DRIVER_USE_AGP |
2011-10-26 00:54:41 +02:00
DRIVER_HAVE_DMA ,
2005-04-16 15:20:36 -07:00
. dev_priv_size = sizeof ( drm_i810_buf_priv_t ) ,
2005-11-10 22:16:34 +11:00
. load = i810_driver_load ,
. lastclose = i810_driver_lastclose ,
. preclose = i810_driver_preclose ,
2014-08-29 12:12:43 +02:00
. set_busid = drm_pci_set_busid ,
2005-07-10 17:31:26 +10:00
. device_is_agp = i810_driver_device_is_agp ,
2005-04-16 15:20:36 -07:00
. dma_quiescent = i810_driver_dma_quiescent ,
. ioctls = i810_ioctls ,
2011-10-31 07:28:57 -07:00
. fops = & i810_driver_fops ,
2005-11-10 22:16:34 +11:00
. name = DRIVER_NAME ,
. desc = DRIVER_DESC ,
. date = DRIVER_DATE ,
. major = DRIVER_MAJOR ,
. minor = DRIVER_MINOR ,
. patchlevel = DRIVER_PATCHLEVEL ,
2005-04-16 15:20:36 -07:00
} ;
2010-12-15 03:16:38 +10:00
static struct pci_driver i810_pci_driver = {
. name = DRIVER_NAME ,
. id_table = pciidlist ,
} ;
2005-04-16 15:20:36 -07:00
static int __init i810_init ( void )
{
2011-01-25 23:17:15 +01:00
if ( num_possible_cpus ( ) > 1 ) {
pr_err ( " drm/i810 does not support SMP \n " ) ;
return - EINVAL ;
}
2005-04-16 15:20:36 -07:00
driver . num_ioctls = i810_max_ioctl ;
2010-12-15 03:16:38 +10:00
return drm_pci_init ( & driver , & i810_pci_driver ) ;
2005-04-16 15:20:36 -07:00
}
static void __exit i810_exit ( void )
{
2010-12-15 03:16:38 +10:00
drm_pci_exit ( & driver , & i810_pci_driver ) ;
2005-04-16 15:20:36 -07:00
}
module_init ( i810_init ) ;
module_exit ( i810_exit ) ;
2005-09-25 14:28:13 +10:00
MODULE_AUTHOR ( DRIVER_AUTHOR ) ;
MODULE_DESCRIPTION ( DRIVER_DESC ) ;
2005-04-16 15:20:36 -07:00
MODULE_LICENSE ( " GPL and additional rights " ) ;