Release 4.11 drivers/gpu/drm/sis/sis_drv.c
/* 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:
*
* 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
* 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 <linux/module.h>
#include <drm/drmP.h>
#include <drm/sis_drm.h>
#include "sis_drv.h"
#include <drm/drm_pciids.h>
static struct pci_device_id pciidlist[] = {
sisdrv_PCI_IDS
};
static int sis_driver_load(struct drm_device *dev, unsigned long chipset)
{
drm_sis_private_t *dev_priv;
pci_set_master(dev->pdev);
dev_priv = kzalloc(sizeof(drm_sis_private_t), GFP_KERNEL);
if (dev_priv == NULL)
return -ENOMEM;
idr_init(&dev_priv->object_idr);
dev->dev_private = (void *)dev_priv;
dev_priv->chipset = chipset;
return 0;
}
Contributors
Person | Tokens | Prop | Commits | CommitProp |
Thomas Hellstrom | 54 | 72.00% | 1 | 14.29% |
Dave Airlie | 9 | 12.00% | 2 | 28.57% |
Márton Németh | 8 | 10.67% | 1 | 14.29% |
Eric Anholt | 3 | 4.00% | 2 | 28.57% |
Jesper Juhl | 1 | 1.33% | 1 | 14.29% |
Total | 75 | 100.00% | 7 | 100.00% |
static void sis_driver_unload(struct drm_device *dev)
{
drm_sis_private_t *dev_priv = dev->dev_private;
idr_destroy(&dev_priv->object_idr);
kfree(dev_priv);
}
Contributors
Person | Tokens | Prop | Commits | CommitProp |
Thomas Hellstrom | 20 | 62.50% | 1 | 20.00% |
Daniel Vetter | 8 | 25.00% | 1 | 20.00% |
Dave Airlie | 2 | 6.25% | 1 | 20.00% |
Gabriel Krisman Bertazi | 1 | 3.12% | 1 | 20.00% |
Eric Anholt | 1 | 3.12% | 1 | 20.00% |
Total | 32 | 100.00% | 5 | 100.00% |
static const struct file_operations sis_driver_fops = {
.owner = THIS_MODULE,
.open = drm_open,
.release = drm_release,
.unlocked_ioctl = drm_ioctl,
.mmap = drm_legacy_mmap,
.poll = drm_poll,
.compat_ioctl = drm_compat_ioctl,
.llseek = noop_llseek,
};
static int sis_driver_open(struct drm_device *dev, struct drm_file *file)
{
struct sis_file_private *file_priv;
DRM_DEBUG_DRIVER("\n");
file_priv = kmalloc(sizeof(*file_priv), GFP_KERNEL);
if (!file_priv)
return -ENOMEM;
file->driver_priv = file_priv;
INIT_LIST_HEAD(&file_priv->obj_list);
return 0;
}
Contributors
Person | Tokens | Prop | Commits | CommitProp |
Daniel Vetter | 65 | 100.00% | 1 | 100.00% |
Total | 65 | 100.00% | 1 | 100.00% |
static void sis_driver_postclose(struct drm_device *dev, struct drm_file *file)
{
struct sis_file_private *file_priv = file->driver_priv;
kfree(file_priv);
}
Contributors
Person | Tokens | Prop | Commits | CommitProp |
Daniel Vetter | 29 | 96.67% | 1 | 50.00% |
Rashika Kheria | 1 | 3.33% | 1 | 50.00% |
Total | 30 | 100.00% | 2 | 100.00% |
static struct drm_driver driver = {
.driver_features = DRIVER_USE_AGP | DRIVER_LEGACY,
.load = sis_driver_load,
.unload = sis_driver_unload,
.open = sis_driver_open,
.preclose = sis_reclaim_buffers_locked,
.postclose = sis_driver_postclose,
.set_busid = drm_pci_set_busid,
.dma_quiescent = sis_idle,
.lastclose = sis_lastclose,
.ioctls = sis_ioctls,
.fops = &sis_driver_fops,
.name = DRIVER_NAME,
.desc = DRIVER_DESC,
.date = DRIVER_DATE,
.major = DRIVER_MAJOR,
.minor = DRIVER_MINOR,
.patchlevel = DRIVER_PATCHLEVEL,
};
static struct pci_driver sis_pci_driver = {
.name = DRIVER_NAME,
.id_table = pciidlist,
};
static int __init sis_init(void)
{
driver.num_ioctls = sis_max_ioctl;
return drm_pci_init(&driver, &sis_pci_driver);
}
Contributors
Person | Tokens | Prop | Commits | CommitProp |
Dave Airlie | 25 | 100.00% | 4 | 100.00% |
Total | 25 | 100.00% | 4 | 100.00% |
static void __exit sis_exit(void)
{
drm_pci_exit(&driver, &sis_pci_driver);
}
Contributors
Person | Tokens | Prop | Commits | CommitProp |
Dave Airlie | 18 | 100.00% | 3 | 100.00% |
Total | 18 | 100.00% | 3 | 100.00% |
module_init(sis_init);
module_exit(sis_exit);
MODULE_AUTHOR(DRIVER_AUTHOR);
MODULE_DESCRIPTION(DRIVER_DESC);
MODULE_LICENSE("GPL and additional rights");
Overall Contributors
Person | Tokens | Prop | Commits | CommitProp |
Dave Airlie | 169 | 37.06% | 9 | 31.03% |
Daniel Vetter | 120 | 26.32% | 5 | 17.24% |
Thomas Hellstrom | 84 | 18.42% | 2 | 6.90% |
Arjan van de Ven | 40 | 8.77% | 1 | 3.45% |
Linus Torvalds | 9 | 1.97% | 1 | 3.45% |
Márton Németh | 8 | 1.75% | 1 | 3.45% |
David Herrmann | 5 | 1.10% | 1 | 3.45% |
Keith Packard | 5 | 1.10% | 1 | 3.45% |
Eric Anholt | 4 | 0.88% | 2 | 6.90% |
Paul Gortmaker | 3 | 0.66% | 1 | 3.45% |
Arnd Bergmann | 3 | 0.66% | 1 | 3.45% |
David Howells | 3 | 0.66% | 1 | 3.45% |
Rashika Kheria | 1 | 0.22% | 1 | 3.45% |
Gabriel Krisman Bertazi | 1 | 0.22% | 1 | 3.45% |
Jesper Juhl | 1 | 0.22% | 1 | 3.45% |
Total | 456 | 100.00% | 29 | 100.00% |
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.