Description
In the Linux kernel, the following vulnerability has been resolved: tracing: Fix reading strings from synthetic events The follow commands caused a crash: # cd /sys/kernel/tracing # echo 's:open char file[]' > dynamic_events # echo 'hist:keys=common_pid:file=filename:onchange($file).trace(open,$file)' > events/syscalls/sys_enter_openat/trigger' # echo 1 > events/synthetic/open/enable BOOM! The problem is that the synthetic event field "char file[]" will read the value given to it as a string without any memory checks to make sure the address is valid. The above example will pass in the user space address and the sythetic event code will happily call strlen() on it and then strscpy() where either one will cause an oops when accessing user space addresses. Use the helper functions from trace_kprobe and trace_eprobe that can read strings safely (and actually succeed when the address is from user space and the memory is mapped in). Now the above can show: packagekitd-1721 [000] ...2. 104.597170: open: file=/usr/lib/rpm/fileattrs/cmake.attr in:imjournal-978 [006] ...2. 104.599642: open: file=/var/lib/rsyslog/imjournal.state.tmp packagekitd-1721 [000] ...2. 104.626308: open: file=/usr/lib/rpm/fileattrs/debuginfo.attr
Product status
bd82631d7ccdc894af2738e47abcba2cb6e7dea9 (git) before d9c79fbcbdb6cb10c07c85040eaf615180b26c48
bd82631d7ccdc894af2738e47abcba2cb6e7dea9 (git) before 149198d0b884e4606ed1d29b330c70016d878276
bd82631d7ccdc894af2738e47abcba2cb6e7dea9 (git) before f8bae1853196b52ede50950387f5b48cf83b9815
bd82631d7ccdc894af2738e47abcba2cb6e7dea9 (git) before 0934ae9977c27133449b6dd8c6213970e7eece38
5.10
Any version before 5.10
5.15.75 (semver)
5.19.17 (semver)
6.0.3 (semver)
6.1 (original_commit_for_fix)
References
git.kernel.org/...c/d9c79fbcbdb6cb10c07c85040eaf615180b26c48
git.kernel.org/...c/149198d0b884e4606ed1d29b330c70016d878276
git.kernel.org/...c/f8bae1853196b52ede50950387f5b48cf83b9815
git.kernel.org/...c/0934ae9977c27133449b6dd8c6213970e7eece38