535N/A/*
535N/A * Copyright (c) 2006, 2012, Oracle and/or its affiliates. All rights reserved.
535N/A *
535N/A * Permission is hereby granted, free of charge, to any person obtaining a
943N/A * copy of this software and associated documentation files (the "Software"),
535N/A * to deal in the Software without restriction, including without limitation
535N/A * the rights to use, copy, modify, merge, publish, distribute, sublicense,
919N/A * and/or sell copies of the Software, and to permit persons to whom the
919N/A * Software is furnished to do so, subject to the following conditions:
919N/A *
919N/A * The above copyright notice and this permission notice (including the next
919N/A * paragraph) shall be included in all copies or substantial portions of the
919N/A * Software.
919N/A *
919N/A * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
919N/A * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
919N/A * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
919N/A * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
919N/A * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
919N/A * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
919N/A * DEALINGS IN THE SOFTWARE.
919N/A */
919N/A
919N/A/*
535N/A * Copyright (c) 2012 Intel Corporation. All rights reserved.
535N/A */
535N/A
535N/A#include <sys/types.h>
535N/A#include <sys/errno.h>
535N/A#include <sys/conf.h>
535N/A#include <sys/kmem.h>
535N/A#include <sys/visual_io.h>
535N/A#include <sys/fbio.h>
911N/A#include <sys/ddi.h>
911N/A#include <sys/sunddi.h>
911N/A#include <sys/stat.h>
911N/A#include <sys/file.h>
535N/A#include <sys/open.h>
535N/A#include <sys/modctl.h>
535N/A#include <sys/pci.h>
535N/A#include <sys/kd.h>
535N/A#include <sys/ddi_impldefs.h>
535N/A#include <sys/sunldi.h>
535N/A#include <sys/mkdev.h>
535N/A#include "drmP.h"
535N/A#include <sys/agpgart.h>
535N/A#include <sys/agp/agpdefs.h>
535N/A#include <sys/agp/agpmaster_io.h>
535N/A
535N/A/**
535N/A * drm_sysfs_device_add - adds a class device to sysfs for a character driver
969N/A * @dev: DRM device to be added
535N/A * @head: DRM head in question
535N/A *
535N/A * Add a DRM device to the DRM's device model class. We use @dev's PCI device
535N/A * as the parent for the Linux device, and make sure it has a file containing
535N/A * the driver we're using (for userspace compatibility).
535N/A */
970N/Aint drm_sysfs_device_add(struct drm_minor *minor)
970N/A{
970N/A struct drm_device *dev = minor->dev;
535N/A gfxp_vgatext_softc_ptr_t gfxp;
int ret;
switch (minor->type) {
case DRM_MINOR_AGPMASTER:
ret = agpmaster_attach(dev->devinfo,
(agp_master_softc_t **)&minor->private,
dev->pdev->pci_cfg_acc_handle, minor->index);
if (ret != DDI_SUCCESS) {
DRM_ERROR("agpmaster_attach failed");
return (ret);
}
return (0);
case DRM_MINOR_VGATEXT:
/* Generic graphics initialization */
gfxp = gfxp_vgatext_softc_alloc();
ret = gfxp_vgatext_attach(dev->devinfo, DDI_ATTACH, gfxp);
if (ret != DDI_SUCCESS) {
DRM_ERROR("gfxp_vgatext_attach failed");
return (EFAULT);
}
minor->private = gfxp;
ret = ddi_create_minor_node(dev->devinfo,
minor->name, S_IFCHR, minor->index, DDI_NT_DISPLAY, NULL);
if (ret != DDI_SUCCESS) {
DRM_ERROR("ddi_create_minor_node failed");
return (EFAULT);
}
return (0);
case DRM_MINOR_LEGACY:
case DRM_MINOR_CONTROL:
case DRM_MINOR_RENDER:
ret = ddi_create_minor_node(dev->devinfo,
minor->name, S_IFCHR, minor->index, DDI_NT_DISPLAY_DRM, NULL);
if (ret != DDI_SUCCESS) {
DRM_ERROR("ddi_create_minor_node failed");
return (EFAULT);
}
return (0);
}
return (ENOTSUP);
}
/**
* drm_sysfs_device_remove - remove DRM device
* @dev: DRM device to remove
*
* This call unregisters and cleans up a class device that was created with a
* call to drm_sysfs_device_add()
*/
void drm_sysfs_device_remove(struct drm_minor *minor)
{
switch (minor->type) {
case DRM_MINOR_AGPMASTER:
if (minor->private) {
agpmaster_detach(
(agp_master_softc_t **)&minor->private);
minor->private = NULL;
}
break;
case DRM_MINOR_VGATEXT:
if (minor->private) {
(void) gfxp_vgatext_detach(minor->dev->devinfo,
DDI_DETACH, minor->private);
gfxp_vgatext_softc_free(minor->private);
minor->private = NULL;
}
/* LINTED */
case DRM_MINOR_LEGACY:
case DRM_MINOR_CONTROL:
case DRM_MINOR_RENDER:
ddi_remove_minor_node(minor->dev->devinfo, minor->name);
}
}