linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] init, allow blacklisting of module_init functions
@ 2016-06-15 15:30 Prarit Bhargava
  2016-06-15 20:25 ` Rasmus Villemoes
  0 siblings, 1 reply; 3+ messages in thread
From: Prarit Bhargava @ 2016-06-15 15:30 UTC (permalink / raw)
  To: linux-kernel
  Cc: Prarit Bhargava, Andrew Morton, Thomas Gleixner, Yang Shi,
	Ingo Molnar, Mel Gorman, Rasmus Villemoes, Kees Cook, Yaowei Bai,
	Andrey Ryabinin

At some point I was 100% sure this worked.  I do remember testing it against
just a loadable module and had positive testing results.  I went back to
the time that it was commited (3.15-ish) and blacklisting a module init
function didn't work there either, so something went wrong somewhere.  In
any case this is a trivial patch to add the functionality...

P.

---8<---

sprint_symbol_no_offset() returns the string "function_name [module_name]"
where [module_name] is not printed for built in kernel functions.  This
means that the blacklisting code will fail when comparing module function
names with the extended string.  This patch adds the functionality to
block a module's module_init() function by finding the space in the string
and truncating the comparison to that length.

Signed-off-by: Prarit Bhargava <prarit@redhat.com>
Cc: Andrew Morton <akpm@linux-foundation.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Yang Shi <yang.shi@linaro.org>
Cc: Prarit Bhargava <prarit@redhat.com>
Cc: Ingo Molnar <mingo@kernel.org>
Cc: Mel Gorman <mgorman@suse.de>
Cc: Rasmus Villemoes <linux@rasmusvillemoes.dk>
Cc: Kees Cook <keescook@chromium.org>
Cc: Yaowei Bai <baiyaowei@cmss.chinamobile.com>
Cc: Andrey Ryabinin <aryabinin@virtuozzo.com>
---
 init/main.c |   13 ++++++++++++-
 1 file changed, 12 insertions(+), 1 deletion(-)

diff --git a/init/main.c b/init/main.c
index 4c17fda5c2ff..730d6a846216 100644
--- a/init/main.c
+++ b/init/main.c
@@ -708,14 +708,25 @@ static bool __init_or_module initcall_blacklisted(initcall_t fn)
 {
 	struct blacklist_entry *entry;
 	char fn_name[KSYM_SYMBOL_LEN];
+	char *space;
+	int length;
 
 	if (list_empty(&blacklisted_initcalls))
 		return false;
 
 	sprint_symbol_no_offset(fn_name, (unsigned long)fn);
+	/*
+	 * fn will be "function_name [module_name]" where [module_name] is not
+	 * displayed for built-in init functions.  Strip off the [module_name].
+	 */
+	space = strchrnul(fn_name, ' ');
+	if (!space)
+		length = strlen(fn_name);
+	else
+		length = space - fn_name;
 
 	list_for_each_entry(entry, &blacklisted_initcalls, next) {
-		if (!strcmp(fn_name, entry->buf)) {
+		if (!strncmp(fn_name, entry->buf, length)) {
 			pr_debug("initcall %s blacklisted\n", fn_name);
 			return true;
 		}
-- 
1.7.9.3

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

* Re: [PATCH] init, allow blacklisting of module_init functions
  2016-06-15 15:30 [PATCH] init, allow blacklisting of module_init functions Prarit Bhargava
@ 2016-06-15 20:25 ` Rasmus Villemoes
  2016-06-16  9:55   ` Prarit Bhargava
  0 siblings, 1 reply; 3+ messages in thread
From: Rasmus Villemoes @ 2016-06-15 20:25 UTC (permalink / raw)
  To: Prarit Bhargava
  Cc: linux-kernel, Andrew Morton, Thomas Gleixner, Yang Shi,
	Ingo Molnar, Mel Gorman, Kees Cook, Yaowei Bai, Andrey Ryabinin

On Wed, Jun 15 2016, Prarit Bhargava <prarit@redhat.com> wrote:

> At some point I was 100% sure this worked.  I do remember testing it against
> just a loadable module and had positive testing results.

I think the current %ps/%pf behaviour was introduced in 4796dd200db9
(way back in 2012). 

> In any case this is a trivial patch to add the functionality...

Which I still think is broken and needlessly complicated. Please read my
first reply again.

Rasmus

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

* Re: [PATCH] init, allow blacklisting of module_init functions
  2016-06-15 20:25 ` Rasmus Villemoes
@ 2016-06-16  9:55   ` Prarit Bhargava
  0 siblings, 0 replies; 3+ messages in thread
From: Prarit Bhargava @ 2016-06-16  9:55 UTC (permalink / raw)
  To: Rasmus Villemoes
  Cc: linux-kernel, Andrew Morton, Thomas Gleixner, Yang Shi,
	Ingo Molnar, Mel Gorman, Kees Cook, Yaowei Bai, Andrey Ryabinin



On 06/15/2016 04:25 PM, Rasmus Villemoes wrote:
> On Wed, Jun 15 2016, Prarit Bhargava <prarit@redhat.com> wrote:
> 
>> At some point I was 100% sure this worked.  I do remember testing it against
>> just a loadable module and had positive testing results.
> 
> I think the current %ps/%pf behaviour was introduced in 4796dd200db9
> (way back in 2012). 

Yeah, I'm scratching my head on that.  I *know* I tested it and it worked.

> 
>> In any case this is a trivial patch to add the functionality...
> 
> Which I still think is broken and needlessly complicated. Please read my
> first reply again.
> 

Oops -- I completely missed the 2nd half of your reply.  Sorry 'bout that.

I'll do a v3 in a bit

P.
> Rasmus
> 

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

end of thread, other threads:[~2016-06-16  9:55 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-06-15 15:30 [PATCH] init, allow blacklisting of module_init functions Prarit Bhargava
2016-06-15 20:25 ` Rasmus Villemoes
2016-06-16  9:55   ` Prarit Bhargava

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).