----- Original Message ----- > >>> On 20.02.12 at 11:35, Andrew Jones <drjones@xxxxxxxxxx> wrote: > > > > > ----- Original Message ----- > >> On Fri, Feb 17, 2012 at 05:52:54PM +0100, Andrew Jones wrote: > >> > On Thu, Feb 16, 2012 at 12:33:32PM -0500, Andrew Jones wrote: > >> > > Hmm, I should maybe self-nack this. The bug that led me to > >> > > writing > >> > > it is likely only with older tooling, such as RHEL5's. The > >> > > problem > >> > > was if you attempted to detach a mounted disk twice, then the > >> > > second > >> > > time it would succeed. The guest had flipped to Closing on the > >> > > first > >> > > try, and thus didn't issue an error to xenbus on the second. I > >> > > see > >> > > >> > Actually, it's even worse than I thought. Just a single attempt > >> > to > >> > detach the device will cause the guest grief (with RHEL5's tools > >> > anyway). Once xenbus shows the device is in the Closing state, > >> > then > >> > tasks accessing the device may hang. > >> > > >> > > The reason I only say maybe self-nack though, is because this > >> > > state > >> > > change seemed to be thrown in with another fix[1]. I'm not > >> > > sure > >> > > if > >> > > the new behavior on legacy hosts was considered or not. If > >> > > not, > >> > > then > >> > > we can consider it now. Do we want to have deferred asynch > >> > > detaches > >> > > over protecting the guest from multiple detach calls on legacy > >> > > hosts? > >> > > > >> > > >> > I guess we can keep the feature and protect the guest with a > >> > patch > >> > like > >> > I'll send in a moment. It doesn't really work for me with a > >> > RHEL5 > >> > host > >> > though. The deferred close works from the pov of the guest, but > >> > the > >> > state of the block device gets left in Closed after the guest > >> > unmounts > >> > it, and then RHEL5's tools can't detach/reattach it. If the > >> > deferred > >> > close ever worked on other Xen hosts though, then I don't > >> > believe > >> > this > >> > patch would break it, and it will also keep the guest safe when > >> > run > >> > on > >> > hosts that don't treat state=Closing the way it currently > >> > expects. > >> > >> There was another fix that sounds similar to this in the backend. > >> 6f5986bce558e64fe867bff600a2127a3cb0c006 > >> > > > > Thanks for the pointer. It doesn't look like the upstream 2.6.18 > > tree has that, but it probably would be a good idea there too. > > While I had seen the change and considered pulling it in, I wasn't > really convinced this is the right behavior here: After all, if the > host > admin requested a resource to be removed from a guest, it shouldn't > depend on the guest whether and when to honor that request, yet > by deferring the disconnect you basically allow the guest to continue > using the disk indefinitely. > I agree. Yesterday I wrote[1] asking if "deferred detach" is really something we want. At the moment, Igor and I are poking through xen-blkfront.c, and currently we'd rather see the feature dropped in favor of a simplified driver. One that has less release paths, and/or release paths with more consistent locking behavior. Drew [1] http://lists.xen.org/archives/html/xen-devel/2012-02/msg01672.html > Jan > > > However, even with that ability to patch backends, we probably > > want the frontends to be more robust on legacy backends for a while > > longer. So, it probably would be best to avoid changing the state > > to > > Closing while we're still busy, unless it's absolutely necessary. > > > > Drew > > > > _______________________________________________ > > Xen-devel mailing list > > Xen-devel@xxxxxxxxxxxxxxxxxxx > > http://lists.xensource.com/xen-devel > > > > > _______________________________________________ > Xen-devel mailing list > Xen-devel@xxxxxxxxxxxxx > http://lists.xensource.com/xen-devel > _______________________________________________ Virtualization mailing list Virtualization@xxxxxxxxxxxxxxxxxxxxxxxxxx https://lists.linuxfoundation.org/mailman/listinfo/virtualization