public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
From: "Rafael J. Wysocki" <rjw@sisk.pl>
To: Pavel Machek <pavel@ucw.cz>
Cc: Andrew Morton <akpm@osdl.org>,
	LKML <linux-kernel@vger.kernel.org>,
	Nigel Cunningham <ncunningham@linuxmail.org>,
	Christoph Hellwig <hch@infradead.org>
Subject: Re: [PATCH -mm] swsusp: Freeze filesystems during suspend
Date: Wed, 1 Nov 2006 13:05:57 +0100	[thread overview]
Message-ID: <200611011305.57657.rjw@sisk.pl> (raw)
In-Reply-To: <20061101114707.GA22079@atrey.karlin.mff.cuni.cz>

Hi,

On Wednesday, 1 November 2006 12:47, Pavel Machek wrote:
> Hi!
> 
> > Freeze all filesystems during the suspend by calling freeze_bdev() for each of
> > them and thaw them during the resume using thaw_bdev().
> > 
> > This is needed by swsusp, because some filesystems (eg. XFS) use work queues
> > and worker_threads run with PF_NOFREEZE set, so they can cause some writes
> > to be performed after the suspend image has been created which may corrupt
> > the filesystem.  The additional benefit of it is that if the resume fails, the
> > filesystems will be in a consistent state and there won't be any journal replays
> > needed.
> > 
> > The freezing of filesystems is carried out when processes are being frozen, so
> > on the majority of architectures it also will happen during a
> > suspend to RAM.
> 
> 
> > @@ -119,7 +120,7 @@ int freeze_processes(void)
> >  		read_unlock(&tasklist_lock);
> >  		todo += nr_user;
> >  		if (!user_frozen && !nr_user) {
> > -			sys_sync();
> > +			freeze_filesystems();
> >  			start_time = jiffies;
> >  		}
> >  		user_frozen = !nr_user;
> 
> 
> Do all filesystems implement freeze?

I think so.

> If not, we may want to keep that sync...

But the sync() won't hurt anyway I think.

> 
> 
> > @@ -156,28 +157,43 @@ int freeze_processes(void)
> >  void thaw_some_processes(int all)
> >  {
> >  	struct task_struct *g, *p;
> > -	int pass = 0; /* Pass 0 = Kernel space, 1 = Userspace */
> >  
> >  	printk("Restarting tasks... ");
> >  	read_lock(&tasklist_lock);
> > -	do {
> > -		do_each_thread(g, p) {
> > -			/*
> > -			 * is_user = 0 if kernel thread or borrowed mm,
> > -			 * 1 otherwise.
> > -			 */
> > -			int is_user = !!(p->mm && !(p->flags & PF_BORROWED_MM));
> > -			if (!freezeable(p) || (is_user != pass))
> > -				continue;
> > -			if (!thaw_process(p))
> > -				printk(KERN_INFO
> > -					"Strange, %s not stopped\n", p->comm);
> > -		} while_each_thread(g, p);
> >  
> > -		pass++;
> > -	} while (pass < 2 && all);
> > +	do_each_thread(g, p) {
> > +		if (!freezeable(p))
> > +			continue;
> > +
> > +		/* Don't thaw userland processes, for now */
> > +		if (p->mm && !(p->flags & PF_BORROWED_MM))
> > +			continue;
> > +
> > +		if (!thaw_process(p))
> > +			printk(KERN_INFO " Strange, %s not stopped\n", p->comm );
> > +	} while_each_thread(g, p);
> > +
> > +	read_unlock(&tasklist_lock);
> > +	if (!all)
> > +		goto Exit;
> > +
> > +	thaw_filesystems();
> > +	read_lock(&tasklist_lock);
> > +
> > +	do_each_thread(g, p) {
> > +		if (!freezeable(p))
> > +			continue;
> > +
> > +		/* Kernel threads should have been thawed already */
> > +		if (!p->mm || (p->flags & PF_BORROWED_MM))
> > +			continue;
> > +
> > +		if (!thaw_process(p))
> > +			printk(KERN_INFO " Strange, %s not stopped\n", p->comm );
> > +	} while_each_thread(g, p);
> >  
> >  	read_unlock(&tasklist_lock);
> > +Exit:
> >  	schedule();
> >  	printk("done.\n");
> 
> 
> Could we do without the code duplication?

Okay, I'll move the loop(s) into a separate function.

> > +/**
> > + * freeze_filesystems - lock all filesystems and force them into a consistent
> > + * state
> > + */
> > +void freeze_filesystems(void)
> > +{
> > +	struct super_block *sb;
> > +
> > +	lockdep_off();
> 
> You should not just turn off lockdep because you don't like its
> output.
> 
> Perhaps tasklist_lock does not nest with whatever freeze_bdev needs?

The locks taken in one call to freeze_bdev() nest with analogous locks
taken in the other calls to freeze_bdev().  Actually we take several locks of
the same (I think) class in a row and keep them all until thaw_filesystems()
is called, which is quite unusual.  I don't think there's any way in which we
can convince lockdep that it's all okay other than switching it off.

Greetings,
Rafael


-- 
You never change things by fighting the existing reality.
		R. Buckminster Fuller

  reply	other threads:[~2006-11-01 12:07 UTC|newest]

Thread overview: 10+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2006-11-01 11:00 [PATCH -mm] swsusp: Freeze filesystems during suspend Rafael J. Wysocki
2006-11-01 11:47 ` Pavel Machek
2006-11-01 12:05   ` Rafael J. Wysocki [this message]
2006-11-01 17:53   ` [PATCH -mm] swsusp: Freeze filesystems during suspend (rev. 2) Rafael J. Wysocki
2006-11-01 19:45     ` Andrew Morton
2006-11-01 20:27       ` Rafael J. Wysocki
2006-11-01 21:21         ` Andrew Morton
2006-11-02 20:53           ` Rafael J. Wysocki
2006-11-01 19:54     ` Andrew Morton
2006-11-01 20:22       ` Rafael J. Wysocki

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=200611011305.57657.rjw@sisk.pl \
    --to=rjw@sisk.pl \
    --cc=akpm@osdl.org \
    --cc=hch@infradead.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=ncunningham@linuxmail.org \
    --cc=pavel@ucw.cz \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox