libpayload: malloc: Change memcpy() to memmove() in realloc

Our realloc() works (somewhat suboptimally) by free()ing the existing
allocation and then reallocating it wherever it fits. If there was free
space before the old location, this means the new allocation may be
before the old one, and if the free space block is smaller than the old
allocation it may overlap. Thus, we should be moving memmove() instead
of memcpy() to move the block over.

This is not a problem in practice since all our existing memcpy()s are
simple iterate and copy front to back implementations which are safe for
overlaps when the destination is in front of the source. but it's still
the more correct thing to do (in case we ever change our memcpy()s to do
something more advanced or whatever).

Signed-off-by: Julius Werner <jwerner@chromium.org>
Change-Id: I35f77a94b7a72c01364ee7eecb5c3ff5ecde57f6
Reviewed-on: https://review.coreboot.org/c/coreboot/+/40028
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Aaron Durbin <adurbin@chromium.org>
This commit is contained in:
Julius Werner 2020-04-01 17:52:23 -07:00
parent adbb224f5a
commit d61350c403
1 changed files with 3 additions and 2 deletions

View File

@ -310,8 +310,9 @@ void *realloc(void *ptr, size_t size)
if (ret == NULL || ret == ptr) if (ret == NULL || ret == ptr)
return ret; return ret;
/* Copy the memory to the new location. */ /* Move the memory to the new location. Might be before the old location
memcpy(ret, ptr, osize > size ? size : osize); and overlap since the free() above includes a _consolidate(). */
memmove(ret, ptr, osize > size ? size : osize);
return ret; return ret;
} }