summaryrefslogtreecommitdiff
path: root/libmpx
diff options
context:
space:
mode:
authorIlya Enkovich <ilya.enkovich@intel.com>2016-06-10 09:31:37 +0000
committerIlya Enkovich <ienkovich@gcc.gnu.org>2016-06-10 09:31:37 +0000
commitaccc6eb28ade43632963d8e2f032d67ead816ece (patch)
treee60ed20e95b1ddc374c43c5f17637a5a8c67023c /libmpx
parent20cdeb52dd3aa5fbd2654b1b2ea35e4a02194473 (diff)
downloadgcc-accc6eb28ade43632963d8e2f032d67ead816ece.tar.gz
backport: mpx_wrappers.c (move_bounds): Fix overflow bug.
libmpx/ 2016-06-10 Ilya Enkovich <ilya.enkovich@intel.com> Backport from mainline r237292. 2016-06-10 Ilya Enkovich <ilya.enkovich@intel.com> * mpxwrap/mpx_wrappers.c (move_bounds): Fix overflow bug. From-SVN: r237293
Diffstat (limited to 'libmpx')
-rw-r--r--libmpx/ChangeLog7
-rw-r--r--libmpx/mpxwrap/mpx_wrappers.c12
2 files changed, 18 insertions, 1 deletions
diff --git a/libmpx/ChangeLog b/libmpx/ChangeLog
index 47146d1cf7c..98bb5577de3 100644
--- a/libmpx/ChangeLog
+++ b/libmpx/ChangeLog
@@ -1,3 +1,10 @@
+2016-06-10 Ilya Enkovich <ilya.enkovich@intel.com>
+
+ Backport from mainline r237292.
+ 2016-06-10 Ilya Enkovich <ilya.enkovich@intel.com>
+
+ * mpxwrap/mpx_wrappers.c (move_bounds): Fix overflow bug.
+
2016-04-27 Release Manager
* GCC 6.1.0 released.
diff --git a/libmpx/mpxwrap/mpx_wrappers.c b/libmpx/mpxwrap/mpx_wrappers.c
index d4c83ef484c..171a780311d 100644
--- a/libmpx/mpxwrap/mpx_wrappers.c
+++ b/libmpx/mpxwrap/mpx_wrappers.c
@@ -27,6 +27,7 @@
#include "string.h"
#include <sys/mman.h>
#include <stdint.h>
+#include <assert.h>
#include "mpxrt/mpxrt.h"
void *
@@ -418,7 +419,16 @@ move_bounds (void *dst, const void *src, size_t n)
else
elems_to_copy -= src_bt_index_end + 1;
}
- src_bd_index_end--;
+ /* Go to previous table but beware of overflow.
+ We should have copied all required element
+ in case src_bd_index_end is 0. */
+ if (src_bd_index_end)
+ src_bd_index_end--;
+ else
+ {
+ assert (!elems_to_copy);
+ return;
+ }
/* For each bounds table we check if there are valid pointers inside.
If there are some, we copy table in pre-counted portions. */
for (; src_bd_index_end > src_bd_index; src_bd_index_end--)