On 2/15/20, Stefan Eßer <st.esser_at_yahoo.de> wrote: > Hi Mateusz, > > your optimization of systrace checks has made KDTRACE_HOOKS mandatory, > since there are unprotected assignments to systrace_enabled (which is > defined as constant 0 in kernels without KDTRACE_HOOKS due to your > change): > > /sys/cddl/dev/systrace/systrace.c:322:20: error: expression is not > assignable > systrace_enabled = true; > ~~~~~~~~~~~~~~~~ ^ > /sys/cddl/dev/systrace/systrace.c:334:20: error: expression is not > assignable > systrace_enabled = false; > ~~~~~~~~~~~~~~~~ ^ > 2 errors generated. > *** [systrace.o] Error code 1 > > The easy work-around is of course to add KDTRACE_HOOKS to the stripped > down kernel configuration. But I think there should be stab functions > in systrace.c to cover the case that this option is not active. > > Or is the overhead and other impact of KDTRACE_HOOKS considered to be > so insignificant that it should be included in every kernel? > Well tinderbox built for me. Note that the module strongly depends on KDTRACE_HOOKS to work in the first place -- even prior to my patch support in the syscall path was gated by this define. In other words, the module should not be being built if the option is not enabled. Thus if anything the change adds an unintended improvement of catching the lack of dependency checking here. I may take a closer look later but preferably someone familiar with the build system would take care of it. It comes with some overhead of course since there is no hot patching, but it is unlikely you will be able to measure it because of other factors. -- Mateusz Guzik <mjguzik gmail.com>Received on Sat Feb 15 2020 - 12:47:14 UTC
This archive was generated by hypermail 2.4.0 : Wed May 19 2021 - 11:41:23 UTC