option KDTRACE_HOOKS non-optional after r357912?
Mateusz Guzik
mjguzik at gmail.com
Sat Feb 15 13:47:15 UTC 2020
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>
More information about the freebsd-current
mailing list