All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH V2] x86/mm/pat: Do a small optimization and fix in reserve_memtype
@ 2015-07-21  8:02 Pan Xinhui
  2015-07-21  8:10 ` Thomas Gleixner
  0 siblings, 1 reply; 4+ messages in thread
From: Pan Xinhui @ 2015-07-21  8:02 UTC (permalink / raw)
  To: linux-kernel
  Cc: tglx, mingo, hpa, x86, bp, toshi.kani, jgross, mcgrof, mnipxh,
	yanmin_zhang

From: Pan Xinhui <xinhuix.pan@intel.com>

It's safe and more reasonable to unlock memtype_lock right after
rbt_memtype_check_insert. It's not cool to call kfree, pr_info, etc with
this lock held. So move spin_unlock a little ahead.

memory_lock protects data stored in rb-tree, if *new* succeed to be
stored into the rb-tree, we might hit panic. Because we access *new* in
dprintk "cattr_name(new->type)". data stored in the rb-tree might be
freed at any possbile time. It's abviously wrong to access such data
without lock. So save new->type to actual_type, and use actual_type in
dprintk.

Signed-off-by: Pan Xinhui <xinhuix.pan@intel.com>
---
change from V1:
	fix an access of *new* without memtype_lock held.
---
 arch/x86/mm/pat.c | 10 ++++------
 1 file changed, 4 insertions(+), 6 deletions(-)

diff --git a/arch/x86/mm/pat.c b/arch/x86/mm/pat.c
index 188e3e0..f3c49fa 100644
--- a/arch/x86/mm/pat.c
+++ b/arch/x86/mm/pat.c
@@ -538,22 +538,20 @@ int reserve_memtype(u64 start, u64 end, enum page_cache_mode req_type,
 	new->type	= actual_type;
 
 	spin_lock(&memtype_lock);
-
 	err = rbt_memtype_check_insert(new, new_type);
+	actual_type = new->type;
+	spin_unlock(&memtype_lock);
+
 	if (err) {
 		pr_info("x86/PAT: reserve_memtype failed [mem %#010Lx-%#010Lx], track %s, req %s\n",
 			start, end - 1,
 			cattr_name(new->type), cattr_name(req_type));
 		kfree(new);
-		spin_unlock(&memtype_lock);
-
 		return err;
 	}
 
-	spin_unlock(&memtype_lock);
-
 	dprintk("reserve_memtype added [mem %#010Lx-%#010Lx], track %s, req %s, ret %s\n",
-		start, end - 1, cattr_name(new->type), cattr_name(req_type),
+		start, end - 1, cattr_name(actual_type), cattr_name(req_type),
 		new_type ? cattr_name(*new_type) : "-");
 
 	return err;
-- 
1.9.1

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

* Re: [PATCH V2] x86/mm/pat: Do a small optimization and fix in reserve_memtype
  2015-07-21  8:02 [PATCH V2] x86/mm/pat: Do a small optimization and fix in reserve_memtype Pan Xinhui
@ 2015-07-21  8:10 ` Thomas Gleixner
  2015-07-21  8:26   ` Pan Xinhui
  0 siblings, 1 reply; 4+ messages in thread
From: Thomas Gleixner @ 2015-07-21  8:10 UTC (permalink / raw)
  To: Pan Xinhui
  Cc: linux-kernel, mingo, hpa, x86, bp, toshi.kani, jgross, mcgrof,
	mnipxh, yanmin_zhang

On Tue, 21 Jul 2015, Pan Xinhui wrote:
> diff --git a/arch/x86/mm/pat.c b/arch/x86/mm/pat.c
> index 188e3e0..f3c49fa 100644
> --- a/arch/x86/mm/pat.c
> +++ b/arch/x86/mm/pat.c
> @@ -538,22 +538,20 @@ int reserve_memtype(u64 start, u64 end, enum page_cache_mode req_type,
>  	new->type	= actual_type;
>  
>  	spin_lock(&memtype_lock);
> -
>  	err = rbt_memtype_check_insert(new, new_type);
> +	actual_type = new->type;

What's the point of this? new->type is set to actual_type 5 lines above.

Thanks,

	tglx

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

* Re: [PATCH V2] x86/mm/pat: Do a small optimization and fix in reserve_memtype
  2015-07-21  8:10 ` Thomas Gleixner
