Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933537AbYBMRU6 (ORCPT ); Wed, 13 Feb 2008 12:20:58 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1757586AbYBMRUr (ORCPT ); Wed, 13 Feb 2008 12:20:47 -0500 Received: from bzq-219-195-70.pop.bezeqint.net ([62.219.195.70]:57699 "EHLO bh-buildlin2.bhalevy.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754403AbYBMRUp (ORCPT ); Wed, 13 Feb 2008 12:20:45 -0500 Message-ID: <47B32680.5020405@panasas.com> Date: Wed, 13 Feb 2008 19:18:56 +0200 From: Boaz Harrosh User-Agent: Thunderbird 2.0.0.9 (X11/20071031) MIME-Version: 1.0 To: James Bottomley CC: =?UTF-8?B?U3ZlbiBLw7ZobGVy?= , Christoph Hellwig , Jeff Garzik , linux-scsi , linux-kernel@vger.kernel.org, Joerg Dorchain , Jon Chelton , Stefan Priebe - allied internet ag Subject: Re: [BUGFIX 2/2] gdth: bugfix for the Timer at exit crash References: <47A19E26.30107@panasas.com> <47B1D7A8.8010108@panasas.com> <47B1DA2A.1060904@panasas.com> <1202917468.3109.5.camel@localhost.localdomain> <47B312B3.3010200@panasas.com> <47B31BDE.2030408@panasas.com> <1202921122.3109.31.camel@localhost.localdomain> <47B31FC2.4040206@panasas.com> <1202922226.3109.36.camel@localhost.localdomain> In-Reply-To: <1202922226.3109.36.camel@localhost.localdomain> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2991 Lines: 74 On Wed, Feb 13 2008 at 19:03 +0200, James Bottomley wrote: > On Wed, 2008-02-13 at 18:50 +0200, Boaz Harrosh wrote: >> On Wed, Feb 13 2008 at 18:45 +0200, James Bottomley wrote: >>> On Wed, 2008-02-13 at 18:33 +0200, Boaz Harrosh wrote: >>>> On Wed, Feb 13 2008 at 17:54 +0200, Boaz Harrosh wrote: >>>>> On Wed, Feb 13 2008 at 17:44 +0200, James Bottomley wrote: >>>>>> On Tue, 2008-02-12 at 19:40 +0200, Boaz Harrosh wrote: >>>>>>> - gdth_flush(ha); >>>>>>> - >>>>>> This piece doesn't look right. gdth_flush() forces the internal cache >>>>>> to disk backing. If you remove it, you're taking the chance that the >>>>>> machine will be powered off without a writeback which can cause data >>>>>> corruption. >>>>>> >>>>>> James >>>>>> >>>>> Yes. >>>>> I have more problems reported, with exit, and am just sending one more patch that puts >>>>> this back in. Which was tested. >>>>> >>>>> So I will resend this one plus one new one. >>>>> >>>>> Boaz >>>>> >>>> The gdth driver would do a register_reboot_notifier(&gdth_notifier); >>>> to a gdth_halt() function, which would then redo half of what gdth_exit >>>> does, and wrongly so, and crash. >>>> >>>> Are we guaranteed in todays kernel that modules .exit function be called >>>> on an halt or reboot? If so then there is no need for duplications and >>>> the gdth_halt() should go. >>> No. The __exit section is actually discardable if you promise never to >>> remove the module. >>> >> I don't understand please explain. >> What does a driver need to do if it needs a consistent shutdown retine? >> module or built in? unload or shutdown? > > It needs to register a reboot notifier, which gdth does. > > However, the notifier is only called on reboot, so it also needs to > clean up correctly on module exit as well. > > The alternative for GDTH would be to process the SCSI SYNCHRONIZE CACHE Why would we think that the controller does not support this command is it not in the mandatory section of the standard? > command. That's done by a shutdown notifier from sd, so the correct > thing would always get done; however it does mean the driver has to be > in a condition to process the last sync cache command. Why would it not be ready? what do other drivers do? The drivers is ready until the very last module's .exit. Is that good enough? > > For the quick fix, just keep the current infrastructure and put back the > gdth_flush() command where it can be effective. > Just did. But if needed I would prefer to emulate the SCSI SYNCHRONIZE CACHE command and not that boot notifier thing. Please advise. > James > > Boaz -- 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/