Merge branch 'drm-tda998x-3.12-fixes' of git://ftp.arm.linux.org.uk/~rmk/linux-cubox into drm-fixes
These four patches fix a few issues discovered since the initial merge, which have been reviewed by Rob Clark and Thierry Reding. * 'drm-tda998x-3.12-fixes' of git://ftp.arm.linux.org.uk/~rmk/linux-cubox: DRM: Armada: prime refcounting bug fix DRM: Armada: fix printing of phys_addr_t/dma_addr_t DRM: Armada: destroy framebuffer after helper DRM: Armada: implement lastclose() for fbhelper
This commit is contained in:
Коммит
5c015db7d9
|
@ -103,6 +103,7 @@ void armada_drm_queue_unref_work(struct drm_device *,
|
||||||
extern const struct drm_mode_config_funcs armada_drm_mode_config_funcs;
|
extern const struct drm_mode_config_funcs armada_drm_mode_config_funcs;
|
||||||
|
|
||||||
int armada_fbdev_init(struct drm_device *);
|
int armada_fbdev_init(struct drm_device *);
|
||||||
|
void armada_fbdev_lastclose(struct drm_device *);
|
||||||
void armada_fbdev_fini(struct drm_device *);
|
void armada_fbdev_fini(struct drm_device *);
|
||||||
|
|
||||||
int armada_overlay_plane_create(struct drm_device *, unsigned long);
|
int armada_overlay_plane_create(struct drm_device *, unsigned long);
|
||||||
|
|
|
@ -321,6 +321,11 @@ static struct drm_ioctl_desc armada_ioctls[] = {
|
||||||
DRM_UNLOCKED),
|
DRM_UNLOCKED),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static void armada_drm_lastclose(struct drm_device *dev)
|
||||||
|
{
|
||||||
|
armada_fbdev_lastclose(dev);
|
||||||
|
}
|
||||||
|
|
||||||
static const struct file_operations armada_drm_fops = {
|
static const struct file_operations armada_drm_fops = {
|
||||||
.owner = THIS_MODULE,
|
.owner = THIS_MODULE,
|
||||||
.llseek = no_llseek,
|
.llseek = no_llseek,
|
||||||
|
@ -337,7 +342,7 @@ static struct drm_driver armada_drm_driver = {
|
||||||
.open = NULL,
|
.open = NULL,
|
||||||
.preclose = NULL,
|
.preclose = NULL,
|
||||||
.postclose = NULL,
|
.postclose = NULL,
|
||||||
.lastclose = NULL,
|
.lastclose = armada_drm_lastclose,
|
||||||
.unload = armada_drm_unload,
|
.unload = armada_drm_unload,
|
||||||
.get_vblank_counter = drm_vblank_count,
|
.get_vblank_counter = drm_vblank_count,
|
||||||
.enable_vblank = armada_drm_enable_vblank,
|
.enable_vblank = armada_drm_enable_vblank,
|
||||||
|
|
|
@ -105,9 +105,9 @@ static int armada_fb_create(struct drm_fb_helper *fbh,
|
||||||
drm_fb_helper_fill_fix(info, dfb->fb.pitches[0], dfb->fb.depth);
|
drm_fb_helper_fill_fix(info, dfb->fb.pitches[0], dfb->fb.depth);
|
||||||
drm_fb_helper_fill_var(info, fbh, sizes->fb_width, sizes->fb_height);
|
drm_fb_helper_fill_var(info, fbh, sizes->fb_width, sizes->fb_height);
|
||||||
|
|
||||||
DRM_DEBUG_KMS("allocated %dx%d %dbpp fb: 0x%08x\n",
|
DRM_DEBUG_KMS("allocated %dx%d %dbpp fb: 0x%08llx\n",
|
||||||
dfb->fb.width, dfb->fb.height,
|
dfb->fb.width, dfb->fb.height, dfb->fb.bits_per_pixel,
|
||||||
dfb->fb.bits_per_pixel, obj->phys_addr);
|
(unsigned long long)obj->phys_addr);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
@ -177,6 +177,16 @@ int armada_fbdev_init(struct drm_device *dev)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void armada_fbdev_lastclose(struct drm_device *dev)
|
||||||
|
{
|
||||||
|
struct armada_private *priv = dev->dev_private;
|
||||||
|
|
||||||
|
drm_modeset_lock_all(dev);
|
||||||
|
if (priv->fbdev)
|
||||||
|
drm_fb_helper_restore_fbdev_mode(priv->fbdev);
|
||||||
|
drm_modeset_unlock_all(dev);
|
||||||
|
}
|
||||||
|
|
||||||
void armada_fbdev_fini(struct drm_device *dev)
|
void armada_fbdev_fini(struct drm_device *dev)
|
||||||
{
|
{
|
||||||
struct armada_private *priv = dev->dev_private;
|
struct armada_private *priv = dev->dev_private;
|
||||||
|
@ -192,11 +202,11 @@ void armada_fbdev_fini(struct drm_device *dev)
|
||||||
framebuffer_release(info);
|
framebuffer_release(info);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
drm_fb_helper_fini(fbh);
|
||||||
|
|
||||||
if (fbh->fb)
|
if (fbh->fb)
|
||||||
fbh->fb->funcs->destroy(fbh->fb);
|
fbh->fb->funcs->destroy(fbh->fb);
|
||||||
|
|
||||||
drm_fb_helper_fini(fbh);
|
|
||||||
|
|
||||||
priv->fbdev = NULL;
|
priv->fbdev = NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -172,8 +172,9 @@ armada_gem_linear_back(struct drm_device *dev, struct armada_gem_object *obj)
|
||||||
obj->dev_addr = obj->linear->start;
|
obj->dev_addr = obj->linear->start;
|
||||||
}
|
}
|
||||||
|
|
||||||
DRM_DEBUG_DRIVER("obj %p phys %#x dev %#x\n",
|
DRM_DEBUG_DRIVER("obj %p phys %#llx dev %#llx\n", obj,
|
||||||
obj, obj->phys_addr, obj->dev_addr);
|
(unsigned long long)obj->phys_addr,
|
||||||
|
(unsigned long long)obj->dev_addr);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -557,7 +558,6 @@ armada_gem_prime_import(struct drm_device *dev, struct dma_buf *buf)
|
||||||
* refcount on the gem object itself.
|
* refcount on the gem object itself.
|
||||||
*/
|
*/
|
||||||
drm_gem_object_reference(obj);
|
drm_gem_object_reference(obj);
|
||||||
dma_buf_put(buf);
|
|
||||||
return obj;
|
return obj;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -573,6 +573,7 @@ armada_gem_prime_import(struct drm_device *dev, struct dma_buf *buf)
|
||||||
}
|
}
|
||||||
|
|
||||||
dobj->obj.import_attach = attach;
|
dobj->obj.import_attach = attach;
|
||||||
|
get_dma_buf(buf);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Don't call dma_buf_map_attachment() here - it maps the
|
* Don't call dma_buf_map_attachment() here - it maps the
|
||||||
|
|
Загрузка…
Ссылка в новой задаче