summaryrefslogtreecommitdiff
path: root/lib/stream.c
diff options
context:
space:
mode:
authorRenato Westphal <renato@opensourcerouting.org>2020-09-04 22:33:48 -0300
committerGitHub <noreply@github.com>2020-09-04 22:33:48 -0300
commitdcdaabcede9302790c48e18132f202ef3886f635 (patch)
tree6ca5b8ff41952921b31c1f10fe0f629f021d8e95 /lib/stream.c
parentc7b5a0ae3a2195b04a00e6359c14e5033bddf253 (diff)
parent763a5d3c2dc7e9061006d56a9a983c2a8be64765 (diff)
Merge pull request #7046 from qlyoung/fix-various-integer-issues
Fix various integer signedness / overflow issues
Diffstat (limited to 'lib/stream.c')
-rw-r--r--lib/stream.c24
1 files changed, 24 insertions, 0 deletions
diff --git a/lib/stream.c b/lib/stream.c
index 6e62e11380..dc207c16a4 100644
--- a/lib/stream.c
+++ b/lib/stream.c
@@ -268,6 +268,30 @@ bool stream_forward_getp2(struct stream *s, size_t size)
return true;
}
+void stream_rewind_getp(struct stream *s, size_t size)
+{
+ STREAM_VERIFY_SANE(s);
+
+ if (size > s->getp || !GETP_VALID(s, s->getp - size)) {
+ STREAM_BOUND_WARN(s, "rewind getp");
+ return;
+ }
+
+ s->getp -= size;
+}
+
+bool stream_rewind_getp2(struct stream *s, size_t size)
+{
+ STREAM_VERIFY_SANE(s);
+
+ if (size > s->getp || !GETP_VALID(s, s->getp - size))
+ return false;
+
+ s->getp -= size;
+
+ return true;
+}
+
void stream_forward_endp(struct stream *s, size_t size)
{
STREAM_VERIFY_SANE(s);