Commit d570d486 authored by Thomas Van Lenten's avatar Thomas Van Lenten

Don't assume c-strings are 4 byte aligned.

The Undefined Behavior sanitizer flags one part of the unittests for this.
For default values for `bytes` we write a length on the front of a c-string
in the static data, apparently the compiler/linker doesn't always make this
4 byte aligned, so it get flagged for undefined/degraded performance. Avoid
this by using memcpy instead.
parent d83837de
...@@ -548,7 +548,8 @@ uint32_t GPBFieldAlternateTag(GPBFieldDescriptor *self) { ...@@ -548,7 +548,8 @@ uint32_t GPBFieldAlternateTag(GPBFieldDescriptor *self) {
// descriptor structure. // descriptor structure.
const uint8_t *bytes = (const uint8_t *)defaultValue_.valueData; const uint8_t *bytes = (const uint8_t *)defaultValue_.valueData;
if (bytes) { if (bytes) {
uint32_t length = *((uint32_t *)bytes); uint32_t length;
memcpy(&length, bytes, sizeof(length));
length = ntohl(length); length = ntohl(length);
bytes += sizeof(length); bytes += sizeof(length);
defaultValue_.valueData = defaultValue_.valueData =
...@@ -963,7 +964,8 @@ uint32_t GPBFieldAlternateTag(GPBFieldDescriptor *self) { ...@@ -963,7 +964,8 @@ uint32_t GPBFieldAlternateTag(GPBFieldDescriptor *self) {
const uint8_t *bytes = const uint8_t *bytes =
(const uint8_t *)description->defaultValue.valueData; (const uint8_t *)description->defaultValue.valueData;
if (bytes) { if (bytes) {
uint32_t length = *((uint32_t *)bytes); uint32_t length;
memcpy(&length, bytes, sizeof(length));
// The length is stored in network byte order. // The length is stored in network byte order.
length = ntohl(length); length = ntohl(length);
bytes += sizeof(length); bytes += sizeof(length);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment