CVE-2024-26740

Source
https://nvd.nist.gov/vuln/detail/CVE-2024-26740
Import Source
https://storage.googleapis.com/cve-osv-conversion/osv-output/CVE-2024-26740.json
JSON Data
https://api.osv.dev/v1/vulns/CVE-2024-26740
Downstream
Related
Published
2024-04-03T17:00:25Z
Modified
2025-10-21T19:00:03.736415Z
Summary
net/sched: act_mirred: use the backlog for mirred ingress
Details

In the Linux kernel, the following vulnerability has been resolved:

net/sched: act_mirred: use the backlog for mirred ingress

The test Davide added in commit ca22da2fbd69 ("actmirred: use the backlog for nested calls to mirred ingress") hangs our testing VMs every 10 or so runs, with the familiar tcpv4rcv -> tcpv4_rcv deadlock reported by lockdep.

The problem as previously described by Davide (see Link) is that if we reverse flow of traffic with the redirect (egress -> ingress) we may reach the same socket which generated the packet. And we may still be holding its socket lock. The common solution to such deadlocks is to put the packet in the Rx backlog, rather than run the Rx path inline. Do that for all egress -> ingress reversals, not just once we started to nest mirred calls.

In the past there was a concern that the backlog indirection will lead to loss of error reporting / less accurate stats. But the current workaround does not seem to address the issue.

References

Affected packages

Git / git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git

Affected ranges

Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
53592b3640019f2834701093e38272fdfd367ad8
Fixed
7c787888d164689da8b1b115f3ef562c1e843af4
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
53592b3640019f2834701093e38272fdfd367ad8
Fixed
60ddea1600bc476e0f5e02bce0e29a460ccbf0be
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
53592b3640019f2834701093e38272fdfd367ad8
Fixed
52f671db18823089a02f07efc04efdb2272ddc17

Affected versions

v4.*

v4.10
v4.10-rc1
v4.10-rc2
v4.10-rc3
v4.10-rc4
v4.10-rc5
v4.10-rc6
v4.10-rc7
v4.10-rc8
v4.11
v4.11-rc1
v4.11-rc2
v4.11-rc3
v4.11-rc4
v4.11-rc5
v4.11-rc6
v4.11-rc7
v4.11-rc8
v4.12
v4.12-rc1
v4.12-rc2
v4.12-rc3
v4.12-rc4
v4.12-rc5
v4.12-rc6
v4.12-rc7
v4.13
v4.13-rc1
v4.13-rc2
v4.13-rc3
v4.13-rc4
v4.13-rc5
v4.13-rc6
v4.13-rc7
v4.14
v4.14-rc1
v4.14-rc2
v4.14-rc3
v4.14-rc4
v4.14-rc5
v4.14-rc6
v4.14-rc7
v4.14-rc8
v4.15
v4.15-rc1
v4.15-rc2
v4.15-rc3
v4.15-rc4
v4.15-rc5
v4.15-rc6
v4.15-rc7
v4.15-rc8
v4.15-rc9
v4.16
v4.16-rc1
v4.16-rc2
v4.16-rc3
v4.16-rc4
v4.16-rc5
v4.16-rc6
v4.16-rc7
v4.17
v4.17-rc1
v4.17-rc2
v4.17-rc3
v4.17-rc4
v4.17-rc5
v4.17-rc6
v4.17-rc7
v4.18
v4.18-rc1
v4.18-rc2
v4.18-rc3
v4.18-rc4
v4.18-rc5
v4.18-rc6
v4.18-rc7
v4.18-rc8
v4.19
v4.19-rc1
v4.19-rc2
v4.19-rc3
v4.19-rc4
v4.19-rc5
v4.19-rc6
v4.19-rc7
v4.19-rc8
v4.20
v4.20-rc1
v4.20-rc2
v4.20-rc3
v4.20-rc4
v4.20-rc5
v4.20-rc6
v4.20-rc7
v4.9
v4.9-rc1
v4.9-rc2
v4.9-rc3
v4.9-rc4
v4.9-rc5
v4.9-rc6
v4.9-rc7
v4.9-rc8

v5.*

