Commit 0a66d840 authored by Adrian Bunk's avatar Adrian Bunk Committed by Linus Torvalds

[PATCH] SCSI qlogicisp.c: some cleanups

This patch does the following cleanups:
- make some needlessly global functions static
- remove qlogicisp.h since it doesn't contain much
- remove the unused functions isp1020_abort and isp1020_reset

Please review especially the latter two points.
Signed-off-by: default avatarAdrian Bunk <bunk@stusta.de>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent ae436d9c
......@@ -37,7 +37,21 @@
#include <asm/byteorder.h>
#include "scsi.h"
#include <scsi/scsi_host.h>
#include "qlogicisp.h"
/*
* With the qlogic interface, every queue slot can hold a SCSI
* command with up to 4 scatter/gather entries. If we need more
* than 4 entries, continuation entries can be used that hold
* another 7 entries each. Unlike for other drivers, this means
* that the maximum number of scatter/gather entries we can
* support at any given time is a function of the number of queue
* slots available. That is, host->can_queue and host->sg_tablesize
* are dynamic and _not_ independent. This all works fine because
* requests are queued serially and the scatter/gather limit is
* determined for each queue request anew.
*/
#define QLOGICISP_REQ_QUEUE_LEN 63 /* must be power of two - 1 */
#define QLOGICISP_MAX_SG(ql) (4 + ((ql) > 0) ? 7*((ql) - 1) : 0)
/* Configuration section *****************************************************/
......@@ -655,7 +669,7 @@ static inline void isp1020_disable_irqs(struct Scsi_Host *host)
}
int isp1020_detect(Scsi_Host_Template *tmpt)
static int isp1020_detect(Scsi_Host_Template *tmpt)
{
int hosts = 0;
struct Scsi_Host *host;
......@@ -736,7 +750,7 @@ int isp1020_detect(Scsi_Host_Template *tmpt)
}
int isp1020_release(struct Scsi_Host *host)
static int isp1020_release(struct Scsi_Host *host)
{
struct isp1020_hostdata *hostdata;
......@@ -757,7 +771,7 @@ int isp1020_release(struct Scsi_Host *host)
}
const char *isp1020_info(struct Scsi_Host *host)
static const char *isp1020_info(struct Scsi_Host *host)
{
static char buf[80];
struct isp1020_hostdata *hostdata;
......@@ -783,7 +797,7 @@ const char *isp1020_info(struct Scsi_Host *host)
* interrupt handler may call this routine as part of
* request-completion handling).
*/
int isp1020_queuecommand(Scsi_Cmnd *Cmnd, void (*done)(Scsi_Cmnd *))
static int isp1020_queuecommand(Scsi_Cmnd *Cmnd, void (*done)(Scsi_Cmnd *))
{
int i, n, num_free;
u_int in_ptr, out_ptr;
......@@ -1161,80 +1175,7 @@ static int isp1020_return_status(struct Status_Entry *sts)
}
int isp1020_abort(Scsi_Cmnd *Cmnd)
{
u_short param[6];
struct Scsi_Host *host;
struct isp1020_hostdata *hostdata;
int return_status = SCSI_ABORT_SUCCESS;
u_int cmd_cookie;
int i;
ENTER("isp1020_abort");
host = Cmnd->device->host;
hostdata = (struct isp1020_hostdata *) host->hostdata;
for (i = 0; i < QLOGICISP_REQ_QUEUE_LEN + 1; i++)
if (hostdata->cmd_slots[i] == Cmnd)
break;
cmd_cookie = i;
isp1020_disable_irqs(host);
param[0] = MBOX_ABORT;
param[1] = (((u_short) Cmnd->device->id) << 8) | Cmnd->device->lun;
param[2] = cmd_cookie >> 16;
param[3] = cmd_cookie & 0xffff;
isp1020_mbox_command(host, param);
if (param[0] != MBOX_COMMAND_COMPLETE) {
printk("qlogicisp : scsi abort failure: %x\n", param[0]);
return_status = SCSI_ABORT_ERROR;
}
isp1020_enable_irqs(host);
LEAVE("isp1020_abort");
return return_status;
}
int isp1020_reset(Scsi_Cmnd *Cmnd, unsigned int reset_flags)
{
u_short param[6];
struct Scsi_Host *host;
struct isp1020_hostdata *hostdata;
int return_status = SCSI_RESET_SUCCESS;
ENTER("isp1020_reset");
host = Cmnd->device->host;
hostdata = (struct isp1020_hostdata *) host->hostdata;
param[0] = MBOX_BUS_RESET;
param[1] = hostdata->host_param.bus_reset_delay;
isp1020_disable_irqs(host);
isp1020_mbox_command(host, param);
if (param[0] != MBOX_COMMAND_COMPLETE) {
printk("qlogicisp : scsi bus reset failure: %x\n", param[0]);
return_status = SCSI_RESET_ERROR;
}
isp1020_enable_irqs(host);
LEAVE("isp1020_reset");
return return_status;
}
int isp1020_biosparam(struct scsi_device *sdev, struct block_device *n,
static int isp1020_biosparam(struct scsi_device *sdev, struct block_device *n,
sector_t capacity, int ip[])
{
int size = capacity;
......
/*
* QLogic ISP1020 Intelligent SCSI Processor Driver (PCI)
* Written by Erik H. Moe, ehm@cris.com
* Copyright 1995, Erik H. Moe
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the
* Free Software Foundation; either version 2, or (at your option) any
* later version.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* General Public License for more details.
*/
/* Renamed and updated to 1.3.x by Michael Griffith <grif@cs.ucr.edu> */
/*
* $Date: 1995/09/22 02:32:56 $
* $Revision: 0.5 $
*
* $Log: isp1020.h,v $
* Revision 0.5 1995/09/22 02:32:56 root
* do auto request sense
*
* Revision 0.4 1995/08/07 04:48:28 root
* supply firmware with driver.
* numerous bug fixes/general cleanup of code.
*
* Revision 0.3 1995/07/16 16:17:16 root
* added reset/abort code.
*
* Revision 0.2 1995/06/29 03:19:43 root
* fixed biosparam.
* added queue protocol.
*
* Revision 0.1 1995/06/25 01:56:13 root
* Initial release.
*
*/
#ifndef _QLOGICISP_H
#define _QLOGICISP_H
/*
* With the qlogic interface, every queue slot can hold a SCSI
* command with up to 4 scatter/gather entries. If we need more
* than 4 entries, continuation entries can be used that hold
* another 7 entries each. Unlike for other drivers, this means
* that the maximum number of scatter/gather entries we can
* support at any given time is a function of the number of queue
* slots available. That is, host->can_queue and host->sg_tablesize
* are dynamic and _not_ independent. This all works fine because
* requests are queued serially and the scatter/gather limit is
* determined for each queue request anew.
*/
#define QLOGICISP_REQ_QUEUE_LEN 63 /* must be power of two - 1 */
#define QLOGICISP_MAX_SG(ql) (4 + ((ql) > 0) ? 7*((ql) - 1) : 0)
int isp1020_detect(Scsi_Host_Template *);
int isp1020_release(struct Scsi_Host *);
const char * isp1020_info(struct Scsi_Host *);
int isp1020_queuecommand(Scsi_Cmnd *, void (* done)(Scsi_Cmnd *));
int isp1020_abort(Scsi_Cmnd *);
int isp1020_reset(Scsi_Cmnd *, unsigned int);
int isp1020_biosparam(struct scsi_device *, struct block_device *,
sector_t, int[]);
#endif /* _QLOGICISP_H */
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment