The SCSI standard defines 64-bit values for LUNs, and large arrays employing large or hierarchical LUN numbers become more and more common. So update the linux SCSI stack to use 64-bit LUN numbers. Signed-off-by: Hannes Reinecke <hare@suse.de> Reviewed-by: Christoph Hellwig <hch@infradead.org> Reviewed-by: Ewan Milne <emilne@redhat.com> Signed-off-by: Christoph Hellwig <hch@lst.de>
		
			
				
	
	
		
			138 lines
		
	
	
	
		
			6 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			138 lines
		
	
	
	
		
			6 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 *  linux/drivers/message/fusion/mptscsih.h
 | 
						|
 *      High performance SCSI / Fibre Channel SCSI Host device driver.
 | 
						|
 *      For use with PCI chip/adapter(s):
 | 
						|
 *          LSIFC9xx/LSI409xx Fibre Channel
 | 
						|
 *      running LSI Fusion MPT (Message Passing Technology) firmware.
 | 
						|
 *
 | 
						|
 *  Copyright (c) 1999-2008 LSI Corporation
 | 
						|
 *  (mailto:DL-MPTFusionLinux@lsi.com)
 | 
						|
 *
 | 
						|
 */
 | 
						|
/*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=*/
 | 
						|
/*
 | 
						|
    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; version 2 of the License.
 | 
						|
 | 
						|
    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.
 | 
						|
 | 
						|
    NO WARRANTY
 | 
						|
    THE PROGRAM IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OR
 | 
						|
    CONDITIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED INCLUDING, WITHOUT
 | 
						|
    LIMITATION, ANY WARRANTIES OR CONDITIONS OF TITLE, NON-INFRINGEMENT,
 | 
						|
    MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Each Recipient is
 | 
						|
    solely responsible for determining the appropriateness of using and
 | 
						|
    distributing the Program and assumes all risks associated with its
 | 
						|
    exercise of rights under this Agreement, including but not limited to
 | 
						|
    the risks and costs of program errors, damage to or loss of data,
 | 
						|
    programs or equipment, and unavailability or interruption of operations.
 | 
						|
 | 
						|
    DISCLAIMER OF LIABILITY
 | 
						|
    NEITHER RECIPIENT NOR ANY CONTRIBUTORS SHALL HAVE ANY LIABILITY FOR ANY
 | 
						|
    DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 | 
						|
    DAMAGES (INCLUDING WITHOUT LIMITATION LOST PROFITS), HOWEVER CAUSED AND
 | 
						|
    ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
 | 
						|
    TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
 | 
						|
    USE OR DISTRIBUTION OF THE PROGRAM OR THE EXERCISE OF ANY RIGHTS GRANTED
 | 
						|
    HEREUNDER, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGES
 | 
						|
 | 
						|
    You should have received a copy of the GNU General Public License
 | 
						|
    along with this program; if not, write to the Free Software
 | 
						|
    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 | 
						|
*/
 | 
						|
 | 
						|
#ifndef SCSIHOST_H_INCLUDED
 | 
						|
#define SCSIHOST_H_INCLUDED
 | 
						|
 | 
						|
/*=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=*/
 | 
						|
/*
 | 
						|
 *	SCSI Public stuff...
 | 
						|
 */
 | 
						|
 | 
						|
#define MPT_SCANDV_GOOD			(0x00000000) /* must be 0 */
 | 
						|
#define MPT_SCANDV_DID_RESET		(0x00000001)
 | 
						|
#define MPT_SCANDV_SENSE		(0x00000002)
 | 
						|
#define MPT_SCANDV_SOME_ERROR		(0x00000004)
 | 
						|
#define MPT_SCANDV_SELECTION_TIMEOUT	(0x00000008)
 | 
						|
#define MPT_SCANDV_ISSUE_SENSE		(0x00000010)
 | 
						|
#define MPT_SCANDV_FALLBACK		(0x00000020)
 | 
						|
#define MPT_SCANDV_BUSY			(0x00000040)
 | 
						|
 | 
						|
#define MPT_SCANDV_MAX_RETRIES		(10)
 | 
						|
 | 
						|
#define MPT_ICFLAG_BUF_CAP	0x01	/* ReadBuffer Read Capacity format */
 | 
						|
#define MPT_ICFLAG_ECHO		0x02	/* ReadBuffer Echo buffer format */
 | 
						|
#define MPT_ICFLAG_EBOS		0x04	/* ReadBuffer Echo buffer has EBOS */
 | 
						|
#define MPT_ICFLAG_PHYS_DISK	0x08	/* Any SCSI IO but do Phys Disk Format */
 | 
						|
#define MPT_ICFLAG_TAGGED_CMD	0x10	/* Do tagged IO */
 | 
						|
#define MPT_ICFLAG_DID_RESET	0x20	/* Bus Reset occurred with this command */
 | 
						|
#define MPT_ICFLAG_RESERVED	0x40	/* Reserved has been issued */
 | 
						|
 | 
						|
