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
next prev parent 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