diff options
author | bors[bot] <26634292+bors[bot]@users.noreply.github.com> | 2020-04-19 19:44:19 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-04-19 19:44:19 +0000 |
commit | fdf828bc5f47ae0b47ac3a99252e6a9616aba320 (patch) | |
tree | 32ea0c2c46dabf47461422696529ba3d28eaedfe /src/sys/socket/mod.rs | |
parent | 154ff5875c50eab8bb4d7310ca9859c9c17c4031 (diff) | |
parent | 0a99945e5c8be0d37661a73bccf7fc715bc59610 (diff) | |
download | nix-fdf828bc5f47ae0b47ac3a99252e6a9616aba320.zip |
Merge #1206
1206: Fix unaligned casting of cmsg data to af_alg_iv r=asomers a=glebpom
Casting a pointer to `cmsg_data` to `af_alg_iv` is incorrect since it's not properly aligned. As of the [`cmsg` man page](http://man7.org/linux/man-pages/man3/cmsg.3.html) "Applications should not cast it to a pointer type matching the payload, but should instead use memcpy(3) to copy data to or from a suitably declared object."
Co-authored-by: Gleb Pomykalov <gleb@lancastr.com>
Diffstat (limited to 'src/sys/socket/mod.rs')
-rw-r--r-- | src/sys/socket/mod.rs | 17 |
1 files changed, 14 insertions, 3 deletions
diff --git a/src/sys/socket/mod.rs b/src/sys/socket/mod.rs index aa280747..6b2d1ad0 100644 --- a/src/sys/socket/mod.rs +++ b/src/sys/socket/mod.rs @@ -657,15 +657,26 @@ impl<'a> ControlMessage<'a> { } #[cfg(any(target_os = "android", target_os = "linux"))] ControlMessage::AlgSetIv(iv) => { + let af_alg_iv = libc::af_alg_iv { + ivlen: iv.len() as u32, + iv: [0u8; 0], + }; + + let size = mem::size_of::<libc::af_alg_iv>(); + unsafe { - let alg_iv = cmsg_data as *mut libc::af_alg_iv; - (*alg_iv).ivlen = iv.len() as u32; + ptr::copy_nonoverlapping( + &af_alg_iv as *const _ as *const u8, + cmsg_data, + size, + ); ptr::copy_nonoverlapping( iv.as_ptr(), - (*alg_iv).iv.as_mut_ptr(), + cmsg_data.add(size), iv.len() ); }; + return }, #[cfg(any(target_os = "android", target_os = "linux"))] |