#define MPT_SCSI_CMD_PER_DEV_HIGH	64
 | 
						|
#define MPT_SCSI_CMD_PER_DEV_LOW	32
 | 
						|
 | 
						|
#define MPT_SCSI_CMD_PER_LUN		7
 | 
						|
 | 
						|
#define MPT_SCSI_MAX_SECTORS    8192
 | 
						|
 | 
						|
/* SCSI driver setup structure. Settings can be overridden
 | 
						|
 * by command line options.
 | 
						|
 */
 | 
						|
#define MPTSCSIH_DOMAIN_VALIDATION      1
 | 
						|
#define MPTSCSIH_MAX_WIDTH              1
 | 
						|
#define MPTSCSIH_MIN_SYNC               0x08
 | 
						|
#define MPTSCSIH_SAF_TE                 0
 | 
						|
#define MPTSCSIH_PT_CLEAR               0
 | 
						|
 | 
						|
#endif
 | 
						|
 | 
						|
 | 
						|
typedef struct _internal_cmd {
 | 
						|
	char		*data;		/* data pointer */
 | 
						|
	dma_addr_t	data_dma;	/* data dma address */
 | 
						|
	int		size;		/* transfer size */
 | 
						|
	u8		cmd;		/* SCSI Op Code */
 | 
						|
	u8		channel;	/* bus number */
 | 
						|
	u8		id;		/* SCSI ID (virtual) */
 | 
						|
	u64		lun;
 | 
						|
	u8		flags;		/* Bit Field - See above */
 | 
						|
	u8		physDiskNum;	/* Phys disk number, -1 else */
 | 
						|
	u8		rsvd2;
 | 
						|
	u8		rsvd;
 | 
						|
} INTERNAL_CMD;
 | 
						|
 | 
						|
extern void mptscsih_remove(struct pci_dev *);
 | 
						|
extern void mptscsih_shutdown(struct pci_dev *);
 | 
						|
#ifdef CONFIG_PM
 | 
						|
extern int mptscsih_suspend(struct pci_dev *pdev, pm_message_t state);
 | 
						|
extern int mptscsih_resume(struct pci_dev *pdev);
 | 
						|
#endif
 | 
						|
extern int mptscsih_show_info(struct seq_file *, struct Scsi_Host *);
 | 
						|
extern const char * mptscsih_info(struct Scsi_Host *SChost);
 | 
						|
extern int mptscsih_qcmd(struct scsi_cmnd *SCpnt);
 | 
						|
extern int mptscsih_IssueTaskMgmt(MPT_SCSI_HOST *hd, u8 type, u8 channel,
 | 
						|
	u8 id, u64 lun, int ctx2abort, ulong timeout);
 | 
						|
extern void mptscsih_slave_destroy(struct scsi_device *device);
 | 
						|
extern int mptscsih_slave_configure(struct scsi_device *device);
 | 
						|
extern int mptscsih_abort(struct scsi_cmnd * SCpnt);
 | 
						|
extern int mptscsih_dev_reset(struct scsi_cmnd * SCpnt);
 | 
						|
extern int mptscsih_bus_reset(struct scsi_cmnd * SCpnt);
 | 
						|
extern int mptscsih_host_reset(struct scsi_cmnd *SCpnt);
 | 
						|
extern int mptscsih_bios_param(struct scsi_device * sdev, struct block_device *bdev, sector_t capacity, int geom[]);
 | 
						|
extern int mptscsih_io_done(MPT_ADAPTER *ioc, MPT_FRAME_HDR *mf, MPT_FRAME_HDR *r);
 | 
						|
extern int mptscsih_taskmgmt_complete(MPT_ADAPTER *ioc, MPT_FRAME_HDR *mf, MPT_FRAME_HDR *r);
 | 
						|
extern int mptscsih_scandv_complete(MPT_ADAPTER *ioc, MPT_FRAME_HDR *mf, MPT_FRAME_HDR *r);
 | 
						|
extern int mptscsih_event_process(MPT_ADAPTER *ioc, EventNotificationReply_t *pEvReply);
 | 
						|
extern int mptscsih_ioc_reset(MPT_ADAPTER *ioc, int post_reset);
 | 
						|
extern int mptscsih_change_queue_depth(struct scsi_device *sdev, int qdepth,
 | 
						|
				       int reason);
 | 
						|
extern u8 mptscsih_raid_id_to_num(MPT_ADAPTER *ioc, u8 channel, u8 id);
 | 
						|
extern int mptscsih_is_phys_disk(MPT_ADAPTER *ioc, u8 channel, u8 id);
 | 
						|
extern struct device_attribute *mptscsih_host_attrs[];
 | 
						|
extern struct scsi_cmnd	*mptscsih_get_scsi_lookup(MPT_ADAPTER *ioc, int i);
 | 
						|
extern void mptscsih_taskmgmt_response_code(MPT_ADAPTER *ioc, u8 response_code);
 | 
						|
extern void mptscsih_flush_running_cmds(MPT_SCSI_HOST *hd);
 |