login
Login
/
Register
Search
Forums
News
Blogs
Features
Site
Home
»
Mailing list archives
»
linux-kernel
»
2008
»
August
»
13
Re: [PATCH] kexec jump: fix compiling warning on xchg(&kexec_lock, 0) in kernel_kexec()
view
thread
!MAILaRCHIVE_VOTE_RePLACE
Previous message: [
thread
] [
date
] [
author
]
Next message: [thread] [
date
] [
author
]
[view in full thread]
From:
Vivek Goyal <vgoyal@...>
To: Andrew Morton <akpm@...>
Cc: Linus Torvalds <torvalds@...>, <ebiederm@...>, <ying.huang@...>, <pavel@...>, <nigel@...>, <rjw@...>, <mingo@...>, <linux-kernel@...>, <kexec@...>
Subject:
Re: [PATCH] kexec jump: fix compiling warning on xchg(&kexec_lock, 0) in kernel_kexec()
Date: Wednesday, August 13, 2008 - 5:21 pm
On Wed, Aug 13, 2008 at 01:41:18PM -0700, Andrew Morton wrote:
quoted text
> On Wed, 13 Aug 2008 13:31:24 -0700 (PDT) > Linus Torvalds <torvalds@linux-foundation.org> wrote: > > > On Wed, 13 Aug 2008, Andrew Morton wrote: > > > > > > #2: > > > > I thought you said there were things that want to sleep in the region? > > be reasonable - that was over five minutes ago. > > --- a/kernel/kexec.c~kexec-use-a-bitop-for-locking-rather-than-xchg > +++ a/kernel/kexec.c > @@ -12,7 +12,7 @@ > #include <linux/slab.h> > #include <linux/fs.h> > #include <linux/kexec.h> > -#include <linux/spinlock.h> > +#include <linux/mutex.h> > #include <linux/list.h> > #include <linux/highmem.h> > #include <linux/syscalls.h> > @@ -924,19 +924,14 @@ static int kimage_load_segment(struct ki > */ > struct kimage *kexec_image; > struct kimage *kexec_crash_image; > -/* > - * A home grown binary mutex. > - * Nothing can wait so this mutex is safe to use > - * in interrupt context :) > - */ > -static int kexec_lock; > + > +static DEFINE_MUTEX(kexec_mutex); > > asmlinkage long sys_kexec_load(unsigned long entry, unsigned long nr_segments, > struct kexec_segment __user *segments, > unsigned long flags) > { > struct kimage **dest_image, *image; > - int locked; > int result; > > /* We only trust the superuser with rebooting the system. */ > @@ -972,8 +967,7 @@ asmlinkage long sys_kexec_load(unsigned > * > * KISS: always take the mutex. > */ > - locked = xchg(&kexec_lock, 1); > - if (locked) > + if (!mutex_trylock(&kexec_mutex)) > return -EBUSY; > > dest_image = &kexec_image; > @@ -1015,8 +1009,7 @@ asmlinkage long sys_kexec_load(unsigned > image = xchg(dest_image, image); > > out: > - locked = xchg(&kexec_lock, 0); /* Release the mutex */ > - BUG_ON(!locked); > + mutex_unlock(&kexec_mutex); > kimage_free(image); > > return result; > @@ -1063,10 +1056,7 @@ asmlinkage long compat_sys_kexec_load(un > > void crash_kexec(struct pt_regs *regs) > { > - int locked; > - > - > - /* Take the kexec_lock here to prevent sys_kexec_load > + /* Take the kexec_mutex here to prevent sys_kexec_load > * running on one cpu from replacing the crash kernel > * we are using after a panic on a different cpu. > * > @@ -1074,8 +1064,7 @@ void crash_kexec(struct pt_regs *regs) > * of memory the xchg(&kexec_crash_image) would be > * sufficient. But since I reuse the memory... > */ > - locked = xchg(&kexec_lock, 1); > - if (!locked) { > + if (mutex_trylock(&kexec_mutex)) { > if (kexec_crash_image) { > struct pt_regs fixed_regs; > crash_setup_regs(&fixed_regs, regs); > @@ -1083,8 +1072,7 @@ void crash_kexec(struct pt_regs *regs) > machine_crash_shutdown(&fixed_regs); > machine_kexec(kexec_crash_image); > } > - locked = xchg(&kexec_lock, 0); > - BUG_ON(!locked); > + mutex_unlock(&kexec_mutex); > } > } > > @@ -1434,7 +1422,7 @@ int kernel_kexec(void) > { > int error = 0; > > - if (xchg(&kexec_lock, 1)) > + if (!mutex_trylock(&kexec_mutex)) > return -EBUSY; > if (!kexec_image) { > error = -EINVAL; > @@ -1498,8 +1486,6 @@ int kernel_kexec(void) > #endif > > Unlock: > - if (!xchg(&kexec_lock, 0)) > - BUG(); > - > + mutex_unlock(&kexec_mutex); > return error; > }
I tested kexec and kudmp on 2.6.27-rc3 with this patch. Works for me on a 32 bit machine. Thanks Vivek --
unsubscribe notice
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to
majordomo@vger.kernel.org
More majordomo info at
http://vger.kernel.org/majordomo-info.html
Please read the FAQ at
http://www.tux.org/lkml/
Previous message: [
thread
] [
date
] [
author
]
Next message: [thread] [
date
] [
author
]
Messages in current thread:
[PATCH] kexec jump: fix compiling warning on xchg(&kexec...
, Huang Ying
, (Wed Aug 13, 5:12 am)
Re: [PATCH] kexec jump: fix compiling warning on xchg(&k...
, Linus Torvalds
, (Wed Aug 13, 12:57 pm)
Re: [PATCH] kexec jump: fix compiling warning on xchg(&k...
, Eric W. Biederman
, (Wed Aug 13, 2:12 pm)
Re: [PATCH] kexec jump: fix compiling warning on xchg(&k...
, Andrew Morton
, (Wed Aug 13, 3:44 pm)
Re: [PATCH] kexec jump: fix compiling warning on xchg(&k...
, Trond Myklebust
, (Wed Aug 13, 4:15 pm)
Re: [PATCH] kexec jump: fix compiling warning on xchg(&k...
, Linus Torvalds
, (Wed Aug 13, 3:50 pm)
Re: [PATCH] kexec jump: fix compiling warning on xchg(&k...
, Andrew Morton
, (Wed Aug 13, 4:07 pm)
Re: [PATCH] kexec jump: fix compiling warning on xchg(&k...
, Linus Torvalds
, (Wed Aug 13, 4:13 pm)
Re: [PATCH] kexec jump: fix compiling warning on xchg(&k...
, Andrew Morton
, (Wed Aug 13, 4:25 pm)
Re: [PATCH] kexec jump: fix compiling warning on xchg(&k...
, Linus Torvalds
, (Wed Aug 13, 4:31 pm)
Re: [PATCH] kexec jump: fix compiling warning on xchg(&k...
, Andrew Morton
, (Wed Aug 13, 4:41 pm)
Re: [PATCH] kexec jump: fix compiling warning on xchg(&k...
, Linus Torvalds
, (Wed Aug 13, 6:17 pm)
Re: [PATCH] kexec jump: fix compiling warning on xchg(&k...
, Vivek Goyal
, (Wed Aug 13, 5:21 pm)
Re: [PATCH] kexec jump: fix compiling warning on xchg(&k...
, Vivek Goyal
, (Wed Aug 13, 2:31 pm)
Re: [PATCH] kexec jump: fix compiling warning on xchg(&k...
, Andrew Morton
, (Wed Aug 13, 5:27 am)
Re: [PATCH] kexec jump: fix compiling warning on xchg(&k...
, Linus Torvalds
, (Wed Aug 13, 1:01 pm)
Re: [PATCH] kexec jump: fix compiling warning on xchg(&k...
, Andrew Morton
, (Wed Aug 13, 1:25 pm)
Re: [PATCH] kexec jump: fix compiling warning on xchg(&k...
, Ingo Molnar
, (Wed Aug 13, 1:59 pm)
Navigation
Create content
Mailing list archives
Recent posts
Popular discussions
linux-kernel
:
Greg KH
[GIT PATCH] driver core patches against 2.6.24
Hiten Pandya
Re: up? (emacs docbook xml ide)
Andy Whitcroft
clam
Kamalesh Babulal
Re: 2.6.23-rc6-mm1
git
:
linux-netdev
:
Stephen Hemminger
Re: iptables very slow after commit 784544739a25c30637397ace5489eeb6e15d7d49
David Miller
[GIT]: Networking
Gerrit Renker
[PATCH 27/37] dccp: Integration of dynamic feature activation - part 2 (server side)
openbsd-misc
:
Colocation donated by:
Who's online
There are currently
10 users
and
870 guests
online.
Online users
buildersperthh
thetruthsixpac
redaask397
cordic
murphybedsayndm
nomorepanicrab
internetmarkban
sequestrationhe
playgolfucm
broce982
Syndicate