vboxvideo_device.c revision 0e159a2dda6eae3a285b4da76c0572abda2a7714
/** @file $Id$
*
* VirtualBox Additions Linux kernel video driver
*/
/*
* Copyright (C) 2011-2012 Oracle Corporation
*
* This file is part of VirtualBox Open Source Edition (OSE), as
* available from http://www.virtualbox.org. This file is free software;
* General Public License (GPL) as published by the Free Software
* Foundation, in version 2 as it comes in the "COPYING" file of the
* VirtualBox OSE distribution. VirtualBox OSE is distributed in the
* hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
* --------------------------------------------------------------------
*
* This code is based on
* with the following copyright and permission notice:
*
* Copyright 2010 Matt Turner.
*
* 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,
* Software is furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice 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
* THE COPYRIGHT HOLDER(S) OR AUTHOR(S) 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: Matt Turner
*/
#include "the-linux-kernel.h"
#include "vboxvideo_drv.h"
#include <VBox/VBoxVideoGuest.h>
{
unsigned size;
int ret;
int rc = VINF_SUCCESS;
void *pvGuestHeapMemory;
/* set accessible VRAM */
VBOXVIDEO_ERROR("can't region_reserve VRAM\n");
return -ENXIO;
}
&gdev->framebuffer);
if (!pVBox->fHaveHGSMI)
return 0;
NULL);
if (RT_FAILURE(rc))
{
gdev->fHaveHGSMI = false;
return 0;
}
return 0;
}
{
if (gdev->framebuffer)
}
{
unsigned i;
{
pVBox->aoffVBVABuffer[i],
}
TRACE_LOG("Maximum framebuffer size: %lu (0x%lx)\n",
vboxFillViewInfo, (void *)pVBox);
if (RT_FAILURE(rc))
{
xf86DrvMsg(pScrn->scrnIndex, X_ERROR, "Failed to send the view information to the host, rc=%d\n", rc);
return FALSE;
}
return TRUE;
}
struct drm_device *ddev,
{
int ret;
/** @todo hardware initialisation goes here once we start doing more complex
* stuff.
*/
if (ret)
return ret;
if (!gdev->fHaveHGSMI)
return 0;
if (ret)
{
gdev->fHaveHGSMI = false;
return ret;
}
return 0;
}
{
}