From mboxrd@z Thu Jan 1 00:00:00 1970 From: Jeff Garzik Subject: Re: [PATCH] ide-scsi highmem cleanup Date: Sun, 30 Oct 2005 22:48:20 -0500 Message-ID: <43659404.6050605@pobox.com> References: <200510310302.j9V32hO4009277@hera.kernel.org> Mime-Version: 1.0 Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit Return-path: Received: from mail.dvmed.net ([216.237.124.58]:12172 "EHLO mail.dvmed.net") by vger.kernel.org with ESMTP id S1751319AbVJaDsc (ORCPT ); Sun, 30 Oct 2005 22:48:32 -0500 In-Reply-To: <200510310302.j9V32hO4009277@hera.kernel.org> Sender: linux-ide-owner@vger.kernel.org List-Id: linux-ide@vger.kernel.org To: Andrew Morton Cc: Linux Kernel Mailing List , Linus Torvalds , Bartlomiej Zolnierkiewicz , "linux-ide@vger.kernel.org" , Alan Cox Linux Kernel Mailing List wrote: > tree c6016a8741a2527acac0ceb6e6ce431a798d6708 > parent f1fc78a8c7f3a784b9fd1e07cc1438a0ea569555 > author Andrew Morton Mon, 31 Oct 2005 07:00:13 -0800 > committer Linus Torvalds Mon, 31 Oct 2005 09:37:17 -0800 > > [PATCH] ide-scsi highmem cleanup > > It's not necessary to test PageHighmem in here - kmap_atomic() does the right > thing. > > Cc: Bartlomiej Zolnierkiewicz > Signed-off-by: Andrew Morton > Signed-off-by: Linus Torvalds > > drivers/scsi/ide-scsi.c | 38 ++++++++++++-------------------------- > 1 files changed, 12 insertions(+), 26 deletions(-) > > diff --git a/drivers/scsi/ide-scsi.c b/drivers/scsi/ide-scsi.c > --- a/drivers/scsi/ide-scsi.c > +++ b/drivers/scsi/ide-scsi.c > @@ -180,19 +180,12 @@ static void idescsi_input_buffers (ide_d > return; > } > count = min(pc->sg->length - pc->b_count, bcount); > - if (PageHighMem(pc->sg->page)) { > - unsigned long flags; > - > - local_irq_save(flags); > - buf = kmap_atomic(pc->sg->page, KM_IRQ0) + pc->sg->offset; > - drive->hwif->atapi_input_bytes(drive, buf + pc->b_count, count); > - kunmap_atomic(buf - pc->sg->offset, KM_IRQ0); > - local_irq_restore(flags); > - } else { > - buf = page_address(pc->sg->page) + pc->sg->offset; > - drive->hwif->atapi_input_bytes(drive, buf + pc->b_count, count); > - } > - bcount -= count; pc->b_count += count; > + buf = kmap_atomic(pc->sg->page, KM_IRQ0); > + drive->hwif->atapi_input_bytes(drive, > + buf + pc->b_count + pc->sg->offset, count); > + kunmap_atomic(buf, KM_IRQ0); > + bcount -= count; > + pc->b_count += count; > if (pc->b_count == pc->sg->length) { > pc->sg++; > pc->b_count = 0; > @@ -212,19 +205,12 @@ static void idescsi_output_buffers (ide_ > return; > } > count = min(pc->sg->length - pc->b_count, bcount); > - if (PageHighMem(pc->sg->page)) { > - unsigned long flags; > - > - local_irq_save(flags); > - buf = kmap_atomic(pc->sg->page, KM_IRQ0) + pc->sg->offset; > - drive->hwif->atapi_output_bytes(drive, buf + pc->b_count, count); > - kunmap_atomic(buf - pc->sg->offset, KM_IRQ0); > - local_irq_restore(flags); > - } else { > - buf = page_address(pc->sg->page) + pc->sg->offset; > - drive->hwif->atapi_output_bytes(drive, buf + pc->b_count, count); > - } > - bcount -= count; pc->b_count += count; > + buf = kmap_atomic(pc->sg->page, KM_IRQ0); > + drive->hwif->atapi_output_bytes(drive, > + buf + pc->b_count + pc->sg->offset, count); > + kunmap_atomic(buf, KM_IRQ0); > + bcount -= count; > + pc->b_count += count; Unless I'm missing something, this patch looks very wrong. kmap_atomic(..., KM_IRQx) needs to be inside local_irq_save(). As such, the PageHighMem() does have clear benefits. Jeff