public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
From: "Gérard Roudier" <groudier@free.fr>
To: Dave Jones <davej@suse.de>
Cc: Linux Kernel <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH] make ncr53c8xx work with bio.
Date: Tue, 4 Dec 2001 20:23:49 +0100 (CET)	[thread overview]
Message-ID: <20011204195646.H3044-100000@gerard> (raw)
In-Reply-To: <20011204133520.A3760@suse.de>


Hi Dave,

Indeed the patch does make the ncr53c8xx driver compile and work again.
If Linus accepts to apply your patch, this will be just fine.

However, the question about still having ncr53c8xx and may-be sym53c8xx
version 1 in linux-2.5, given that sym-2 can, at least in theory, replaces
both, is not yet answered.

Anyway, at minimal, these drivers should get made conformant to eh
expectations and also modified as follows:

- Remove the double spin_locking.

- Remove the batching of completions prior to give them back to upper
  layer. This is useless given that no recursive call can happen and
  such batching is done by scsi layer thanks to forced new eh.

Such changes are easy to make, at least by me, and I will propose them if
it gets proven that these drivers versions are still useful for linux-2.5.
This depends obviously on the actual reliability of sym-2 compared to the
bundle ncr53c8xx/sym53c8xx. Only practice can give the right answer.

In the meantime, maintaining these drivers at minimal compilable and
working is certainly a good thing.

  Gérard.

On Tue, 4 Dec 2001, Dave Jones wrote:

> Hi folks,
>  Patch below makes ncr53c8xx driver compile again in 2.5.1pre5.
>  Seems to have survived yesterdays torture tests.
>
> regards,
> Dave.
>
> diff -urN --exclude-from=/home/davej/.exclude linux/drivers/scsi/ncr53c8xx.c linux-dj/drivers/scsi/ncr53c8xx.c
> --- linux/drivers/scsi/ncr53c8xx.c	Sun Sep 30 20:26:07 2001
> +++ linux-dj/drivers/scsi/ncr53c8xx.c	Mon Dec  3 16:44:11 2001
> @@ -8625,9 +8625,9 @@
>       if (DEBUG_FLAGS & DEBUG_TINY) printk ("]\n");
>
>       if (done_list) {
> -          NCR_LOCK_SCSI_DONE(np, flags);
> +          NCR_LOCK_SCSI_DONE(done_list->host, flags);
>            ncr_flush_done_cmds(done_list);
> -          NCR_UNLOCK_SCSI_DONE(np, flags);
> +          NCR_UNLOCK_SCSI_DONE(done_list->host, flags);
>       }
>  }
>
> @@ -8648,9 +8648,9 @@
>       NCR_UNLOCK_NCB(np, flags);
>
>       if (done_list) {
> -          NCR_LOCK_SCSI_DONE(np, flags);
> +          NCR_LOCK_SCSI_DONE(done_list->host, flags);
>            ncr_flush_done_cmds(done_list);
> -          NCR_UNLOCK_SCSI_DONE(np, flags);
> +          NCR_UNLOCK_SCSI_DONE(done_list->host, flags);
>       }
>  }
>
> diff -urN --exclude-from=/home/davej/.exclude linux/drivers/scsi/sym53c8xx_comm.h linux-dj/drivers/scsi/sym53c8xx_comm.h
> --- linux/drivers/scsi/sym53c8xx_comm.h	Fri Oct 12 23:35:54 2001
> +++ linux-dj/drivers/scsi/sym53c8xx_comm.h	Mon Dec  3 16:43:38 2001
> @@ -438,10 +438,10 @@
>  #define	NCR_LOCK_NCB(np, flags)    spin_lock_irqsave(&np->smp_lock, flags)
>  #define	NCR_UNLOCK_NCB(np, flags)  spin_unlock_irqrestore(&np->smp_lock, flags)
>
> -#define	NCR_LOCK_SCSI_DONE(np, flags) \
> -		spin_lock_irqsave(&io_request_lock, flags)
> -#define	NCR_UNLOCK_SCSI_DONE(np, flags) \
> -		spin_unlock_irqrestore(&io_request_lock, flags)
> +#define	NCR_LOCK_SCSI_DONE(host, flags) \
> +		spin_lock_irqsave(&(host)->host_lock, flags)
> +#define	NCR_UNLOCK_SCSI_DONE(host, flags) \
> +		spin_unlock_irqrestore(&((host)->host_lock), flags)
>
>  #else
>
> @@ -452,8 +452,8 @@
>  #define	NCR_LOCK_NCB(np, flags)    do { save_flags(flags); cli(); } while (0)
>  #define	NCR_UNLOCK_NCB(np, flags)  do { restore_flags(flags); } while (0)
>
> -#define	NCR_LOCK_SCSI_DONE(np, flags)    do {;} while (0)
> -#define	NCR_UNLOCK_SCSI_DONE(np, flags)  do {;} while (0)
> +#define	NCR_LOCK_SCSI_DONE(host, flags)    do {;} while (0)
> +#define	NCR_UNLOCK_SCSI_DONE(host, flags)  do {;} while (0)
>
>  #endif
>
>
> --
> | Dave Jones.                    http://www.codemonkey.org.uk
> | SuSE Labs .
>
>


      reply	other threads:[~2001-12-04 22:17 UTC|newest]

Thread overview: 2+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2001-12-04 13:35 [PATCH] make ncr53c8xx work with bio Dave Jones
2001-12-04 19:23 ` Gérard Roudier [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20011204195646.H3044-100000@gerard \
    --to=groudier@free.fr \
    --cc=davej@suse.de \
    --cc=linux-kernel@vger.kernel.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox