2005-04-17 02:20:36 +04:00
/* sis.c -- sis driver -*- linux-c -*-
*
* 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 :
2005-09-25 08:28:13 +04:00
*
2005-04-17 02:20:36 +04:00
* The above copyright notice and this permission notice ( including the next
* paragraph ) shall be included in all copies or substantial portions of the
* Software .
2005-09-25 08:28:13 +04:00
*
2005-04-17 02:20:36 +04:00
* 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
* PRECISION INSIGHT 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 .
*
*/
# include "drmP.h"
# include "sis_drm.h"
# include "sis_drv.h"
# include "drm_pciids.h"
2005-09-25 08:28:13 +04:00
2005-04-17 02:20:36 +04:00
static struct pci_device_id pciidlist [ ] = {
sisdrv_PCI_IDS
} ;
2007-07-11 09:53:27 +04:00
static int sis_driver_load ( struct drm_device * dev , unsigned long chipset )
2006-08-07 16:03:22 +04:00
{
drm_sis_private_t * dev_priv ;
int ret ;
dev_priv = drm_calloc ( 1 , sizeof ( drm_sis_private_t ) , DRM_MEM_DRIVER ) ;
if ( dev_priv = = NULL )
return DRM_ERR ( ENOMEM ) ;
dev - > dev_private = ( void * ) dev_priv ;
dev_priv - > chipset = chipset ;
ret = drm_sman_init ( & dev_priv - > sman , 2 , 12 , 8 ) ;
if ( ret ) {
drm_free ( dev_priv , sizeof ( dev_priv ) , DRM_MEM_DRIVER ) ;
}
return ret ;
}
2007-07-11 09:53:27 +04:00
static int sis_driver_unload ( struct drm_device * dev )
2006-08-07 16:03:22 +04:00
{
drm_sis_private_t * dev_priv = dev - > dev_private ;
drm_sman_takedown ( & dev_priv - > sman ) ;
drm_free ( dev_priv , sizeof ( * dev_priv ) , DRM_MEM_DRIVER ) ;
return 0 ;
}
2005-04-17 02:20:36 +04:00
static struct drm_driver driver = {
. driver_features = DRIVER_USE_AGP | DRIVER_USE_MTRR ,
2006-08-07 16:03:22 +04:00
. load = sis_driver_load ,
. unload = sis_driver_unload ,
. context_dtor = NULL ,
2006-08-08 15:34:46 +04:00
. dma_quiescent = sis_idle ,
2006-08-07 16:03:22 +04:00
. reclaim_buffers = NULL ,
2007-03-23 05:28:33 +03:00
. reclaim_buffers_idlelocked = sis_reclaim_buffers_locked ,
2006-08-07 16:03:22 +04:00
. lastclose = sis_lastclose ,
2005-04-17 02:20:36 +04:00
. get_map_ofs = drm_core_get_map_ofs ,
. get_reg_ofs = drm_core_get_reg_ofs ,
. ioctls = sis_ioctls ,
. fops = {
2005-09-25 08:28:13 +04:00
. owner = THIS_MODULE ,
. open = drm_open ,
. release = drm_release ,
. ioctl = drm_ioctl ,
. mmap = drm_mmap ,
. poll = drm_poll ,
. fasync = drm_fasync ,
2005-11-10 14:16:34 +03:00
} ,
2005-04-17 02:20:36 +04:00
. pci_driver = {
2005-11-10 14:16:34 +03:00
. name = DRIVER_NAME ,
. id_table = pciidlist ,
} ,
. name = DRIVER_NAME ,
. desc = DRIVER_DESC ,
. date = DRIVER_DATE ,
. major = DRIVER_MAJOR ,
. minor = DRIVER_MINOR ,
. patchlevel = DRIVER_PATCHLEVEL ,
2005-04-17 02:20:36 +04:00
} ;
static int __init sis_init ( void )
{
driver . num_ioctls = sis_max_ioctl ;
return drm_init ( & driver ) ;
}
static void __exit sis_exit ( void )
{
drm_exit ( & driver ) ;
}
module_init ( sis_init ) ;
module_exit ( sis_exit ) ;
2005-09-25 08:28:13 +04:00
MODULE_AUTHOR ( DRIVER_AUTHOR ) ;
MODULE_DESCRIPTION ( DRIVER_DESC ) ;
2005-04-17 02:20:36 +04:00
MODULE_LICENSE ( " GPL and additional rights " ) ;