Ensure log buffer bounds

This change adds checks in `TagLenValue.write()` to ensure that the size
of written data doesn't exceed the buffer size.

Verifier in recent kernel versions requires the bound to be a constant
value, so using `buf.len()` does not work.

Signed-off-by: Michal Rostecki <vadorovsky@gmail.com>
pull/350/head
Michal Rostecki 3 years ago committed by Dave Tucker
parent 6aea880890
commit 2e0702854b

@ -90,7 +90,9 @@ where
pub(crate) fn write(&self, mut buf: &mut [u8]) -> Result<usize, ()> { pub(crate) fn write(&self, mut buf: &mut [u8]) -> Result<usize, ()> {
let size = mem::size_of::<T>() + mem::size_of::<usize>() + self.value.len(); let size = mem::size_of::<T>() + mem::size_of::<usize>() + self.value.len();
if buf.len() < size { // The verifier rejects the program if it can't see that `size` doesn't
// exceed the buffer size.
if size > LOG_BUF_CAPACITY {
return Err(()); return Err(());
} }
@ -101,6 +103,11 @@ where
buf = &mut buf[mem::size_of::<usize>()..]; buf = &mut buf[mem::size_of::<usize>()..];
let len = cmp::min(buf.len(), self.value.len()); let len = cmp::min(buf.len(), self.value.len());
// The verifier rejects the program if it can't see that `size` doesn't
// exceed the buffer size.
if len > LOG_BUF_CAPACITY {
return Err(());
}
buf[..len].copy_from_slice(&self.value[..len]); buf[..len].copy_from_slice(&self.value[..len]);
Ok(size) Ok(size)
} }

Loading…
Cancel
Save