|
@@ -0,0 +1,30 @@
|
|
|
|
+From 36c6d268cb190282a2c17106acfd31863121b58e Mon Sep 17 00:00:00 2001
|
|
|
|
+From: Frank Denis <github@pureftpd.org>
|
|
|
|
+Date: Mon, 24 Feb 2020 15:19:43 +0100
|
|
|
|
+Subject: [PATCH] pure_strcmp(): len(s2) can be > len(s1)
|
|
|
|
+
|
|
|
|
+Reported by Antonio Morales from GitHub Security Labs, thanks!
|
|
|
|
+[Retrieved from:
|
|
|
|
+https://github.com/jedisct1/pure-ftpd/commit/36c6d268cb190282a2c17106acfd31863121b]
|
|
|
|
+Signed-off-by: Fabrice Fontaine <fontaine.fabrice@gmail.com>
|
|
|
|
+---
|
|
|
|
+ src/utils.c | 8 +++++++-
|
|
|
|
+ 1 file changed, 7 insertions(+), 1 deletion(-)
|
|
|
|
+
|
|
|
|
+diff --git a/src/utils.c b/src/utils.c
|
|
|
|
+index f41492d..a7f0381 100644
|
|
|
|
+--- a/src/utils.c
|
|
|
|
++++ b/src/utils.c
|
|
|
|
+@@ -45,5 +45,11 @@ int pure_memcmp(const void * const b1_, const void * const b2_, size_t len)
|
|
|
|
+
|
|
|
|
+ int pure_strcmp(const char * const s1, const char * const s2)
|
|
|
|
+ {
|
|
|
|
+- return pure_memcmp(s1, s2, strlen(s1) + 1U);
|
|
|
|
++ const size_t s1_len = strlen(s1);
|
|
|
|
++ const size_t s2_len = strlen(s2);
|
|
|
|
++
|
|
|
|
++ if (s1_len != s2_len) {
|
|
|
|
++ return -1;
|
|
|
|
++ }
|
|
|
|
++ return pure_memcmp(s1, s2, s1_len);
|
|
|
|
+ }
|