diff options
author | Owain Ainsworth <oga@cvs.openbsd.org> | 2008-11-22 21:26:49 +0000 |
---|---|---|
committer | Owain Ainsworth <oga@cvs.openbsd.org> | 2008-11-22 21:26:49 +0000 |
commit | efaaf8fdb0ae277917aee89ce3717ef1fa793fa0 (patch) | |
tree | 1b5628ae32f72b00560a9f3eb1394e984b21d2e0 /sys/dev/pci/drm/r128_drv.c | |
parent | e352ee055ffd21c59021f5da76de929ac5cd366e (diff) |
Move the drm drivers over from:
vga1 at pci0
inteldrm0 at vga1
to
vga1 at pci0
inteldrm0 at vga1
drm0 at inteldrm0
i.e. a similar scheme to audio(4) where the interface attaches on top of
the wildly different drivers. This helps to clean up the code a lot
(more is coming) and help me start to move drm to being essentially bus
independent, which will help in the future.
Diffstat (limited to 'sys/dev/pci/drm/r128_drv.c')
-rw-r--r-- | sys/dev/pci/drm/r128_drv.c | 31 |
1 files changed, 12 insertions, 19 deletions
diff --git a/sys/dev/pci/drm/r128_drv.c b/sys/dev/pci/drm/r128_drv.c index aa0911303a8..35dd1ba0828 100644 --- a/sys/dev/pci/drm/r128_drv.c +++ b/sys/dev/pci/drm/r128_drv.c @@ -110,41 +110,34 @@ static const struct drm_driver_info ragedrm_driver = { int ragedrm_probe(struct device *parent, void *match, void *aux) { - return drm_probe((struct pci_attach_args *)aux, ragedrm_pciidlist); + return drm_pciprobe((struct pci_attach_args *)aux, ragedrm_pciidlist); } void ragedrm_attach(struct device *parent, struct device *self, void *aux) { - struct pci_attach_args *pa = aux; - struct drm_device *dev = (struct drm_device *)self; - drm_r128_private_t *dev_priv; + drm_r128_private_t *dev_priv = (drm_r128_private_t *)self; + struct pci_attach_args *pa = aux; - dev_priv = drm_calloc(1, sizeof(*dev_priv), DRM_MEM_DRIVER); - if (dev_priv == NULL) - return; - dev->dev_private = (void *)dev_priv; - - dev->driver = &ragedrm_driver; - return drm_attach(parent, self, pa); + dev_priv->drmdev = drm_attach_mi(&ragedrm_driver, pa, parent, self); } int ragedrm_detach(struct device *self, int flags) { - struct drm_device *dev = (struct drm_device *)self; - drm_r128_private_t *dev_priv = dev->dev_private; + drm_r128_private_t *dev_priv = (drm_r128_private_t *)self; - drm_free(dev_priv, sizeof(*dev_priv), - DRM_MEM_DRIVER); - dev->dev_private = NULL; + if (dev_priv->drmdev != NULL) { + config_detach(dev_priv->drmdev, flags); + dev_priv->drmdev = NULL; + } - return (drm_detach(self, flags)); + return (0); } struct cfattach ragedrm_ca = { - sizeof(struct drm_device), ragedrm_probe, ragedrm_attach, - ragedrm_detach, drm_activate + sizeof(drm_r128_private_t), ragedrm_probe, ragedrm_attach, + ragedrm_detach }; struct cfdriver ragedrm_cd = { |