提交 c68a99cd 编写于 作者: P Paul Fulghum 提交者: Linus Torvalds

synclink_gt fix locking in error path of rx enable

Fix locking in error path of rx_enable() introduced by
synclink_gt-add-rx-dma-buffer-fill-level-control patch.
Signed-off-by: NPaul Fulghum <paulkf@microgate.com>
Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: NAlan Cox <alan@lxorguk.ukuu.org.uk>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
上级 814dae03
...@@ -2686,8 +2686,10 @@ static int rx_enable(struct slgt_info *info, int enable) ...@@ -2686,8 +2686,10 @@ static int rx_enable(struct slgt_info *info, int enable)
*/ */
rbuf_fill_level = ((unsigned int)enable) >> 16; rbuf_fill_level = ((unsigned int)enable) >> 16;
if (rbuf_fill_level) { if (rbuf_fill_level) {
if ((rbuf_fill_level > DMABUFSIZE) || (rbuf_fill_level % 4)) if ((rbuf_fill_level > DMABUFSIZE) || (rbuf_fill_level % 4)) {
spin_unlock_irqrestore(&info->lock, flags);
return -EINVAL; return -EINVAL;
}
info->rbuf_fill_level = rbuf_fill_level; info->rbuf_fill_level = rbuf_fill_level;
rx_stop(info); /* restart receiver to use new fill level */ rx_stop(info); /* restart receiver to use new fill level */
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册