commit acfa9f6ce8295b2493b4e21b73463b93ef3c4333
parent 9231e0905829f1c33abe07bed9be35298c9bdcf5
Author: jvoisin <julien.voisin@dustri.org>
Date:   Tue, 22 Aug 2023 19:16:49 +0200
Add hardening for pwrite
Diffstat:
4 files changed, 41 insertions(+), 0 deletions(-)
diff --git a/include/unistd.h b/include/unistd.h
@@ -180,6 +180,17 @@ _FORTIFY_FN(write) ssize_t write(int __f, const void * _FORTIFY_POS0 __s,
 	return __orig_write(__f, __s, __n);
 }
 
+__diagnose_as_builtin(__builtin_pwrite, 1, 2, 3, 4)
+_FORTIFY_FN(pwrite) ssize_t pwrite(int __f, const void * _FORTIFY_POS0 __s,
+                                 size_t __n, off_t __o)
+{
+	size_t __b = __bos(__s, 0);
+
+	if (__n > __b)
+		__builtin_trap();
+	return __orig_pwrite(__f, __s, __n, __o);
+}
+
 #ifdef __cplusplus
 }
 #endif
diff --git a/tests/Makefile b/tests/Makefile
@@ -63,6 +63,8 @@ TARGETS= \
 	test_ppoll_static            \
 	test_pread_dynamic           \
 	test_pread_static            \
+	test_pwrite_dynamic          \
+	test_pwrite_static           \
 	test_read_dynamic            \
 	test_read_static             \
 	test_readlink_dynamic        \
diff --git a/tests/test_pwrite_dynamic.c b/tests/test_pwrite_dynamic.c
@@ -0,0 +1,14 @@
+#include "common.h"
+
+#include <unistd.h>
+
+int main(int argc, char** argv) {
+  char buffer[8] = {0};
+
+  CHK_FAIL_START
+  pwrite(0, buffer, argc, 0);
+  CHK_FAIL_END
+
+  puts(buffer);
+  return ret;
+}
diff --git a/tests/test_pwrite_static.c b/tests/test_pwrite_static.c
@@ -0,0 +1,14 @@
+#include "common.h"
+
+#include <unistd.h>
+
+int main(int argc, char** argv) {
+  char buffer[12] = {0};
+
+  CHK_FAIL_START
+  pwrite(0, buffer, 14, 0);
+  CHK_FAIL_END
+
+  puts(buffer);
+  return ret;
+}