diff options
| author | Meenali Gupta <meenali.gupta@windriver.com> | 2023-11-16 11:17:44 +0000 |
|---|---|---|
| committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2023-11-20 15:30:52 +0000 |
| commit | 820c282b7de5daed91693e95e2ee9e2988929ad8 (patch) | |
| tree | 4e1af94553921dd73ba734c6b876158842254f48 /meta/recipes-connectivity | |
| parent | 4dd9e54a3b230bd542284a451905cb5203effa84 (diff) | |
| download | poky-820c282b7de5daed91693e95e2ee9e2988929ad8.tar.gz | |
avahi: fix CVE-2023-38470
A vulnerability was found in Avahi. A reachable assertion exists
in the avahi_escape_label() function.
(From OE-Core rev: 93b4489c84f5f21e3fbcd66a39d50b5d64001a58)
Signed-off-by: Meenali Gupta <meenali.gupta@windriver.com>
Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/recipes-connectivity')
| -rw-r--r-- | meta/recipes-connectivity/avahi/avahi_0.8.bb | 1 | ||||
| -rw-r--r-- | meta/recipes-connectivity/avahi/files/CVE-2023-38470.patch | 59 |
2 files changed, 60 insertions, 0 deletions
diff --git a/meta/recipes-connectivity/avahi/avahi_0.8.bb b/meta/recipes-connectivity/avahi/avahi_0.8.bb index 90b33ba81b..a0b31a4697 100644 --- a/meta/recipes-connectivity/avahi/avahi_0.8.bb +++ b/meta/recipes-connectivity/avahi/avahi_0.8.bb | |||
| @@ -27,6 +27,7 @@ SRC_URI = "${GITHUB_BASE_URI}/download/v${PV}/avahi-${PV}.tar.gz \ | |||
| 27 | file://local-ping.patch \ | 27 | file://local-ping.patch \ |
| 28 | file://invalid-service.patch \ | 28 | file://invalid-service.patch \ |
| 29 | file://CVE-2023-38469.patch \ | 29 | file://CVE-2023-38469.patch \ |
| 30 | file://CVE-2023-38470.patch \ | ||
| 30 | " | 31 | " |
| 31 | 32 | ||
| 32 | GITHUB_BASE_URI = "https://github.com/lathiat/avahi/releases/" | 33 | GITHUB_BASE_URI = "https://github.com/lathiat/avahi/releases/" |
diff --git a/meta/recipes-connectivity/avahi/files/CVE-2023-38470.patch b/meta/recipes-connectivity/avahi/files/CVE-2023-38470.patch new file mode 100644 index 0000000000..91f9e677ac --- /dev/null +++ b/meta/recipes-connectivity/avahi/files/CVE-2023-38470.patch | |||
| @@ -0,0 +1,59 @@ | |||
| 1 | From af7bfad67ca53a7c4042a4a2d85456b847e9f249 Mon Sep 17 00:00:00 2001 | ||
| 2 | From: =?UTF-8?q?Petr=20Men=C5=A1=C3=ADk?= <pemensik@redhat.com> | ||
| 3 | Date: Tue, 11 Apr 2023 15:29:59 +0200 | ||
| 4 | Subject: [PATCH] avahi: Ensure each label is at least one byte long | ||
| 5 | |||
| 6 | The only allowed exception is single dot, where it should return empty | ||
| 7 | string. | ||
| 8 | |||
| 9 | Fixes #454. | ||
| 10 | |||
| 11 | Upstream-Status: Backport [https://github.com/lathiat/avahi/commit/94cb6489114636940ac683515417990b55b5d66c] | ||
| 12 | CVE: CVE-2023-38470 | ||
| 13 | |||
| 14 | Signed-off-by: Meenali Gupta <meenali.gupta@windriver.com> | ||
| 15 | --- | ||
| 16 | avahi-common/domain-test.c | 14 ++++++++++++++ | ||
| 17 | avahi-common/domain.c | 2 +- | ||
| 18 | 2 files changed, 15 insertions(+), 1 deletion(-) | ||
| 19 | |||
| 20 | diff --git a/avahi-common/domain-test.c b/avahi-common/domain-test.c | ||
| 21 | index cf763ec..3acc1c1 100644 | ||
| 22 | --- a/avahi-common/domain-test.c | ||
| 23 | +++ b/avahi-common/domain-test.c | ||
| 24 | @@ -45,6 +45,20 @@ int main(AVAHI_GCC_UNUSED int argc, AVAHI_GCC_UNUSED char *argv[]) { | ||
| 25 | printf("%s\n", s = avahi_normalize_name_strdup("fo\\\\o\\..f oo.")); | ||
| 26 | avahi_free(s); | ||
| 27 | |||
| 28 | + printf("%s\n", s = avahi_normalize_name_strdup(".")); | ||
| 29 | + avahi_free(s); | ||
| 30 | + | ||
| 31 | + s = avahi_normalize_name_strdup(",.=.}.=.?-.}.=.?.?.}.}.?.?.?.z.?.?.}.}." | ||
| 32 | + "}.?.?.?.r.=.=.}.=.?.}}.}.?.?.?.zM.=.=.?.?.}.}.?.?.}.}.}" | ||
| 33 | + ".?.?.?.r.=.=.}.=.?.}}.}.?.?.?.zM.=.=.?.?.}.}.?.?.?.zM.?`" | ||
| 34 | + "?.}.}.}.?.?.?.r.=.?.}.=.?.?.}.?.?.?.}.=.?.?.}??.}.}.?.?." | ||
| 35 | + "?.z.?.?.}.}.}.?.?.?.r.=.=.}.=.?.}}.}.?.?.?.zM.?`?.}.}.}." | ||
| 36 | + "??.?.zM.?`?.}.}.}.?.?.?.r.=.?.}.=.?.?.}.?.?.?.}.=.?.?.}?" | ||
| 37 | + "?.}.}.?.?.?.z.?.?.}.}.}.?.?.?.r.=.=.}.=.?.}}.}.?.?.?.zM." | ||
| 38 | + "?`?.}.}.}.?.?.?.r.=.=.?.?`.?.?}.}.}.?.?.?.r.=.?.}.=.?.?." | ||
| 39 | + "}.?.?.?.}.=.?.?.}"); | ||
| 40 | + assert(s == NULL); | ||
| 41 | + | ||
| 42 | printf("%i\n", avahi_domain_equal("\\065aa bbb\\.\\046cc.cc\\\\.dee.fff.", "Aaa BBB\\.\\.cc.cc\\\\.dee.fff")); | ||
| 43 | printf("%i\n", avahi_domain_equal("A", "a")); | ||
| 44 | |||
| 45 | diff --git a/avahi-common/domain.c b/avahi-common/domain.c | ||
| 46 | index 3b1ab68..e66d241 100644 | ||
| 47 | --- a/avahi-common/domain.c | ||
| 48 | +++ b/avahi-common/domain.c | ||
| 49 | @@ -201,7 +201,7 @@ char *avahi_normalize_name(const char *s, char *ret_s, size_t size) { | ||
| 50 | } | ||
| 51 | |||
| 52 | if (!empty) { | ||
| 53 | - if (size < 1) | ||
| 54 | + if (size < 2) | ||
| 55 | return NULL; | ||
| 56 | |||
| 57 | *(r++) = '.'; | ||
| 58 | -- | ||
| 59 | 2.40.0 | ||
