瀏覽代碼

Fix Busybox CVE-2017-16544 issue

RISCi_ATOM 6 年之前
父節點
當前提交
51331fc003
共有 1 個文件被更改,包括 22 次插入0 次删除
  1. 22 0
      package/utils/busybox/patches/900-fix_cve2017-16544.patch

+ 22 - 0
package/utils/busybox/patches/900-fix_cve2017-16544.patch

@@ -0,0 +1,22 @@
+--- a/libbb/lineedit.c
++++ b/libbb/lineedit.c
+@@ -632,6 +632,19 @@ static void free_tab_completion_data(voi
+ 
+ static void add_match(char *matched)
+ {
++	unsigned char *p = (unsigned char*)matched;
++	while (*p) {
++		/* ESC attack fix: drop any string with control chars */
++		if (*p < ' '
++		 || (!ENABLE_UNICODE_SUPPORT && *p >= 0x7f)
++		 || (ENABLE_UNICODE_SUPPORT && *p == 0x7f)
++		) {
++			free(matched);
++			return;
++		}
++		p++;
++	}
++
+ 	matches = xrealloc_vector(matches, 4, num_matches);
+ 	matches[num_matches] = matched;
+ 	num_matches++;