drm/tinydrm: Fix drm_driver.fops.owner
authorNoralf Trønnes <noralf@tronnes.org>
Sun, 26 Mar 2017 14:25:29 +0000 (16:25 +0200)
committerDaniel Vetter <daniel.vetter@ffwll.ch>
Mon, 27 Mar 2017 06:41:35 +0000 (08:41 +0200)
drm_driver.fops can't be shared since the owner then becomes tinydrm.ko.
Move the fops declaration to the driver.

v2: Use DEFINE_DRM_GEM_CMA_FOPS

Reported-by: Daniel Vetter <daniel.vetter@intel.com>
Signed-off-by: Noralf Trønnes <noralf@tronnes.org>
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Link: http://patchwork.freedesktop.org/patch/msgid/20170326142529.16938-1-noralf@tronnes.org
drivers/gpu/drm/tinydrm/core/tinydrm-core.c
drivers/gpu/drm/tinydrm/mi0283qt.c
include/drm/tinydrm/tinydrm.h

index 6a257dd08ee03b7326930b6aa2b7c99d579fe1ef..fd25c7e534eea7def98a059a37ff1761493f39ca 100644 (file)
@@ -122,21 +122,6 @@ void tinydrm_gem_cma_free_object(struct drm_gem_object *gem_obj)
 }
 EXPORT_SYMBOL_GPL(tinydrm_gem_cma_free_object);
 
-const struct file_operations tinydrm_fops = {
-       .owner          = THIS_MODULE,
-       .open           = drm_open,
-       .release        = drm_release,
-       .unlocked_ioctl = drm_ioctl,
-#ifdef CONFIG_COMPAT
-       .compat_ioctl   = drm_compat_ioctl,
-#endif
-       .poll           = drm_poll,
-       .read           = drm_read,
-       .llseek         = no_llseek,
-       .mmap           = drm_gem_cma_mmap,
-};
-EXPORT_SYMBOL(tinydrm_fops);
-
 static struct drm_framebuffer *
 tinydrm_fb_create(struct drm_device *drm, struct drm_file *file_priv,
                  const struct drm_mode_fb_cmd2 *mode_cmd)
index b29fe86158f7a672cabac47f2a0c81fc148b5720..482ff1c3db61b58e50848eec4eeee3519ac1f26c 100644 (file)
@@ -132,9 +132,12 @@ static const struct drm_display_mode mi0283qt_mode = {
        TINYDRM_MODE(320, 240, 58, 43),
 };
 
+DEFINE_DRM_GEM_CMA_FOPS(mi0283qt_fops);
+
 static struct drm_driver mi0283qt_driver = {
        .driver_features        = DRIVER_GEM | DRIVER_MODESET | DRIVER_PRIME |
                                  DRIVER_ATOMIC,
+       .fops                   = &mi0283qt_fops,
        TINYDRM_GEM_DRIVER_OPS,
        .lastclose              = tinydrm_lastclose,
        .debugfs_init           = mipi_dbi_debugfs_init,
index cf9ca207b8b1fa041436d3fcf98073dbd2c07389..00b800df4d1b2b6c6cbe69a3646c8fc577b524db 100644 (file)
@@ -58,8 +58,7 @@ pipe_to_tinydrm(struct drm_simple_display_pipe *pipe)
        .gem_prime_mmap         = drm_gem_cma_prime_mmap, \
        .dumb_create            = drm_gem_cma_dumb_create, \
        .dumb_map_offset        = drm_gem_cma_dumb_map_offset, \
-       .dumb_destroy           = drm_gem_dumb_destroy, \
-       .fops                   = &tinydrm_fops
+       .dumb_destroy           = drm_gem_dumb_destroy
 
 /**
  * TINYDRM_MODE - tinydrm display mode
@@ -84,7 +83,6 @@ pipe_to_tinydrm(struct drm_simple_display_pipe *pipe)
        .type = DRM_MODE_TYPE_DRIVER, \
        .clock = 1 /* pass validation */
 
-extern const struct file_operations tinydrm_fops;
 void tinydrm_lastclose(struct drm_device *drm);
 void tinydrm_gem_cma_free_object(struct drm_gem_object *gem_obj);
 struct drm_gem_object *