Git is an open source, scalable, distributed revision control system. git shell
is a restricted login shell that can be used to implement Gits push/pull functionality via SSH. In versions prior to 2.30.6, 2.31.5, 2.32.4, 2.33.5, 2.34.5, 2.35.5, 2.36.3, and 2.37.4, the function that splits the command arguments into an array improperly uses an int
to represent the number of entries in the array, allowing a malicious actor to intentionally overflow the return value, leading to arbitrary heap writes. Because the resulting array is then passed to execv()
, it is possible to leverage this attack to gain remote code execution on a victim machine. Note that a victim must first allow access to git shell
as a login shell in order to be vulnerable to this attack. This problem is patched in versions 2.30.6, 2.31.5, 2.32.4, 2.33.5, 2.34.5, 2.35.5, 2.36.3, and 2.37.4 and users are advised to upgrade to the latest version. Disabling git shell
access via remote logins is a viable short-term workaround.
A heap overflow condition is a buffer overflow, where the buffer that can be overwritten is allocated in the heap portion of memory, generally meaning that the buffer was allocated using a routine such as malloc().
Name | Vendor | Start Version | End Version |
---|---|---|---|
Git | Git-scm | * | 2.30.6 (excluding) |
Git | Git-scm | 2.31.0 (including) | 2.31.5 (excluding) |
Git | Git-scm | 2.32.0 (including) | 2.32.4 (excluding) |
Git | Git-scm | 2.33.0 (including) | 2.33.5 (excluding) |
Git | Git-scm | 2.34.0 (including) | 2.34.5 (excluding) |
Git | Git-scm | 2.35.0 (including) | 2.35.5 (excluding) |
Git | Git-scm | 2.36.0 (including) | 2.36.3 (excluding) |
Git | Git-scm | 2.37.0 (including) | 2.37.4 (excluding) |
Git | Git-scm | 2.38.0 (including) | 2.38.0 (including) |
Red Hat Enterprise Linux 8 | RedHat | git-0:2.39.1-1.el8 | * |
Red Hat Enterprise Linux 8.6 Extended Update Support | RedHat | git-0:2.31.8-1.el8_6 | * |
Red Hat Enterprise Linux 9 | RedHat | git-0:2.39.1-1.el9 | * |
Git | Ubuntu | bionic | * |
Git | Ubuntu | devel | * |
Git | Ubuntu | esm-infra/xenial | * |
Git | Ubuntu | focal | * |
Git | Ubuntu | jammy | * |
Git | Ubuntu | kinetic | * |
Git | Ubuntu | lunar | * |
Git | Ubuntu | trusty | * |
Git | Ubuntu | xenial | * |