summaryrefslogtreecommitdiff
path: root/upb/pb
diff options
context:
space:
mode:
authorEsun Kim <veblush@google.com>2019-07-31 14:20:46 -0700
committerEsun Kim <veblush@google.com>2019-07-31 14:20:46 -0700
commitbc8b1a8f90706c7178fc0a128a7a791b85bbe88f (patch)
treec9732dec7f92679619dbb1589318b3f369f1f646 /upb/pb
parent7e7cb5f831a97655a2d28ed49b485e14a9dd8188 (diff)
Fixed UBSAN issues
Diffstat (limited to 'upb/pb')
-rw-r--r--upb/pb/compile_decoder.c2
-rw-r--r--upb/pb/varint.int.h8
2 files changed, 7 insertions, 3 deletions
diff --git a/upb/pb/compile_decoder.c b/upb/pb/compile_decoder.c
index 1b40302..63d7fe2 100644
--- a/upb/pb/compile_decoder.c
+++ b/upb/pb/compile_decoder.c
@@ -149,7 +149,7 @@ static int32_t getofs(uint32_t instruction) {
static void setofs(uint32_t *instruction, int32_t ofs) {
if (op_has_longofs(*instruction)) {
- *instruction = getop(*instruction) | ofs << 8;
+ *instruction = getop(*instruction) | (uint32_t)ofs << 8;
} else {
*instruction = (*instruction & ~0xff00) | ((ofs & 0xff) << 8);
}
diff --git a/upb/pb/varint.int.h b/upb/pb/varint.int.h
index ddda694..ff1ca66 100644
--- a/upb/pb/varint.int.h
+++ b/upb/pb/varint.int.h
@@ -46,8 +46,12 @@ UPB_INLINE int32_t upb_zzdec_32(uint32_t n) {
UPB_INLINE int64_t upb_zzdec_64(uint64_t n) {
return (n >> 1) ^ -(int64_t)(n & 1);
}
-UPB_INLINE uint32_t upb_zzenc_32(int32_t n) { return (n << 1) ^ (n >> 31); }
-UPB_INLINE uint64_t upb_zzenc_64(int64_t n) { return (n << 1) ^ (n >> 63); }
+UPB_INLINE uint32_t upb_zzenc_32(int32_t n) {
+ return ((uint32_t)n << 1) ^ (n >> 31);
+}
+UPB_INLINE uint64_t upb_zzenc_64(int64_t n) {
+ return ((uint64_t)n << 1) ^ (n >> 63);
+}
/* Decoding *******************************************************************/
generated by cgit on debian on lair
contact matthew@masot.net with questions or feedback