提交 22d0def9 编写于 作者: A Alexander Nyberg 提交者: Linus Torvalds

[PATCH] ns558 list handling fix

Need to use list_for_entry_safe(), as we're removing items during the
traversal.  list_for_each_entry() uses the first ptr also as an iterator, if
you kfree() it slab takes it, might poison it and then you try to use it to
iterate to the next object in list.

Cc: Vojtech Pavlik <vojtech@suse.cz>
Cc: Dmitry Torokhov <dmitry.torokhov@gmail.com>
Signed-off-by: NAndrew Morton <akpm@osdl.org>
Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
上级 c0438174
...@@ -275,9 +275,9 @@ static int __init ns558_init(void) ...@@ -275,9 +275,9 @@ static int __init ns558_init(void)
static void __exit ns558_exit(void) static void __exit ns558_exit(void)
{ {
struct ns558 *ns558; struct ns558 *ns558, *safe;
list_for_each_entry(ns558, &ns558_list, node) { list_for_each_entry_safe(ns558, safe, &ns558_list, node) {
gameport_unregister_port(ns558->gameport); gameport_unregister_port(ns558->gameport);
release_region(ns558->io & ~(ns558->size - 1), ns558->size); release_region(ns558->io & ~(ns558->size - 1), ns558->size);
kfree(ns558); kfree(ns558);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册