From: Yu Watanabe Date: Fri, 12 Apr 2024 23:46:44 +0000 (+0900) Subject: network/tc: fix stack overflow when dropping tclass or qdisc X-Git-Tag: v256-rc1~182^2~1 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=632d321050f58fe1b5bed7cfe769d212377c0301;p=thirdparty%2Fsystemd.git network/tc: fix stack overflow when dropping tclass or qdisc Fixes a bug introduced by be8e93390003e45acbb318c6e1e48fbc3c772f78 (v255). Fixes #32247. Fixes #32254. --- diff --git a/src/network/tc/qdisc.c b/src/network/tc/qdisc.c index 75bcbbf01d9..55ce16600a7 100644 --- a/src/network/tc/qdisc.c +++ b/src/network/tc/qdisc.c @@ -293,14 +293,20 @@ QDisc* qdisc_drop(QDisc *qdisc) { link = ASSERT_PTR(qdisc->link); + qdisc_mark(qdisc); /* To avoid stack overflow. */ + /* also drop all child classes assigned to the qdisc. */ SET_FOREACH(tclass, link->tclasses) { + if (tclass_is_marked(tclass)) + continue; + if (TC_H_MAJ(tclass->classid) != qdisc->handle) continue; tclass_drop(tclass); } + qdisc_unmark(qdisc); qdisc_enter_removed(qdisc); if (qdisc->state == 0) { diff --git a/src/network/tc/tclass.c b/src/network/tc/tclass.c index ab8f79ac5bf..63229ec6e8d 100644 --- a/src/network/tc/tclass.c +++ b/src/network/tc/tclass.c @@ -260,14 +260,20 @@ TClass* tclass_drop(TClass *tclass) { link = ASSERT_PTR(tclass->link); + tclass_mark(tclass); /* To avoid stack overflow. */ + /* Also drop all child qdiscs assigned to the class. */ SET_FOREACH(qdisc, link->qdiscs) { + if (qdisc_is_marked(qdisc)) + continue; + if (qdisc->parent != tclass->classid) continue; qdisc_drop(qdisc); } + tclass_unmark(tclass); tclass_enter_removed(tclass); if (tclass->state == 0) {