Commit 882a04c0 authored by Dave Airlie's avatar Dave Airlie

drm: mark ffb as broken because it actually is

The ffb driver has been broken since 2.6.8 at least, so mark it
as so. This also contains some fixes so it at least compiles.
Signed-off-by: default avatarDave Airlie <airlied@linux.ie>
parent 317a4d81
...@@ -556,7 +556,7 @@ config DRM ...@@ -556,7 +556,7 @@ config DRM
config DRM_FFB config DRM_FFB
tristate "Creator/Creator3D" tristate "Creator/Creator3D"
depends on DRM depends on DRM && BROKEN
help help
Choose this option if you have one of Sun's Creator3D-based graphics Choose this option if you have one of Sun's Creator3D-based graphics
and frame buffer cards. Product page at and frame buffer cards. Product page at
......
...@@ -210,30 +210,17 @@ unsigned long ffb_get_unmapped_area(struct file *filp, ...@@ -210,30 +210,17 @@ unsigned long ffb_get_unmapped_area(struct file *filp,
return addr; return addr;
} }
/* This functions must be here since it references drm_numdevs)
* which drm_drv.h declares.
*/
static int ffb_presetup(drm_device_t *dev) static int ffb_presetup(drm_device_t *dev)
{ {
ffb_dev_priv_t *ffb_priv; ffb_dev_priv_t *ffb_priv;
drm_device_t *temp_dev;
int ret = 0; int ret = 0;
int i; int i = 0;
/* Check for the case where no device was found. */ /* Check for the case where no device was found. */
if (ffb_position == NULL) if (ffb_position == NULL)
return -ENODEV; return -ENODEV;
/* Find our instance number by finding our device in dev structure */ /* code used to use numdevs no numdevs anymore */
for (i = 0; i < drm_numdevs; i++) {
temp_dev = &(drm_device[i]);
if(temp_dev == dev)
break;
}
if (i == drm_numdevs)
return -ENODEV;
ffb_priv = kmalloc(sizeof(ffb_dev_priv_t), GFP_KERNEL); ffb_priv = kmalloc(sizeof(ffb_dev_priv_t), GFP_KERNEL);
if (!ffb_priv) if (!ffb_priv)
return -ENOMEM; return -ENOMEM;
...@@ -305,16 +292,74 @@ static unsigned long ffb_driver_get_reg_ofs(drm_device_t *dev) ...@@ -305,16 +292,74 @@ static unsigned long ffb_driver_get_reg_ofs(drm_device_t *dev)
return 0; return 0;
} }
void ffb_driver_register_fns(drm_device_t *dev) static int postinit( struct drm_device *dev, unsigned long flags )
{
DRM_INFO( "Initialized %s %d.%d.%d %s on minor %d\n",
DRIVER_NAME,
DRIVER_MAJOR,
DRIVER_MINOR,
DRIVER_PATCHLEVEL,
DRIVER_DATE,
dev->minor
);
return 0;
}
static int version( drm_version_t *version )
{ {
ffb_set_context_ioctls(); int len;
DRM(fops).get_unmapped_area = ffb_get_unmapped_area;
dev->driver.release = ffb_driver_release; version->version_major = DRIVER_MAJOR;
dev->driver.presetup = ffb_presetup; version->version_minor = DRIVER_MINOR;
dev->driver.pretakedown = ffb_driver_pretakedown; version->version_patchlevel = DRIVER_PATCHLEVEL;
dev->driver.postcleanup = ffb_driver_postcleanup; DRM_COPY( version->name, DRIVER_NAME );
dev->driver.kernel_context_switch = ffb_context_switch; DRM_COPY( version->date, DRIVER_DATE );
dev->driver.kernel_context_switch_unlock = ffb_driver_kernel_context_switch_unlock; DRM_COPY( version->desc, DRIVER_DESC );
dev->driver.get_map_ofs = ffb_driver_get_map_ofs; return 0;
dev->driver.get_reg_ofs = ffb_driver_get_reg_ofs; }
static drm_ioctl_desc_t ioctls[] = {
};
static struct drm_driver driver = {
.driver_features = 0,
.dev_priv_size = sizeof(u32),
.release = ffb_driver_release,
.presetup = ffb_presetup,
.pretakedown = ffb_driver_pretakedown,
.postcleanup = ffb_driver_postcleanup,
.kernel_context_switch = ffb_driver_context_switch,
.kernel_context_switch_unlock = ffb_driver_kernel_context_switch_unlock,
.get_map_ofs = ffb_driver_get_map_ofs,
.get_reg_ofs = ffb_driver_get_reg_ofs,
.postinit = postinit,
.version = version,
.ioctls = ioctls,
.num_ioctls = DRM_ARRAY_SIZE(ioctls),
.fops = {
.owner = THIS_MODULE,
.open = drm_open,
.release = drm_release,
.ioctl = drm_ioctl,
.mmap = drm_mmap,
.poll = drm_poll,
.fasync = drm_fasync,
},
};
static int __init ffb_init(void)
{
return -ENODEV;
} }
static void __exit ffb_exit(void)
{
}
module_init(ffb_init);
module_exit(ffb_exit);
MODULE_AUTHOR( DRIVER_AUTHOR );
MODULE_DESCRIPTION( DRIVER_DESC );
MODULE_LICENSE("GPL and additional rights");
...@@ -275,7 +275,6 @@ typedef struct ffb_dev_priv { ...@@ -275,7 +275,6 @@ typedef struct ffb_dev_priv {
struct ffb_hw_context *hw_state[FFB_MAX_CTXS]; struct ffb_hw_context *hw_state[FFB_MAX_CTXS];
} ffb_dev_priv_t; } ffb_dev_priv_t;
extern struct file_operations DRM(fops);
extern unsigned long ffb_get_unmapped_area(struct file *filp, extern unsigned long ffb_get_unmapped_area(struct file *filp,
unsigned long hint, unsigned long hint,
unsigned long len, unsigned long len,
...@@ -284,3 +283,4 @@ extern unsigned long ffb_get_unmapped_area(struct file *filp, ...@@ -284,3 +283,4 @@ extern unsigned long ffb_get_unmapped_area(struct file *filp,
extern void ffb_set_context_ioctls(void); extern void ffb_set_context_ioctls(void);
extern drm_ioctl_desc_t DRM(ioctls)[]; extern drm_ioctl_desc_t DRM(ioctls)[];
extern int ffb_driver_context_switch(drm_device_t *dev, int old, int new);
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment