All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] module: Optimize search_module_extables()
@ 2017-02-08 14:48 Peter Zijlstra
  2017-02-08 15:44 ` Mark Rutland
  2017-02-11  4:41 ` Jessica Yu
  0 siblings, 2 replies; 3+ messages in thread
From: Peter Zijlstra @ 2017-02-08 14:48 UTC (permalink / raw)
  To: jeyu, rusty; +Cc: Mark Rutland, linux-kernel


While looking through the __ex_table stuff I found that we do a linear
lookup of the module. Also fix up a comment.

Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
---
 kernel/module.c | 27 ++++++++++++++-------------
 1 file changed, 14 insertions(+), 13 deletions(-)

diff --git a/kernel/module.c b/kernel/module.c
index 3d8f126208e3..7bcdc35dbf95 100644
--- a/kernel/module.c
+++ b/kernel/module.c
@@ -4165,22 +4165,23 @@ const struct exception_table_entry *search_module_extables(unsigned long addr)
 	struct module *mod;
 
 	preempt_disable();
-	list_for_each_entry_rcu(mod, &modules, list) {
-		if (mod->state == MODULE_STATE_UNFORMED)
-			continue;
-		if (mod->num_exentries == 0)
-			continue;
+	mod = __module_address(addr);
+	if (!mod)
+		goto out;
 
-		e = search_extable(mod->extable,
-				   mod->extable + mod->num_exentries - 1,
-				   addr);
-		if (e)
-			break;
-	}
+	if (!mod->num_exentries)
+		goto out;
+
+	e = search_extable(mod->extable,
+			   mod->extable + mod->num_exentries - 1,
+			   addr);
+out:
 	preempt_enable();
 
-	/* Now, if we found one, we are running inside it now, hence
-	   we cannot unload the module, hence no refcnt needed. */
+	/*
+	 * Now, if we found one, we are running inside it now, hence
+	 * we cannot unload the module, hence no refcnt needed.
+	 */
 	return e;
 }
 

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

* Re: [PATCH] module: Optimize search_module_extables()
  2017-02-08 14:48 [PATCH] module: Optimize search_module_extables() Peter Zijlstra
@ 2017-02-08 15:44 ` Mark Rutland
  2017-02-11  4:41 ` Jessica Yu
  1 sibling, 0 replies; 3+ messages in thread
From: Mark Rutland @ 2017-02-08 15:44 UTC (permalink / raw)
  To: Peter Zijlstra; +Cc: jeyu, rusty, linux-kernel

On Wed, Feb 08, 2017 at 03:48:01PM +0100, Peter Zijlstra wrote:
> 
> While looking through the __ex_table stuff I found that we do a linear
> lookup of the module. Also fix up a comment.
> 
> Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>

I'm not all that familiar with the module code, but from a quick scan of
__module_address() this looks sane to me. FWIW:

Acked-by: Mark Rutland <mark.rutland@arm.com>

Mark.

> ---
>  kernel/module.c | 27 ++++++++++++++-------------
>  1 file changed, 14 insertions(+), 13 deletions(-)
> 
> diff --git a/kernel/module.c b/kernel/module.c
> index 3d8f126208e3..7bcdc35dbf95 100644
> --- a/kernel/module.c
> +++ b/kernel/module.c
> @@ -4165,22 +4165,23 @@ const struct exception_table_entry *search_module_extables(unsigned long addr)
>  	struct module *mod;
>  
>  	preempt_disable();
> -	list_for_each_entry_rcu(mod, &modules, list) {
> -		if (mod->state == MODULE_STATE_UNFORMED)
> -			continue;
> -		if (mod->num_exentries == 0)
> -			continue;
> +	mod = __module_address(addr);
> +	if (!mod)
> +		goto out;
>  
> -		e = search_extable(mod->extable,
> -				   mod->extable + mod->num_exentries - 1,
> -				   addr);
> -		if (e)
> -			break;
> -	}
> +	if (!mod->num_exentries)
> +		goto out;
> +
> +	e = search_extable(mod->extable,
> +			   mod->extable + mod->num_exentries - 1,
> +			   addr);
> +out:
>  	preempt_enable();
>  
> -	/* Now, if we found one, we are running inside it now, hence
> -	   we cannot unload the module, hence no refcnt needed. */
> +	/*
> +	 * Now, if we found one, we are running inside it now, hence
> +	 * we cannot unload the module, hence no refcnt needed.
> +	 */
>  	return e;
>  }
>  

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

* Re: module: Optimize search_module_extables()
  2017-02-08 14:48 [PATCH] module: Optimize search_module_extables() Peter Zijlstra
  2017-02-08 15:44 ` Mark Rutland
@ 2017-02-11  4:41 ` Jessica Yu
  1 sibling, 0 replies; 3+ messages in thread
From: Jessica Yu @ 2017-02-11  4:41 UTC (permalink / raw)
  To: Peter Zijlstra; +Cc: rusty, Mark Rutland, linux-kernel

+++ Peter Zijlstra [08/02/17 15:48 +0100]:
>
>While looking through the __ex_table stuff I found that we do a linear
>lookup of the module. Also fix up a comment.
>
>Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>

Applied, thanks.

Hm. A quick scan through module.c still shows a couple of places that use
similar linear lookups, and may benefit from the same __module_address
optimization. But I'll save that for a separate patch..

Jessica

>---
> kernel/module.c | 27 ++++++++++++++-------------
> 1 file changed, 14 insertions(+), 13 deletions(-)
>
>diff --git a/kernel/module.c b/kernel/module.c
>index 3d8f126208e3..7bcdc35dbf95 100644
>--- a/kernel/module.c
>+++ b/kernel/module.c
>@@ -4165,22 +4165,23 @@ const struct exception_table_entry *search_module_extables(unsigned long addr)
> 	struct module *mod;
>
> 	preempt_disable();
>-	list_for_each_entry_rcu(mod, &modules, list) {
>-		if (mod->state == MODULE_STATE_UNFORMED)
>-			continue;
>-		if (mod->num_exentries == 0)
>-			continue;
>+	mod = __module_address(addr);
>+	if (!mod)
>+		goto out;
>
>-		e = search_extable(mod->extable,
>-				   mod->extable + mod->num_exentries - 1,
>-				   addr);
>-		if (e)
>-			break;
>-	}
>+	if (!mod->num_exentries)
>+		goto out;
>+
>+	e = search_extable(mod->extable,
>+			   mod->extable + mod->num_exentries - 1,
>+			   addr);
>+out:
> 	preempt_enable();
>
>-	/* Now, if we found one, we are running inside it now, hence
>-	   we cannot unload the module, hence no refcnt needed. */
>+	/*
>+	 * Now, if we found one, we are running inside it now, hence
>+	 * we cannot unload the module, hence no refcnt needed.
>+	 */
> 	return e;
> }
>

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

end of thread, other threads:[~2017-02-11  4:41 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2017-02-08 14:48 [PATCH] module: Optimize search_module_extables() Peter Zijlstra
2017-02-08 15:44 ` Mark Rutland
2017-02-11  4:41 ` 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.