提交 d13c46c6 编写于 作者: R Russell King

DRM: armada: fix use of kfifo_put()

The kfifo_put() API changed in 498d319b (kfifo API type safety)
which now results in the wrong pointer being added to the kfifo ring,
which then causes an oops.  Fix this.

Cc: <stable@vger.kernel.org> # 3.13
Signed-off-by: NRussell King <rmk+kernel@arm.linux.org.uk>
上级 bed86f15
...@@ -68,15 +68,7 @@ void __armada_drm_queue_unref_work(struct drm_device *dev, ...@@ -68,15 +68,7 @@ void __armada_drm_queue_unref_work(struct drm_device *dev,
{ {
struct armada_private *priv = dev->dev_private; struct armada_private *priv = dev->dev_private;
/* WARN_ON(!kfifo_put(&priv->fb_unref, fb));
* Yes, we really must jump through these hoops just to store a
* _pointer_ to something into the kfifo. This is utterly insane
* and idiotic, because it kfifo requires the _data_ pointed to by
* the pointer const, not the pointer itself. Not only that, but
* you have to pass a pointer _to_ the pointer you want stored.
*/
const struct drm_framebuffer *silly_api_alert = fb;
WARN_ON(!kfifo_put(&priv->fb_unref, &silly_api_alert));
schedule_work(&priv->fb_unref_work); schedule_work(&priv->fb_unref_work);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册