diff options
author | Jakob Kaivo <jkk@ung.org> | 2024-06-11 13:44:21 -0400 |
---|---|---|
committer | Jakob Kaivo <jkk@ung.org> | 2024-06-11 13:44:21 -0400 |
commit | 4f29706128f3d3a66f0503d07c4960d4021aaf27 (patch) | |
tree | 7f76ae1b7819b99756feb1daf93cfe31d5c41c3b /src/string/strcat.c | |
parent | 523944d96e11bde68bf9bcf8e42b7ebc99c5ed3d (diff) |
support watching for dangerous parameter accessnon-posix
Diffstat (limited to 'src/string/strcat.c')
-rw-r--r-- | src/string/strcat.c | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/src/string/strcat.c b/src/string/strcat.c index afbdf84c..60e7695d 100644 --- a/src/string/strcat.c +++ b/src/string/strcat.c @@ -8,7 +8,13 @@ char * strcat(char * restrict s1, const char * restrict s2) SIGNAL_SAFE(0); ASSERT_NONNULL(s1); ASSERT_NONNULL(s2); - ASSERT_NOOVERLAP(s1, strlen(s1) + strlen(s2), s2, strlen(s2)); + DANGEROUS_READ(s2, -1); + size_t s2len = strlen(s2); + DANGER_OVER(); + DANGEROUS_READ(s1, -1); + size_t s1len = strlen(s1); + ASSERT_NOOVERLAP(s1, s1len + s2len, s2, s2len); + DANGEROUS_WRITE(s1, s1len + s2len); /* RETURN_ALWAYS(ARGUMENT(s1)); @@ -18,6 +24,9 @@ char * strcat(char * restrict s1, const char * restrict s2) } strcpy(s1 + i, s2); + + DANGER_OVER(); + return s1; } |