Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id ; Tue, 16 Apr 2002 08:04:08 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id ; Tue, 16 Apr 2002 08:04:07 -0400 Received: from [195.63.194.11] ([195.63.194.11]:57097 "EHLO mail.stock-world.de") by vger.kernel.org with ESMTP id ; Tue, 16 Apr 2002 08:04:06 -0400 Message-ID: <3CBC04A5.1040201@evision-ventures.com> Date: Tue, 16 Apr 2002 13:01:57 +0200 From: Martin Dalecki User-Agent: Mozilla/5.0 (X11; U; Linux i686; en-US; rv:0.9.9) Gecko/20020311 X-Accept-Language: en-us, pl MIME-Version: 1.0 To: Jens Axboe CC: Petr Vandrovec , linux-kernel@vger.kernel.org Subject: Re: [PATCH] IDE TCQ #4 In-Reply-To: <27670700DF5@vcnet.vc.cvut.cz> <20020416102501.GG17043@suse.de> Content-Type: text/plain; charset=us-ascii; format=flowed Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Jens Axboe wrote: > yes this looks like a silly problem. the fix should be to have > ata_ar_get() set ATA_AR_RETURN in ar_flags: > > if (!list_empty(&drive->free_req)) { > ar = list_ata_entry(drive->free_req.next); > list_del(&ar->ar_queue); > ata_ar_init(drive, ar); > ar->ar_flags |= ATA_AR_RETURN; > } > > and then only have ata_ar_put() readd it to the list when it is set: > > static inline void ata_ar_put(ide_drive_t *drive, struct ata_request > *ar) > { > if (ar->ar_flags & ATA_AR_RETURN) > list_add(&ar->ar_queue, &drive->free_req); > ... > > Then you can also remove the ata_ar_put() conditional in > ide_end_drive_cmd(), just call ata_ar_put() unconditionally. Well something similar is already in IDE 37... I have just invented a flag ATA_AR_STATIC which get's set in ide_raw_taskfile ata_ar_put ich then checking for if (!(ar->ar_flags & ATA_AR_STATIC))... It has the desired effect in practice. - 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/