@ 2015-07-21  8:26   ` Pan Xinhui
  2015-07-21 15:23     ` Thomas Gleixner
  0 siblings, 1 reply; 4+ messages in thread
From: Pan Xinhui @ 2015-07-21  8:26 UTC (permalink / raw)
  To: Thomas Gleixner
  Cc: linux-kernel, mingo, hpa, x86, bp, toshi.kani, jgross, mcgrof,
	mnipxh, yanmin_zhang

hi, tglx
	thanks for your reply :)

On 2015年07月21日 16:10, Thomas Gleixner wrote:
> On Tue, 21 Jul 2015, Pan Xinhui wrote:
>> diff --git a/arch/x86/mm/pat.c b/arch/x86/mm/pat.c
>> index 188e3e0..f3c49fa 100644
>> --- a/arch/x86/mm/pat.c
>> +++ b/arch/x86/mm/pat.c
>> @@ -538,22 +538,20 @@ int reserve_memtype(u64 start, u64 end, enum page_cache_mode req_type,
>>  	new->type	= actual_type;
>>  
>>  	spin_lock(&memtype_lock);
>> -
>>  	err = rbt_memtype_check_insert(new, new_type);
>> +	actual_type = new->type;
> 
> What's the point of this? new->type is set to actual_type 5 lines above.
191 int rbt_memtype_check_insert(struct memtype *new,
192                  enum page_cache_mode *ret_type)
193 {
194     int err = 0;
195 
196     err = memtype_rb_check_conflict(&memtype_rbroot, new->start, new->end,
197                         new->type, ret_type);
198 
199     if (!err) {
200         if (ret_type)
201             new->type = *ret_type;
202 
So new->type might be set to *ret_type.

136     if (match->type != found_type && newtype == NULL)
137         goto failure;
138 
139     dprintk("Overlap at 0x%Lx-0x%Lx\n", match->start, match->end);
140     found_type = match->type;
141 
142     node = rb_next(&match->rb);
143     while (node) {
144         match = container_of(node, struct memtype, rb);
145 
146         if (match->start >= end) /* Checked all possible matches */
147             goto success;
148 
149         if (is_node_overlap(match, start, end) &&
150             match->type != found_type) {
151             goto failure;
152         }
153 
154         node = rb_next(&match->rb);
155     }
156 success:
157     if (newtype)
158         *newtype = found_type;

So *ret_type might be set to found_type(match->type),

The call train is deep, it took me long time to review them.
As actual_type != new->type is possible, we need save new->type to actual_type.

thanks
xinhui
> 
> Thanks,
> 
> 	tglx
> 

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

* Re: [PATCH V2] x86/mm/pat: Do a small optimization and fix in reserve_memtype
  2015-07-21  8:26   ` Pan Xinhui
@ 2015-07-21 15:23     ` Thomas Gleixner
  0 siblings, 0 replies; 4+ messages in thread
From: Thomas Gleixner @ 2015-07-21 15:23 UTC (permalink / raw)
  To: Pan Xinhui
  Cc: linux-kernel, mingo, hpa, x86, bp, toshi.kani, jgross, mcgrof,
	mnipxh, yanmin_zhang

On Tue, 21 Jul 2015, Pan Xinhui wrote:
> So *ret_type might be set to found_type(match->type),
> 
> The call train is deep, it took me long time to review them.
> As actual_type != new->type is possible, we need save new->type to actual_type.

Fair enough. But that wants to have a comment in the code as any
casual reader will trip over this.

Thanks,

	tglx

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

end of thread, other threads:[~2015-07-21 15:23 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2015-07-21  8:02 [PATCH V2] x86/mm/pat: Do a small optimization and fix in reserve_memtype Pan Xinhui
2015-07-21  8:10 ` Thomas Gleixner
2015-07-21  8:26   ` Pan Xinhui
2015-07-21 15:23     ` Thomas Gleixner

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.