All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH 0/3] module: minor allocation optimization
@ 2017-12-08  0:15 Luis R. Rodriguez
  2017-12-08  0:15 ` [PATCH 1/3] module: add an early early_mod_check() Luis R. Rodriguez
                   ` (2 more replies)
  0 siblings, 3 replies; 6+ messages in thread
From: Luis R. Rodriguez @ 2017-12-08  0:15 UTC (permalink / raw)
  To: jeyu, rusty
  Cc: keescook, tixxdz, mbenes, atomlin, pmladek, hare, james.l.morris,
	ebiederm, davem, akpm, torvalds, linux-kernel, Luis R. Rodriguez

Long ago I was debugging kernel/module.c and kernel/kmod.c and had
implemented a sanity check to avoid allocating much of the needed struct
module from what user passes on finit_module() too early, ie, before
checking if the module was actually loaded.

I had disregarded this work as I had bundled it up with some aliasing
work I had done, so incorrectly thought this depended on the alias work.
Upon a second look it does not. The module name set on userspace on
info->name is not the alias but the proper module name, as such using
finished_loading() should suffice once to avoid allocating the module
if its already present.

I've tested this with kmod.sh and found no regressions, the few minor
enhancements are documented in patch 3 in detail. I'll let 0-day hammer
on it as we review the patches [0] [1] but no build issues so far.

[0] https://git.kernel.org/pub/scm/linux/kernel/git/mcgrof/linux.git/log/?h=20171207-avoid-bogus-layout_and_allocate
[1] https://git.kernel.org/pub/scm/linux/kernel/git/mcgrof/linux-next.git/log/?h=20171207-avoid-bogus-layout_and_allocate

Luis R. Rodriguez (3):
  module: add an early early_mod_check()
  module: move finished_loading()
  module: avoid allocation if module is already present and ready

 kernel/module.c | 81 ++++++++++++++++++++++++++++++++++-----------------------
 1 file changed, 49 insertions(+), 32 deletions(-)

-- 
2.15.0

^ permalink raw reply	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2017-12-19  1:26 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2017-12-08  0:15 [PATCH 0/3] module: minor allocation optimization Luis R. Rodriguez
2017-12-08  0:15 ` [PATCH 1/3] module: add an early early_mod_check() Luis R. Rodriguez
2017-12-19  1:00   ` Jessica Yu
2017-12-08  0:15 ` [PATCH 2/3] module: move finished_loading() Luis R. Rodriguez
2017-12-08  0:15 ` [PATCH 3/3] module: avoid allocation if module is already present and ready Luis R. Rodriguez
2017-12-19  1:26   ` Jessica Yu

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.