Re: [PATCH v4 2/3] virtio_balloon: introduce migration primitives toballoon pages

From: Rafael Aquini
Date: Wed Jul 18 2012 - 19:16:57 EST


Howdy Andrew,

Thanks for taking the time to go through this work and provide me with such good
feedback.

On Wed, Jul 18, 2012 at 03:49:08PM -0700, Andrew Morton wrote:
> On Tue, 17 Jul 2012 13:50:42 -0300
> Rafael Aquini <aquini@xxxxxxxxxx> wrote:
>
> > Besides making balloon pages movable at allocation time and introducing
> > the necessary primitives to perform balloon page migration/compaction,
> > this patch also introduces the following locking scheme to provide the
> > proper synchronization and protection for struct virtio_balloon elements
> > against concurrent accesses due to parallel operations introduced by
> > memory compaction / page migration.
> > - balloon_lock (mutex) : synchronizes the access demand to elements of
> > struct virtio_balloon and its queue operations;
> > - pages_lock (spinlock): special protection to balloon pages list against
> > concurrent list handling operations;
> >
> > ...
> >
> > + balloon_mapping->a_ops = &virtio_balloon_aops;
> > + balloon_mapping->backing_dev_info = (void *)vb;
>
> hoo boy. We're making page->mapping->backing_dev_info point at a
> struct which does not have type `struct backing_dev_info'. And then we
> are exposing that page to core MM functions. So we're hoping that core
> MM will never walk down page->mapping->backing_dev_info and explode.
>
> That's nasty, hacky and fragile.

Shame on me, on this one.

Mea culpa: I took this approach, originally, because I stuck the spinlock within
the struct virtio_balloon and this was the easiest way to recover it just by
having the page pointer. I did this stupidity because on earlier stages of this
patch some functions that demanded access to that list spinlock were placed
outside the balloon driver's code -- this is a left-over
(I know, it's a total lame excuse, but it's the truth)

This is easily fixable, however, as the balloon page list spinlock is now only
being accessed within driver's code and it can be declared outside the struct.


--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/