mpx_wrappers.c (move_bounds): Fix overflow bug.

libmpx/

2016-06-10  Ilya Enkovich  <ilya.enkovich@intel.com>

	* mpxwrap/mpx_wrappers.c (move_bounds): Fix overflow bug.

From-SVN: r237292
This commit is contained in:
Ilya Enkovich 2016-06-10 09:23:53 +00:00 committed by Ilya Enkovich
parent 27d6ba889b
commit 2cfab6c0f7
2 changed files with 15 additions and 1 deletions

View File

@ -1,3 +1,7 @@
2016-06-10 Ilya Enkovich <ilya.enkovich@intel.com>
* mpxwrap/mpx_wrappers.c (move_bounds): Fix overflow bug.
2016-01-20 Matthias Klose <doko@ubuntu.com>
* libtool-version: Remove.

View File

@ -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--)