aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/src/queueing.h
diff options
context:
space:
mode:
authorSamuel Neves <sneves@dei.uc.pt>2018-05-11 21:15:55 +0100
committerJason A. Donenfeld <Jason@zx2c4.com>2018-05-13 16:58:53 +0200
commit37f114a73ba37219b00a66f0a51219a696599745 (patch)
tree7005764f601898de7ea84b5147475b52472d0784 /src/queueing.h
parentsocket: use skb_put_data (diff)
downloadwireguard-monolithic-historical-37f114a73ba37219b00a66f0a51219a696599745.tar.xz
wireguard-monolithic-historical-37f114a73ba37219b00a66f0a51219a696599745.zip
chacha20poly1305: make gcc 8.1 happy
GCC 8.1 does not know about the invariant `0 <= ctx->num < POLY1305_BLOCK_SIZE`. This results in a warning that `memcpy(ctx->data + num, inp, len);` may overflow the `data` field, which is correct for arbitrary values of `num`. To make the invariant explicit we ensure that `num` is in the required range. An alternative would be to change `ctx->num` to a 4-bit bitfield at the point of declaration. This changes the code from `test ebp, ebp; jz end` to `and ebp, 15; jz end`, which have identical performance characteristics. Signed-off-by: Samuel Neves <sneves@dei.uc.pt>
Diffstat (limited to 'src/queueing.h')
0 files changed, 0 insertions, 0 deletions