summaryrefslogtreecommitdiffstats
path: root/meta/recipes-extended/tar/tar-1.17/avoid_heap_overflow.patch
diff options
context:
space:
mode:
Diffstat (limited to 'meta/recipes-extended/tar/tar-1.17/avoid_heap_overflow.patch')
-rw-r--r--meta/recipes-extended/tar/tar-1.17/avoid_heap_overflow.patch22
1 files changed, 22 insertions, 0 deletions
diff --git a/meta/recipes-extended/tar/tar-1.17/avoid_heap_overflow.patch b/meta/recipes-extended/tar/tar-1.17/avoid_heap_overflow.patch
new file mode 100644
index 0000000000..da2ae3cb0f
--- /dev/null
+++ b/meta/recipes-extended/tar/tar-1.17/avoid_heap_overflow.patch
@@ -0,0 +1,22 @@
1Upstream-Status: Inappropriate [bugfix: http://web.nvd.nist.gov/view/vuln/detail?vulnId=CVE-2010-0624]
2
3This patch avoids heap overflow reported by :
4http://web.nvd.nist.gov/view/vuln/detail?vulnId=CVE-2010-0624
5
6This is a clean patch for the GPLv2 tar recipe.
7
8Nitin A Kamble <nitin.a.kamble@intel.com> 2011/04/25
9
10Index: tar-1.17/lib/rtapelib.c
11===================================================================
12--- tar-1.17.orig/lib/rtapelib.c
13+++ tar-1.17/lib/rtapelib.c
14@@ -570,7 +570,7 @@ rmt_read__ (int handle, char *buffer, si
15
16 sprintf (command_buffer, "R%lu\n", (unsigned long) length);
17 if (do_command (handle, command_buffer) == -1
18- || (status = get_status (handle)) == SAFE_READ_ERROR)
19+ || ((status = get_status (handle)) == SAFE_READ_ERROR) || (status > length))
20 return SAFE_READ_ERROR;
21
22 for (counter = 0; counter < status; counter += rlen, buffer += rlen)