v5.0
v5.0-rc1
v5.0-rc2
v5.0-rc3
v5.0-rc4
v5.0-rc5
v5.0-rc6
v5.0-rc7
v5.0-rc8
v5.1
v5.1-rc1
v5.1-rc2
v5.1-rc3
v5.1-rc4
v5.1-rc5
v5.1-rc6
v5.1-rc7
v5.10
v5.10-rc1
v5.10-rc2
v5.10-rc3
v5.10-rc4
v5.10-rc5
v5.10-rc6
v5.10-rc7
v5.11
v5.11-rc1
v5.11-rc2
v5.11-rc3
v5.11-rc4
v5.11-rc5
v5.11-rc6
v5.11-rc7
v5.12
v5.12-rc1
v5.12-rc1-dontuse
v5.12-rc2
v5.12-rc3
v5.12-rc4
v5.12-rc5
v5.12-rc6
v5.12-rc7
v5.12-rc8
v5.13
v5.13-rc1
v5.13-rc2
v5.13-rc3
v5.13-rc4
v5.13-rc5
v5.13-rc6
v5.13-rc7
v5.14
v5.14-rc1
v5.14-rc2
v5.14-rc3
v5.14-rc4
v5.14-rc5
v5.14-rc6
v5.14-rc7
v5.15
v5.15-rc1
v5.15-rc2
v5.15-rc3
v5.15-rc4
v5.15-rc5
v5.15-rc6
v5.15-rc7
v5.16
v5.16-rc1
v5.16-rc2
v5.16-rc3
v5.16-rc4
v5.16-rc5
v5.16-rc6
v5.16-rc7
v5.16-rc8
v5.17
v5.17-rc1
v5.17-rc2
v5.17-rc3
v5.17-rc4
v5.17-rc5
v5.17-rc6
v5.17-rc7
v5.17-rc8
v5.18
v5.18-rc1
v5.18-rc2
v5.18-rc3
v5.18-rc4
v5.18-rc5
v5.18-rc6
v5.18-rc7
v5.19
v5.19-rc1
v5.19-rc2
v5.19-rc3
v5.19-rc4
v5.19-rc5
v5.19-rc6
v5.19-rc7
v5.19-rc8
v5.2
v5.2-rc1
v5.2-rc2
v5.2-rc3
v5.2-rc4
v5.2-rc5
v5.2-rc6
v5.2-rc7
v5.3
v5.3-rc1
v5.3-rc2
v5.3-rc3
v5.3-rc4
v5.3-rc5
v5.3-rc6
v5.3-rc7
v5.3-rc8
v5.4
v5.4-rc1
v5.4-rc2
v5.4-rc3
v5.4-rc4
v5.4-rc5
v5.4-rc6
v5.4-rc7
v5.4-rc8
v5.5
v5.5-rc1
v5.5-rc2
v5.5-rc3
v5.5-rc4
v5.5-rc5
v5.5-rc6
v5.5-rc7
v5.6
v5.6-rc1
v5.6-rc2
v5.6-rc3
v5.6-rc4
v5.6-rc5
v5.6-rc6
v5.6-rc7
v5.7
v5.7-rc1
v5.7-rc2
v5.7-rc3
v5.7-rc4
v5.7-rc5
v5.7-rc6
v5.7-rc7
v5.8
v5.8-rc1
v5.8-rc2
v5.8-rc3
v5.8-rc4
v5.8-rc5
v5.8-rc6
v5.8-rc7
v5.9
v5.9-rc1
v5.9-rc2
v5.9-rc3
v5.9-rc4
v5.9-rc5
v5.9-rc6
v5.9-rc7
v5.9-rc8

v6.*

v6.0
v6.0-rc1
v6.0-rc2
v6.0-rc3
v6.0-rc4
v6.0-rc5
v6.0-rc6
v6.0-rc7
v6.1
v6.1-rc1
v6.1-rc2
v6.1-rc3
v6.1-rc4
v6.1-rc5
v6.1-rc6
v6.1-rc7
v6.1-rc8
v6.2
v6.2-rc1
v6.2-rc2
v6.2-rc3
v6.2-rc4
v6.2-rc5
v6.2-rc6
v6.2-rc7
v6.2-rc8
v6.3
v6.3-rc1
v6.3-rc2
v6.3-rc3
v6.3-rc4
v6.3-rc5
v6.3-rc6
v6.3-rc7
v6.4
v6.4-rc1
v6.4-rc2
v6.4-rc3
v6.4-rc4
v6.4-rc5
v6.4-rc6
v6.4-rc7
v6.5
v6.5-rc1
v6.5-rc2
v6.5-rc3
v6.5-rc4
v6.5-rc5
v6.5-rc6
v6.5-rc7
v6.6
v6.6-rc1
v6.6-rc2
v6.6-rc3
v6.6-rc4
v6.6-rc5
v6.6-rc6
v6.6-rc7
v6.6.1
v6.6.10
v6.6.11
v6.6.12
v6.6.13
v6.6.14
v6.6.15
v6.6.16
v6.6.17
v6.6.18
v6.6.2
v6.6.3
v6.6.4
v6.6.5
v6.6.6
v6.6.7
v6.6.8
v6.6.9
v6.7
v6.7-rc1
v6.7-rc2
v6.7-rc3
v6.7-rc4
v6.7-rc5
v6.7-rc6
v6.7-rc7
v6.7-rc8
v6.7.1
v6.7.2
v6.7.3
v6.7.4
v6.7.5
v6.7.6
v6.8-rc1
v6.8-rc2
v6.8-rc3
v6.8-rc4

