aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEd Maste <emaste@FreeBSD.org>2023-09-05 16:35:31 +0000
committerEd Maste <emaste@FreeBSD.org>2023-09-25 13:45:06 +0000
commit2871b8a185b2c5b8de2d9f27301a7e523672b242 (patch)
tree9ad4a2e8005a639732f2b039a94c264f2dd3da4f
parented82385135cca73ab0416600269ace3e5bb4cd6c (diff)
downloadsrc-2871b8a185b2c5b8de2d9f27301a7e523672b242.tar.gz
src-2871b8a185b2c5b8de2d9f27301a7e523672b242.zip
bspatch: use C23 overflow checking math now that it is available
Reviewed by: des Sponsored by: The FreeBSD Foundation Differential Revision: https://reviews.freebsd.org/D41771 (cherry picked from commit ee12faa062c04a49bf6fe4e6867bad8606e2413f)
-rw-r--r--usr.bin/bsdiff/bspatch/bspatch.c10
1 files changed, 2 insertions, 8 deletions
diff --git a/usr.bin/bsdiff/bspatch/bspatch.c b/usr.bin/bsdiff/bspatch/bspatch.c
index a596ab1837dd..d7fabddabbfe 100644
--- a/usr.bin/bsdiff/bspatch/bspatch.c
+++ b/usr.bin/bsdiff/bspatch/bspatch.c
@@ -36,6 +36,7 @@
#include <fcntl.h>
#include <libgen.h>
#include <limits.h>
+#include <stdckdint.h>
#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
@@ -64,15 +65,8 @@ add_off_t(off_t a, off_t b)
{
off_t result;
-#if __GNUC__ >= 5 || \
- (defined(__has_builtin) && __has_builtin(__builtin_add_overflow))
- if (__builtin_add_overflow(a, b, &result))
+ if (ckd_add(&result, a, b))
errx(1, "Corrupt patch");
-#else
- if ((b > 0 && a > OFF_MAX - b) || (b < 0 && a < OFF_MIN - b))
- errx(1, "Corrupt patch");
- result = a + b;
-#endif
return result;
}