diff options
Diffstat (limited to 'drivers/gpu/drm/r128')
| -rw-r--r-- | drivers/gpu/drm/r128/r128_cce.c | 12 | ||||
| -rw-r--r-- | drivers/gpu/drm/r128/r128_drv.c | 54 | ||||
| -rw-r--r-- | drivers/gpu/drm/r128/r128_drv.h | 6 | ||||
| -rw-r--r-- | drivers/gpu/drm/r128/r128_ioc32.c | 8 | ||||
| -rw-r--r-- | drivers/gpu/drm/r128/r128_irq.c | 7 | ||||
| -rw-r--r-- | drivers/gpu/drm/r128/r128_state.c | 77 | 
6 files changed, 71 insertions, 93 deletions
diff --git a/drivers/gpu/drm/r128/r128_cce.c b/drivers/gpu/drm/r128/r128_cce.c index 570e190710b..59459fe4e8c 100644 --- a/drivers/gpu/drm/r128/r128_cce.c +++ b/drivers/gpu/drm/r128/r128_cce.c @@ -32,10 +32,10 @@  #include <linux/firmware.h>  #include <linux/platform_device.h>  #include <linux/slab.h> +#include <linux/module.h> -#include "drmP.h" -#include "drm.h" -#include "r128_drm.h" +#include <drm/drmP.h> +#include <drm/r128_drm.h>  #include "r128_drv.h"  #define R128_FIFO_DEBUG		0 @@ -540,7 +540,7 @@ static int r128_do_init_cce(struct drm_device *dev, drm_r128_init_t *init)  	dev_priv->ring.end = ((u32 *) dev_priv->cce_ring->handle  			      + init->ring_size / sizeof(u32));  	dev_priv->ring.size = init->ring_size; -	dev_priv->ring.size_l2qw = drm_order(init->ring_size / 8); +	dev_priv->ring.size_l2qw = order_base_2(init->ring_size / 8);  	dev_priv->ring.tail_mask = (dev_priv->ring.size / sizeof(u32)) - 1; @@ -892,10 +892,10 @@ static int r128_cce_get_buffers(struct drm_device *dev,  		buf->file_priv = file_priv; -		if (DRM_COPY_TO_USER(&d->request_indices[i], &buf->idx, +		if (copy_to_user(&d->request_indices[i], &buf->idx,  				     sizeof(buf->idx)))  			return -EFAULT; -		if (DRM_COPY_TO_USER(&d->request_sizes[i], &buf->total, +		if (copy_to_user(&d->request_sizes[i], &buf->total,  				     sizeof(buf->total)))  			return -EFAULT; diff --git a/drivers/gpu/drm/r128/r128_drv.c b/drivers/gpu/drm/r128/r128_drv.c index 18c3c71e41b..5bd307cd8da 100644 --- a/drivers/gpu/drm/r128/r128_drv.c +++ b/drivers/gpu/drm/r128/r128_drv.c @@ -29,20 +29,34 @@   *    Gareth Hughes <gareth@valinux.com>   */ -#include "drmP.h" -#include "drm.h" -#include "r128_drm.h" +#include <linux/module.h> + +#include <drm/drmP.h> +#include <drm/r128_drm.h>  #include "r128_drv.h" -#include "drm_pciids.h" +#include <drm/drm_pciids.h>  static struct pci_device_id pciidlist[] = {  	r128_PCI_IDS  }; +static const struct file_operations r128_driver_fops = { +	.owner = THIS_MODULE, +	.open = drm_open, +	.release = drm_release, +	.unlocked_ioctl = drm_ioctl, +	.mmap = drm_mmap, +	.poll = drm_poll, +#ifdef CONFIG_COMPAT +	.compat_ioctl = r128_compat_ioctl, +#endif +	.llseek = noop_llseek, +}; +  static struct drm_driver driver = {  	.driver_features = -	    DRIVER_USE_AGP | DRIVER_USE_MTRR | DRIVER_PCI_DMA | DRIVER_SG | +	    DRIVER_USE_AGP | DRIVER_PCI_DMA | DRIVER_SG |  	    DRIVER_HAVE_DMA | DRIVER_HAVE_IRQ | DRIVER_IRQ_SHARED,  	.dev_priv_size = sizeof(drm_r128_buf_priv_t),  	.load = r128_driver_load, @@ -55,27 +69,9 @@ static struct drm_driver driver = {  	.irq_postinstall = r128_driver_irq_postinstall,  	.irq_uninstall = r128_driver_irq_uninstall,  	.irq_handler = r128_driver_irq_handler, -	.reclaim_buffers = drm_core_reclaim_buffers,  	.ioctls = r128_ioctls,  	.dma_ioctl = r128_cce_buffers, -	.fops = { -		.owner = THIS_MODULE, -		.open = drm_open, -		.release = drm_release, -		.unlocked_ioctl = drm_ioctl, -		.mmap = drm_mmap, -		.poll = drm_poll, -		.fasync = drm_fasync, -#ifdef CONFIG_COMPAT -		.compat_ioctl = r128_compat_ioctl, -#endif -		.llseek = noop_llseek, -	}, -	.pci_driver = { -		.name = DRIVER_NAME, -		.id_table = pciidlist, -	}, - +	.fops = &r128_driver_fops,  	.name = DRIVER_NAME,  	.desc = DRIVER_DESC,  	.date = DRIVER_DATE, @@ -86,19 +82,25 @@ static struct drm_driver driver = {  int r128_driver_load(struct drm_device *dev, unsigned long flags)  { +	pci_set_master(dev->pdev);  	return drm_vblank_init(dev, 1);  } +static struct pci_driver r128_pci_driver = { +	.name = DRIVER_NAME, +	.id_table = pciidlist, +}; +  static int __init r128_init(void)  {  	driver.num_ioctls = r128_max_ioctl; -	return drm_init(&driver); +	return drm_pci_init(&driver, &r128_pci_driver);  }  static void __exit r128_exit(void)  { -	drm_exit(&driver); +	drm_pci_exit(&driver, &r128_pci_driver);  }  module_init(r128_init); diff --git a/drivers/gpu/drm/r128/r128_drv.h b/drivers/gpu/drm/r128/r128_drv.h index 930c71b2fb5..5bf3f5ff805 100644 --- a/drivers/gpu/drm/r128/r128_drv.h +++ b/drivers/gpu/drm/r128/r128_drv.h @@ -131,7 +131,7 @@ typedef struct drm_r128_buf_priv {  	drm_r128_freelist_t *list_entry;  } drm_r128_buf_priv_t; -extern struct drm_ioctl_desc r128_ioctls[]; +extern const struct drm_ioctl_desc r128_ioctls[];  extern int r128_max_ioctl;  				/* r128_cce.c */ @@ -154,7 +154,7 @@ extern int r128_do_cleanup_cce(struct drm_device *dev);  extern int r128_enable_vblank(struct drm_device *dev, int crtc);  extern void r128_disable_vblank(struct drm_device *dev, int crtc);  extern u32 r128_get_vblank_counter(struct drm_device *dev, int crtc); -extern irqreturn_t r128_driver_irq_handler(DRM_IRQ_ARGS); +extern irqreturn_t r128_driver_irq_handler(int irq, void *arg);  extern void r128_driver_irq_preinstall(struct drm_device *dev);  extern int r128_driver_irq_postinstall(struct drm_device *dev);  extern void r128_driver_irq_uninstall(struct drm_device *dev); @@ -514,7 +514,7 @@ do {									\  	if (R128_VERBOSE)						\  		DRM_INFO("COMMIT_RING() tail=0x%06x\n",			\  			 dev_priv->ring.tail);				\ -	DRM_MEMORYBARRIER();						\ +	mb();						\  	R128_WRITE(R128_PM4_BUFFER_DL_WPTR, dev_priv->ring.tail);	\  	R128_READ(R128_PM4_BUFFER_DL_WPTR);				\  } while (0) diff --git a/drivers/gpu/drm/r128/r128_ioc32.c b/drivers/gpu/drm/r128/r128_ioc32.c index 51c99fc4dd3..663f38c63ba 100644 --- a/drivers/gpu/drm/r128/r128_ioc32.c +++ b/drivers/gpu/drm/r128/r128_ioc32.c @@ -31,9 +31,9 @@   */  #include <linux/compat.h> -#include "drmP.h" -#include "drm.h" -#include "r128_drm.h" +#include <drm/drmP.h> +#include <drm/r128_drm.h> +#include "r128_drv.h"  typedef struct drm_r128_init32 {  	int func; @@ -203,7 +203,7 @@ long r128_compat_ioctl(struct file *filp, unsigned int cmd, unsigned long arg)  	if (nr < DRM_COMMAND_BASE)  		return drm_compat_ioctl(filp, cmd, arg); -	if (nr < DRM_COMMAND_BASE + DRM_ARRAY_SIZE(r128_compat_ioctls)) +	if (nr < DRM_COMMAND_BASE + ARRAY_SIZE(r128_compat_ioctls))  		fn = r128_compat_ioctls[nr - DRM_COMMAND_BASE];  	if (fn != NULL) diff --git a/drivers/gpu/drm/r128/r128_irq.c b/drivers/gpu/drm/r128/r128_irq.c index 429d5a02695..c2ae496babb 100644 --- a/drivers/gpu/drm/r128/r128_irq.c +++ b/drivers/gpu/drm/r128/r128_irq.c @@ -30,9 +30,8 @@   *    Eric Anholt <anholt@FreeBSD.org>   */ -#include "drmP.h" -#include "drm.h" -#include "r128_drm.h" +#include <drm/drmP.h> +#include <drm/r128_drm.h>  #include "r128_drv.h"  u32 r128_get_vblank_counter(struct drm_device *dev, int crtc) @@ -45,7 +44,7 @@ u32 r128_get_vblank_counter(struct drm_device *dev, int crtc)  	return atomic_read(&dev_priv->vbl_received);  } -irqreturn_t r128_driver_irq_handler(DRM_IRQ_ARGS) +irqreturn_t r128_driver_irq_handler(int irq, void *arg)  {  	struct drm_device *dev = (struct drm_device *) arg;  	drm_r128_private_t *dev_priv = (drm_r128_private_t *) dev->dev_private; diff --git a/drivers/gpu/drm/r128/r128_state.c b/drivers/gpu/drm/r128/r128_state.c index a9e33ce6591..575e986f82a 100644 --- a/drivers/gpu/drm/r128/r128_state.c +++ b/drivers/gpu/drm/r128/r128_state.c @@ -28,9 +28,8 @@   *    Gareth Hughes <gareth@valinux.com>   */ -#include "drmP.h" -#include "drm.h" -#include "r128_drm.h" +#include <drm/drmP.h> +#include <drm/r128_drm.h>  #include "r128_drv.h"  /* ================================================================ @@ -896,31 +895,22 @@ static int r128_cce_dispatch_write_span(struct drm_device *dev,  	if (count > 4096 || count <= 0)  		return -EMSGSIZE; -	if (DRM_COPY_FROM_USER(&x, depth->x, sizeof(x))) +	if (copy_from_user(&x, depth->x, sizeof(x)))  		return -EFAULT; -	if (DRM_COPY_FROM_USER(&y, depth->y, sizeof(y))) +	if (copy_from_user(&y, depth->y, sizeof(y)))  		return -EFAULT;  	buffer_size = depth->n * sizeof(u32); -	buffer = kmalloc(buffer_size, GFP_KERNEL); -	if (buffer == NULL) -		return -ENOMEM; -	if (DRM_COPY_FROM_USER(buffer, depth->buffer, buffer_size)) { -		kfree(buffer); -		return -EFAULT; -	} +	buffer = memdup_user(depth->buffer, buffer_size); +	if (IS_ERR(buffer)) +		return PTR_ERR(buffer);  	mask_size = depth->n * sizeof(u8);  	if (depth->mask) { -		mask = kmalloc(mask_size, GFP_KERNEL); -		if (mask == NULL) { +		mask = memdup_user(depth->mask, mask_size); +		if (IS_ERR(mask)) {  			kfree(buffer); -			return -ENOMEM; -		} -		if (DRM_COPY_FROM_USER(mask, depth->mask, mask_size)) { -			kfree(buffer); -			kfree(mask); -			return -EFAULT; +			return PTR_ERR(mask);  		}  		for (i = 0; i < count; i++, x++) { @@ -1000,46 +990,33 @@ static int r128_cce_dispatch_write_pixels(struct drm_device *dev,  		kfree(x);  		return -ENOMEM;  	} -	if (DRM_COPY_FROM_USER(x, depth->x, xbuf_size)) { +	if (copy_from_user(x, depth->x, xbuf_size)) {  		kfree(x);  		kfree(y);  		return -EFAULT;  	} -	if (DRM_COPY_FROM_USER(y, depth->y, xbuf_size)) { +	if (copy_from_user(y, depth->y, xbuf_size)) {  		kfree(x);  		kfree(y);  		return -EFAULT;  	}  	buffer_size = depth->n * sizeof(u32); -	buffer = kmalloc(buffer_size, GFP_KERNEL); -	if (buffer == NULL) { -		kfree(x); -		kfree(y); -		return -ENOMEM; -	} -	if (DRM_COPY_FROM_USER(buffer, depth->buffer, buffer_size)) { +	buffer = memdup_user(depth->buffer, buffer_size); +	if (IS_ERR(buffer)) {  		kfree(x);  		kfree(y); -		kfree(buffer); -		return -EFAULT; +		return PTR_ERR(buffer);  	}  	if (depth->mask) {  		mask_size = depth->n * sizeof(u8); -		mask = kmalloc(mask_size, GFP_KERNEL); -		if (mask == NULL) { -			kfree(x); -			kfree(y); -			kfree(buffer); -			return -ENOMEM; -		} -		if (DRM_COPY_FROM_USER(mask, depth->mask, mask_size)) { +		mask = memdup_user(depth->mask, mask_size); +		if (IS_ERR(mask)) {  			kfree(x);  			kfree(y);  			kfree(buffer); -			kfree(mask); -			return -EFAULT; +			return PTR_ERR(mask);  		}  		for (i = 0; i < count; i++) { @@ -1108,9 +1085,9 @@ static int r128_cce_dispatch_read_span(struct drm_device *dev,  	if (count > 4096 || count <= 0)  		return -EMSGSIZE; -	if (DRM_COPY_FROM_USER(&x, depth->x, sizeof(x))) +	if (copy_from_user(&x, depth->x, sizeof(x)))  		return -EFAULT; -	if (DRM_COPY_FROM_USER(&y, depth->y, sizeof(y))) +	if (copy_from_user(&y, depth->y, sizeof(y)))  		return -EFAULT;  	BEGIN_RING(7); @@ -1163,12 +1140,12 @@ static int r128_cce_dispatch_read_pixels(struct drm_device *dev,  		kfree(x);  		return -ENOMEM;  	} -	if (DRM_COPY_FROM_USER(x, depth->x, xbuf_size)) { +	if (copy_from_user(x, depth->x, xbuf_size)) {  		kfree(x);  		kfree(y);  		return -EFAULT;  	} -	if (DRM_COPY_FROM_USER(y, depth->y, ybuf_size)) { +	if (copy_from_user(y, depth->y, ybuf_size)) {  		kfree(x);  		kfree(y);  		return -EFAULT; @@ -1525,7 +1502,7 @@ static int r128_cce_stipple(struct drm_device *dev, void *data, struct drm_file  	DEV_INIT_TEST_WITH_RETURN(dev_priv); -	if (DRM_COPY_FROM_USER(&mask, stipple->mask, 32 * sizeof(u32))) +	if (copy_from_user(&mask, stipple->mask, 32 * sizeof(u32)))  		return -EFAULT;  	RING_SPACE_TEST_WITH_RETURN(dev_priv); @@ -1617,13 +1594,13 @@ static int r128_getparam(struct drm_device *dev, void *data, struct drm_file *fi  	switch (param->param) {  	case R128_PARAM_IRQ_NR: -		value = drm_dev_to_irq(dev); +		value = dev->pdev->irq;  		break;  	default:  		return -EINVAL;  	} -	if (DRM_COPY_TO_USER(param->value, &value, sizeof(int))) { +	if (copy_to_user(param->value, &value, sizeof(int))) {  		DRM_ERROR("copy_to_user\n");  		return -EFAULT;  	} @@ -1644,7 +1621,7 @@ void r128_driver_lastclose(struct drm_device *dev)  	r128_do_cleanup_cce(dev);  } -struct drm_ioctl_desc r128_ioctls[] = { +const struct drm_ioctl_desc r128_ioctls[] = {  	DRM_IOCTL_DEF_DRV(R128_INIT, r128_cce_init, DRM_AUTH|DRM_MASTER|DRM_ROOT_ONLY),  	DRM_IOCTL_DEF_DRV(R128_CCE_START, r128_cce_start, DRM_AUTH|DRM_MASTER|DRM_ROOT_ONLY),  	DRM_IOCTL_DEF_DRV(R128_CCE_STOP, r128_cce_stop, DRM_AUTH|DRM_MASTER|DRM_ROOT_ONLY), @@ -1664,4 +1641,4 @@ struct drm_ioctl_desc r128_ioctls[] = {  	DRM_IOCTL_DEF_DRV(R128_GETPARAM, r128_getparam, DRM_AUTH),  }; -int r128_max_ioctl = DRM_ARRAY_SIZE(r128_ioctls); +int r128_max_ioctl = ARRAY_SIZE(r128_ioctls);  | 
