diff options
| author | Renato Westphal <renato@opensourcerouting.org> | 2020-09-04 22:33:48 -0300 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-09-04 22:33:48 -0300 |
| commit | dcdaabcede9302790c48e18132f202ef3886f635 (patch) | |
| tree | 6ca5b8ff41952921b31c1f10fe0f629f021d8e95 /lib/stream.c | |
| parent | c7b5a0ae3a2195b04a00e6359c14e5033bddf253 (diff) | |
| parent | 763a5d3c2dc7e9061006d56a9a983c2a8be64765 (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.c | 24 |
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); |
