90848209baf53a74f547fcf4254dc56d9b167ecavboxsync/** @file $Id$
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync *
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * VirtualBox Additions Linux kernel driver, DRM support
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync */
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync/*
c58f1213e628a545081c70e26c6b67a841cff880vboxsync * Copyright (C) 2006-2012 Oracle Corporation
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync *
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * This file is part of VirtualBox Open Source Edition (OSE), as
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * available from http://www.virtualbox.org. This file is free software;
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * you can redistribute it and/or modify it under the terms of the GNU
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * General Public License (GPL) as published by the Free Software
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * Foundation, in version 2 as it comes in the "COPYING" file of the
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * --------------------------------------------------------------------
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync *
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * This code is based on:
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync *
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * tdfx_drv.c -- tdfx driver -*- linux-c -*-
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * Created: Thu Oct 7 10:38:32 1999 by faith@precisioninsight.com
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync *
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * Copyright 1999 Precision Insight, Inc., Cedar Park, Texas.
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * Copyright 2000 VA Linux Systems, Inc., Sunnyvale, California.
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * All Rights Reserved.
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync *
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * Permission is hereby granted, free of charge, to any person obtaining a
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * copy of this software and associated documentation files (the "Software"),
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * to deal in the Software without restriction, including without limitation
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * the rights to use, copy, modify, merge, publish, distribute, sublicense,
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * and/or sell copies of the Software, and to permit persons to whom the
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * Software is furnished to do so, subject to the following conditions:
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync *
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * The above copyright notice and this permission notice (including the next
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * paragraph) shall be included in all copies or substantial portions of the
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * Software.
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync *
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * PRECISION INSIGHT AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * DEALINGS IN THE SOFTWARE.
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync *
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * Authors:
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * Rickard E. (Rik) Faith <faith@valinux.com>
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * Daryll Strauss <daryll@valinux.com>
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync * Gareth Hughes <gareth@valinux.com>
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync */
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync
e43535ace2499e7f8ef8822186047979bd58d464vboxsync#include "version-generated.h"
e4d40e67c9cbfecb0b2ed48eec081648ba3a14bavboxsync
91f0c0700e09523b034dbd8985afdf0066829928vboxsync#include <linux/module.h>
d88b7783eca6d7990151296f0b6091b47d241e40vboxsync#include <linux/version.h>
91f0c0700e09523b034dbd8985afdf0066829928vboxsync#include <drm/drmP.h>
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync#include "vboxvideo_drm.h"
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync
91f0c0700e09523b034dbd8985afdf0066829928vboxsync/* This definition and the file-operations-as-pointer change were both added in
91f0c0700e09523b034dbd8985afdf0066829928vboxsync * kernel 3.3. All back-ports of the structure change to distribution kernels
91f0c0700e09523b034dbd8985afdf0066829928vboxsync * that I have checked also back-ported the definition at the same time. */
91f0c0700e09523b034dbd8985afdf0066829928vboxsync#ifdef DRM_IOCTL_MODE_ADDFB2
91f0c0700e09523b034dbd8985afdf0066829928vboxsync# define DRM_FOPS_AS_POINTER
c7496297385f154fb9681d1d9f65a0a484413e2dvboxsync#endif
c7496297385f154fb9681d1d9f65a0a484413e2dvboxsync
35f9a149bd26957f0f5b492d7cf2b84e449d1cadvboxsync/* The first of these was introduced when drm was generalised to work with
35f9a149bd26957f0f5b492d7cf2b84e449d1cadvboxsync * non-PCI buses, but was removed between 3.15 and 3.16. The second is a
35f9a149bd26957f0f5b492d7cf2b84e449d1cadvboxsync * random definition introduced in the mean-time. */
35f9a149bd26957f0f5b492d7cf2b84e449d1cadvboxsync#if defined(DRIVER_BUS_PCI) || defined(DRIVER_PRIME)
35f9a149bd26957f0f5b492d7cf2b84e449d1cadvboxsync# define DRM_NEW_BUS_INIT 1
35f9a149bd26957f0f5b492d7cf2b84e449d1cadvboxsync#endif
35f9a149bd26957f0f5b492d7cf2b84e449d1cadvboxsync
90848209baf53a74f547fcf4254dc56d9b167ecavboxsyncstatic struct pci_device_id pciidlist[] = {
28023d61db8b6bb393f447d41e639a246dbae010vboxsync vboxvideo_PCI_IDS
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync};
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync
0a350f245609d37cb97e442d3ca659f7ed0e19abvboxsyncMODULE_DEVICE_TABLE(pci, pciidlist);
0a350f245609d37cb97e442d3ca659f7ed0e19abvboxsync
11f9b573aa91144e8a077e34864c9df96ec3d64cvboxsyncint vboxvideo_driver_load(struct drm_device * dev, unsigned long flags)
11f9b573aa91144e8a077e34864c9df96ec3d64cvboxsync{
11f9b573aa91144e8a077e34864c9df96ec3d64cvboxsync return 0;
11f9b573aa91144e8a077e34864c9df96ec3d64cvboxsync}
91f0c0700e09523b034dbd8985afdf0066829928vboxsync
91f0c0700e09523b034dbd8985afdf0066829928vboxsync#ifdef DRM_FOPS_AS_POINTER
28d0d13f7b2546ba9c4fbfc70d8871eb066169cbvboxsync/* since linux-3.3.0-rc1 drm_driver::fops is pointer */
28d0d13f7b2546ba9c4fbfc70d8871eb066169cbvboxsyncstatic struct file_operations driver_fops =
28d0d13f7b2546ba9c4fbfc70d8871eb066169cbvboxsync{
28d0d13f7b2546ba9c4fbfc70d8871eb066169cbvboxsync .owner = THIS_MODULE,
28d0d13f7b2546ba9c4fbfc70d8871eb066169cbvboxsync .open = drm_open,
28d0d13f7b2546ba9c4fbfc70d8871eb066169cbvboxsync .release = drm_release,
28d0d13f7b2546ba9c4fbfc70d8871eb066169cbvboxsync .unlocked_ioctl = drm_ioctl,
d88b7783eca6d7990151296f0b6091b47d241e40vboxsync# if LINUX_VERSION_CODE < KERNEL_VERSION(3, 18, 0)
d88b7783eca6d7990151296f0b6091b47d241e40vboxsync /* This shouldn't be necessary even for old kernels as there is
d88b7783eca6d7990151296f0b6091b47d241e40vboxsync * nothing sensible to mmap. But we play safe and keep it for
d88b7783eca6d7990151296f0b6091b47d241e40vboxsync * legacy reasons. */
28d0d13f7b2546ba9c4fbfc70d8871eb066169cbvboxsync .mmap = drm_mmap,
d88b7783eca6d7990151296f0b6091b47d241e40vboxsync# endif
28d0d13f7b2546ba9c4fbfc70d8871eb066169cbvboxsync .poll = drm_poll,
28d0d13f7b2546ba9c4fbfc70d8871eb066169cbvboxsync};
28d0d13f7b2546ba9c4fbfc70d8871eb066169cbvboxsync#endif
11f9b573aa91144e8a077e34864c9df96ec3d64cvboxsync
28023d61db8b6bb393f447d41e639a246dbae010vboxsyncstatic struct drm_driver driver =
28023d61db8b6bb393f447d41e639a246dbae010vboxsync{
28023d61db8b6bb393f447d41e639a246dbae010vboxsync /* .driver_features = DRIVER_USE_MTRR, */
28023d61db8b6bb393f447d41e639a246dbae010vboxsync .load = vboxvideo_driver_load,
d260a602a58cb03b80a4fc9490a6d6976f7cb4b8vboxsync#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 18, 0)
d260a602a58cb03b80a4fc9490a6d6976f7cb4b8vboxsync /* If this is missing a warning gets printed to dmesg. We will not
d260a602a58cb03b80a4fc9490a6d6976f7cb4b8vboxsync * attempt to make kernels work to which the change (915b4d11b) got back-
d260a602a58cb03b80a4fc9490a6d6976f7cb4b8vboxsync * ported, as the problem is only cosmetic. */
d260a602a58cb03b80a4fc9490a6d6976f7cb4b8vboxsync .set_busid = drm_pci_set_busid,
d260a602a58cb03b80a4fc9490a6d6976f7cb4b8vboxsync#endif
91f0c0700e09523b034dbd8985afdf0066829928vboxsync# ifndef DRM_FOPS_AS_POINTER
28023d61db8b6bb393f447d41e639a246dbae010vboxsync .fops =
28023d61db8b6bb393f447d41e639a246dbae010vboxsync {
28023d61db8b6bb393f447d41e639a246dbae010vboxsync .owner = THIS_MODULE,
28023d61db8b6bb393f447d41e639a246dbae010vboxsync .open = drm_open,
28023d61db8b6bb393f447d41e639a246dbae010vboxsync .release = drm_release,
28023d61db8b6bb393f447d41e639a246dbae010vboxsync /* This was changed with Linux 2.6.33 but Fedora backported this
28023d61db8b6bb393f447d41e639a246dbae010vboxsync * change to their 2.6.32 kernel. */
91f0c0700e09523b034dbd8985afdf0066829928vboxsync#if defined(DRM_UNLOCKED)
28023d61db8b6bb393f447d41e639a246dbae010vboxsync .unlocked_ioctl = drm_ioctl,
6a608eb4f69e5bc1838d17fb9132acbbc6575e7cvboxsync#else
28023d61db8b6bb393f447d41e639a246dbae010vboxsync .ioctl = drm_ioctl,
28023d61db8b6bb393f447d41e639a246dbae010vboxsync#endif
28023d61db8b6bb393f447d41e639a246dbae010vboxsync .mmap = drm_mmap,
28023d61db8b6bb393f447d41e639a246dbae010vboxsync .poll = drm_poll,
28023d61db8b6bb393f447d41e639a246dbae010vboxsync },
91f0c0700e09523b034dbd8985afdf0066829928vboxsync#else /* defined(DRM_FOPS_AS_POINTER) */
1d986eadc28df256d19dd4f912d40bd9fc0a8036vboxsync .fops = &driver_fops,
28d0d13f7b2546ba9c4fbfc70d8871eb066169cbvboxsync#endif
35f9a149bd26957f0f5b492d7cf2b84e449d1cadvboxsync#ifndef DRM_NEW_BUS_INIT
28023d61db8b6bb393f447d41e639a246dbae010vboxsync .pci_driver =
28023d61db8b6bb393f447d41e639a246dbae010vboxsync {
28023d61db8b6bb393f447d41e639a246dbae010vboxsync .name = DRIVER_NAME,
28023d61db8b6bb393f447d41e639a246dbae010vboxsync .id_table = pciidlist,
28023d61db8b6bb393f447d41e639a246dbae010vboxsync },
6a608eb4f69e5bc1838d17fb9132acbbc6575e7cvboxsync#endif
28023d61db8b6bb393f447d41e639a246dbae010vboxsync .name = DRIVER_NAME,
28023d61db8b6bb393f447d41e639a246dbae010vboxsync .desc = DRIVER_DESC,
28023d61db8b6bb393f447d41e639a246dbae010vboxsync .date = DRIVER_DATE,
28023d61db8b6bb393f447d41e639a246dbae010vboxsync .major = DRIVER_MAJOR,
28023d61db8b6bb393f447d41e639a246dbae010vboxsync .minor = DRIVER_MINOR,
28023d61db8b6bb393f447d41e639a246dbae010vboxsync .patchlevel = DRIVER_PATCHLEVEL,
28023d61db8b6bb393f447d41e639a246dbae010vboxsync};
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync
35f9a149bd26957f0f5b492d7cf2b84e449d1cadvboxsync#ifdef DRM_NEW_BUS_INIT
28023d61db8b6bb393f447d41e639a246dbae010vboxsyncstatic struct pci_driver pci_driver =
28023d61db8b6bb393f447d41e639a246dbae010vboxsync{
28023d61db8b6bb393f447d41e639a246dbae010vboxsync .name = DRIVER_NAME,
28023d61db8b6bb393f447d41e639a246dbae010vboxsync .id_table = pciidlist,
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync};
28023d61db8b6bb393f447d41e639a246dbae010vboxsync#endif
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync
90848209baf53a74f547fcf4254dc56d9b167ecavboxsyncstatic int __init vboxvideo_init(void)
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync{
35f9a149bd26957f0f5b492d7cf2b84e449d1cadvboxsync#ifndef DRM_NEW_BUS_INIT
28023d61db8b6bb393f447d41e639a246dbae010vboxsync return drm_init(&driver);
28023d61db8b6bb393f447d41e639a246dbae010vboxsync#else
28023d61db8b6bb393f447d41e639a246dbae010vboxsync return drm_pci_init(&driver, &pci_driver);
28023d61db8b6bb393f447d41e639a246dbae010vboxsync#endif
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync}
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync
90848209baf53a74f547fcf4254dc56d9b167ecavboxsyncstatic void __exit vboxvideo_exit(void)
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync{
35f9a149bd26957f0f5b492d7cf2b84e449d1cadvboxsync#ifndef DRM_NEW_BUS_INIT
28023d61db8b6bb393f447d41e639a246dbae010vboxsync drm_exit(&driver);
28023d61db8b6bb393f447d41e639a246dbae010vboxsync#else
28023d61db8b6bb393f447d41e639a246dbae010vboxsync drm_pci_exit(&driver, &pci_driver);
28023d61db8b6bb393f447d41e639a246dbae010vboxsync#endif
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync}
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync
90848209baf53a74f547fcf4254dc56d9b167ecavboxsyncmodule_init(vboxvideo_init);
90848209baf53a74f547fcf4254dc56d9b167ecavboxsyncmodule_exit(vboxvideo_exit);
90848209baf53a74f547fcf4254dc56d9b167ecavboxsync
90848209baf53a74f547fcf4254dc56d9b167ecavboxsyncMODULE_AUTHOR(DRIVER_AUTHOR);
90848209baf53a74f547fcf4254dc56d9b167ecavboxsyncMODULE_DESCRIPTION(DRIVER_DESC);
e43535ace2499e7f8ef8822186047979bd58d464vboxsync#ifdef MODULE_VERSION
e43535ace2499e7f8ef8822186047979bd58d464vboxsyncMODULE_VERSION(VBOX_VERSION_STRING);
e43535ace2499e7f8ef8822186047979bd58d464vboxsync#endif
e482bceaf56f15ca2dc706c32feeb275933d96f9vboxsyncMODULE_LICENSE("GPL and additional rights");