Database specific

vanir_signatures

[
    {
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@7c787888d164689da8b1b115f3ef562c1e843af4",
        "target": {
            "file": "net/sched/act_mirred.c"
        },
        "deprecated": false,
        "signature_version": "v1",
        "id": "CVE-2024-26740-1ec826d9",
        "signature_type": "Line",
        "digest": {
            "threshold": 0.9,
            "line_hashes": [
                "91583067559447866975353165013533380018",
                "295409590011743660183353232969723720280",
                "109333041649815478435867602236742844684",
                "77426945422323017955917422721258788361",
                "331094589291738535441376965525376042190",
                "290439277700699066773341764960683462570",
                "79518574372596983527110107023008105641",
                "301310496256959556812285690631785513831",
                "147424844244442850025037909871633817482",
                "128155790847644139699690246980050358605",
                "310575916506611568762683895678893058500",
                "30301821335805089528307809258568098958",
                "24410434887695683047226345577791963204",
                "320119644249030467528946335762989413026",
                "275218558696344159530705270418592421090",
                "209821781473550275343829734785018858016",
                "290065459862683520600863165987520792245",
                "109267311302692311286298457007676561326",
                "166873560015895743084416358904028814998"
            ]
        }
    },
    {
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@60ddea1600bc476e0f5e02bce0e29a460ccbf0be",
        "target": {
            "function": "tcf_mirred_forward",
            "file": "net/sched/act_mirred.c"
        },
        "deprecated": false,
        "signature_version": "v1",
        "id": "CVE-2024-26740-2cf2cf08",
        "signature_type": "Function",
        "digest": {
            "length": 225.0,
            "function_hash": "264741306489643089179417311218751079720"
        }
    },
    {
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@60ddea1600bc476e0f5e02bce0e29a460ccbf0be",
        "target": {
            "function": "tcf_mirred_to_dev",
            "file": "net/sched/act_mirred.c"
        },
        "deprecated": false,
        "signature_version": "v1",
        "id": "CVE-2024-26740-5d751c50",
        "signature_type": "Function",
        "digest": {
            "length": 1274.0,
            "function_hash": "216903111173282239349562072055126174576"
        }
    },
    {
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@60ddea1600bc476e0f5e02bce0e29a460ccbf0be",
        "target": {
            "file": "net/sched/act_mirred.c"
        },
        "deprecated": false,
        "signature_version": "v1",
        "id": "CVE-2024-26740-7e35fb05",
        "signature_type": "Line",
        "digest": {
            "threshold": 0.9,
            "line_hashes": [
                "91583067559447866975353165013533380018",
                "295409590011743660183353232969723720280",
                "109333041649815478435867602236742844684",
                "77426945422323017955917422721258788361",
                "331094589291738535441376965525376042190",
                "290439277700699066773341764960683462570",
                "79518574372596983527110107023008105641",
                "301310496256959556812285690631785513831",
                "147424844244442850025037909871633817482",
                "128155790847644139699690246980050358605",
                "310575916506611568762683895678893058500",
                "30301821335805089528307809258568098958",
                "24410434887695683047226345577791963204",
                "320119644249030467528946335762989413026",
                "275218558696344159530705270418592421090",
                "209821781473550275343829734785018858016",
                "290065459862683520600863165987520792245",
                "109267311302692311286298457007676561326",
                "166873560015895743084416358904028814998"
            ]
        }
    },
    {
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@7c787888d164689da8b1b115f3ef562c1e843af4",
        "target": {
            "function": "tcf_mirred_forward",
            "file": "net/sched/act_mirred.c"
        },
        "deprecated": false,
        "signature_version": "v1",
        "id": "CVE-2024-26740-82dbc950",
        "signature_type": "Function",
        "digest": {
            "length": 225.0,
            "function_hash": "264741306489643089179417311218751079720"
        }
    },
    {
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@52f671db18823089a02f07efc04efdb2272ddc17",
        "target": {
            "function": "tcf_mirred_forward",
            "file": "net/sched/act_mirred.c"
        },
        "deprecated": false,
        "signature_version": "v1",
        "id": "CVE-2024-26740-989ed358",
        "signature_type": "Function",
        "digest": {
            "length": 225.0,
            "function_hash": "264741306489643089179417311218751079720"
        }
    },
    {
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@52f671db18823089a02f07efc04efdb2272ddc17",
        "target": {
            "file": "net/sched/act_mirred.c"
        },
        "deprecated": false,
        "signature_version": "v1",
        "id": "CVE-2024-26740-99076dbe",
        "signature_type": "Line",
        "digest": {
            "threshold": 0.9,
            "line_hashes": [
                "91583067559447866975353165013533380018",
                "295409590011743660183353232969723720280",
                "109333041649815478435867602236742844684",
                "77426945422323017955917422721258788361",
                "331094589291738535441376965525376042190",
                "290439277700699066773341764960683462570",
                "79518574372596983527110107023008105641",
                "301310496256959556812285690631785513831",
                "147424844244442850025037909871633817482",
                "128155790847644139699690246980050358605",
                "310575916506611568762683895678893058500",
                "30301821335805089528307809258568098958",
                "24410434887695683047226345577791963204",
                "320119644249030467528946335762989413026",
                "275218558696344159530705270418592421090",
                "209821781473550275343829734785018858016",
                "290065459862683520600863165987520792245",
                "109267311302692311286298457007676561326",
                "166873560015895743084416358904028814998"
            ]
        }
    },
    {
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@52f671db18823089a02f07efc04efdb2272ddc17",
        "target": {
            "function": "is_mirred_nested",
            "file": "net/sched/act_mirred.c"
        },
        "deprecated": false,
        "signature_version": "v1",
        "id": "CVE-2024-26740-9c7b9985",
        "signature_type": "Function",
        "digest": {
            "length": 92.0,
            "function_hash": "216860129782194369606512033409108053277"
        }
    },
    {
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@7c787888d164689da8b1b115f3ef562c1e843af4",
        "target": {
            "function": "tcf_mirred_to_dev",
            "file": "net/sched/act_mirred.c"
        },
        "deprecated": false,
        "signature_version": "v1",
        "id": "CVE-2024-26740-9f685f0d",
        "signature_type": "Function",
        "digest": {
            "length": 1274.0,
            "function_hash": "216903111173282239349562072055126174576"
        }
    },
    {
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@60ddea1600bc476e0f5e02bce0e29a460ccbf0be",
        "target": {
            "function": "is_mirred_nested",
            "file": "net/sched/act_mirred.c"
        },
        "deprecated": false,
        "signature_version": "v1",
        "id": "CVE-2024-26740-b30b6612",
        "signature_type": "Function",
        "digest": {
            "length": 92.0,
            "function_hash": "216860129782194369606512033409108053277"
        }
    },
    {
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@7c787888d164689da8b1b115f3ef562c1e843af4",
        "target": {
            "function": "is_mirred_nested",
            "file": "net/sched/act_mirred.c"
        },
        "deprecated": false,
        "signature_version": "v1",
        "id": "CVE-2024-26740-e192ba16",
        "signature_type": "Function",
        "digest": {
            "length": 92.0,
            "function_hash": "216860129782194369606512033409108053277"
        }
    },
    {
        "source": "https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git@52f671db18823089a02f07efc04efdb2272ddc17",
        "target": {
            "function": "tcf_mirred_to_dev",
            "file": "net/sched/act_mirred.c"
        },
        "deprecated": false,
        "signature_version": "v1",
        "id": "CVE-2024-26740-f9ee4154",
        "signature_type": "Function",
        "digest": {
            "length": 1274.0,
            "function_hash": "216903111173282239349562072055126174576"
        }
    }
]

Linux / Kernel

Package

Name
Kernel

Affected ranges

Type
ECOSYSTEM
Events
Introduced
4.10.0
Fixed
6.6.19
Type
ECOSYSTEM
Events
Introduced
6.7.0
Fixed
6.7.7