]> git.ipfire.org Git - thirdparty/haproxy.git/commitdiff
BUG/MEDIUM: conn: fix UAF on connection after reversal on edge
authorAmaury Denoyelle <adenoyelle@haproxy.com>
Thu, 4 Sep 2025 14:35:49 +0000 (16:35 +0200)
committerAmaury Denoyelle <adenoyelle@haproxy.com>
Thu, 4 Sep 2025 16:13:35 +0000 (18:13 +0200)
When a connection is reversed, some elements must be resetted prior to
reusing it. Most notably, connection must be removed from lists specific
on frontend/backend sides.

When reverse was performed for frontend to backend side, connection was
not removed via its <stopping_list> attach point. On previous releases,
this did not cause any issue. However, crashes start to occur recently,
probably due to the recent reorganization of connection list attach
points from the following patch.

  commit a96f1286a75246fef6db3e615fabdef1de927d83
  BUG/MINOR: connection: rearrange union list members

To fix this, simply ensure that <stopping_list> detach is performed via
conn_reverse().

This patch must be backported up to 3.0 release.

src/connection.c

index e3e5040ba0ccc39fb7425f945c374c8ae6d8ff6d..15fac3126a18addcda3d4ee6d1cf1801b81abaf1 100644 (file)
@@ -2961,6 +2961,8 @@ int conn_reverse(struct connection *conn)
                struct server *srv = objt_server(conn->reverse.target);
                BUG_ON(!srv);
 
+               LIST_DEL_INIT(&conn->stopping_list);
+
                if (conn_backend_init(conn))
                        return 1;