mirror of
https://github.com/SCST-project/scst.git
synced 2026-05-20 20:21:30 +00:00
svn+ssh://yanb123@svn.code.sf.net/p/scst/svn/branches/3.0.x
................
r5671 | bvassche | 2014-07-10 09:27:29 +0300 (Thu, 10 Jul 2014) | 1 line
scst: Create /var/lib/scst/pr and /var/lib/scst/vdev_mode_pages during installation (merge r5669 and r5670 from trunk)
................
r5687 | bvassche | 2014-07-20 08:59:31 +0300 (Sun, 20 Jul 2014) | 1 line
iscsi-scst: Handle data buffers with non-zero offset correctly (merge r5683 from trunk)
................
r5688 | bvassche | 2014-07-20 09:01:49 +0300 (Sun, 20 Jul 2014) | 1 line
Makefile: Only report which RPMs have been built if "make rpm" is run as a non-privileged user (merge r5560 from trunk)
................
r5689 | bvassche | 2014-07-20 09:03:55 +0300 (Sun, 20 Jul 2014) | 1 line
fcst: Remove an unused variable (merge r5605 from trunk)
................
r5690 | bvassche | 2014-07-20 09:04:43 +0300 (Sun, 20 Jul 2014) | 1 line
fcst: Move exch_done() calls into ft_cmd_done() (merge r5606 from trunk)
................
r5691 | bvassche | 2014-07-20 09:05:27 +0300 (Sun, 20 Jul 2014) | 1 line
fcst: Handle frame send failures properly (merge r5607 from trunk)
................
r5692 | bvassche | 2014-07-20 09:07:57 +0300 (Sun, 20 Jul 2014) | 1 line
qla2x00t: Documentation / source code comment / log messages spelling fix (merge r5555 from trunk)
................
r5693 | bvassche | 2014-07-20 09:46:28 +0300 (Sun, 20 Jul 2014) | 1 line
scst: Make lockdep_assert_held() easier to use (merge r5573 from trunk)
................
r5694 | bvassche | 2014-07-20 09:47:58 +0300 (Sun, 20 Jul 2014) | 1 line
scst: Leave out FSF mail address (merge r5572 from trunk)
................
r5695 | bvassche | 2014-07-20 09:52:12 +0300 (Sun, 20 Jul 2014) | 1 line
Change BUG_ON(1) into BUG() (merge r5618 from trunk)
................
r5696 | bvassche | 2014-07-20 09:54:00 +0300 (Sun, 20 Jul 2014) | 1 line
iscsi-scst: Suppress a compiler warning (merge r5614 from trunk)
................
r5697 | bvassche | 2014-07-20 10:03:04 +0300 (Sun, 20 Jul 2014) | 1 line
scst/include/scst.h: Define lockdep_assert_held() only once (follow-up for r5693)
................
r5723 | vlnb | 2014-08-21 08:21:55 +0300 (Thu, 21 Aug 2014) | 11 lines
Merged revisions 5721 via svnmerge from
svn+ssh://vlnb@svn.code.sf.net/p/scst/svn/trunk
........
r5721 | vlnb | 2014-08-20 22:17:47 -0700 (Wed, 20 Aug 2014) | 5 lines
Fix incorrect address computation during receive PDUs preparations
Found and fix suggested by Кирилл Тюшев <kirill.tyushev8@gmail.com>
........
................
git-svn-id: http://svn.code.sf.net/p/scst/svn/branches/3.0.x-iser@5739 d57e44dd-8a1f-0410-8b47-8ef2f437770f
239 lines
11 KiB
C
239 lines
11 KiB
C
/* $Id: isp_library.h,v 1.35 2009/05/10 16:25:09 mjacob Exp $ */
|
|
/*-
|
|
* Copyright (c) 1997-2009 by Matthew Jacob
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
*
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
* documentation and/or other materials provided with the distribution.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
* 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 OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
* SUCH DAMAGE.
|
|
*
|
|
*
|
|
* Alternatively, this software may be distributed under the terms of the
|
|
* the GNU Public License ("GPL") with platforms where the prevalant license
|
|
* is the GNU Public License:
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of The Version 2 GNU General Public License as published
|
|
* by the Free Software Foundation.
|
|
*
|
|
* 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.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program.
|
|
*
|
|
*
|
|
* Matthew Jacob
|
|
* Feral Software
|
|
* 421 Laurel Avenue
|
|
* Menlo Park, CA 94025
|
|
* USA
|
|
*
|
|
* gplbsd at feral com
|
|
*/
|
|
#ifndef _ISP_LIBRARY_H
|
|
#define _ISP_LIBRARY_H
|
|
|
|
/*
|
|
* Common command shipping routine.
|
|
*
|
|
* This used to be platform specific, but basically once you get the segment
|
|
* stuff figured out, you can make all the code in one spot.
|
|
*/
|
|
typedef enum { ISP_TO_DEVICE, ISP_FROM_DEVICE, ISP_NOXFR} isp_ddir_t;
|
|
int isp_send_cmd(ispsoftc_t *, void *, void *, uint32_t, uint32_t, isp_ddir_t);
|
|
|
|
/*
|
|
* Handle management functions.
|
|
*
|
|
* These handles are associate with a command.
|
|
*/
|
|
int isp_save_xs(ispsoftc_t *, XS_T *, uint32_t *);
|
|
XS_T * isp_find_xs(ispsoftc_t *, uint32_t);
|
|
uint32_t isp_find_handle(ispsoftc_t *, XS_T *);
|
|
uint32_t isp_handle_index(uint32_t);
|
|
void isp_destroy_handle(ispsoftc_t *, uint32_t);
|
|
|
|
/*
|
|
* Request Queue allocation
|
|
*/
|
|
void *isp_getrqentry(ispsoftc_t *);
|
|
|
|
/*
|
|
* Queue Entry debug functions
|
|
*/
|
|
void isp_print_qentry (ispsoftc_t *, const char *, int, void *);
|
|
void isp_print_bytes(ispsoftc_t *, const char *, int, void *);
|
|
|
|
/*
|
|
* Fibre Channel specific routines and data.
|
|
*/
|
|
extern const char *isp_class3_roles[4];
|
|
int isp_fc_runstate(ispsoftc_t *, int, int);
|
|
void isp_dump_portdb(ispsoftc_t *, int);
|
|
|
|
const char *isp_fc_fw_statename(int);
|
|
const char *isp_fc_loop_statename(int);
|
|
const char *isp_fc_toponame(fcparam *);
|
|
|
|
int isp_fc_change_role(ispsoftc_t *, int, int);
|
|
|
|
|
|
/*
|
|
* Cleanup
|
|
*/
|
|
void isp_clear_commands(ispsoftc_t *);
|
|
|
|
/*
|
|
* Common chip shutdown function
|
|
*/
|
|
void isp_shutdown(ispsoftc_t *);
|
|
|
|
/*
|
|
* Put/Get routines to push from CPU view to device view
|
|
* or to pull from device view to CPU view for various
|
|
* data structures (IOCB)
|
|
*/
|
|
void isp_put_hdr(ispsoftc_t *, isphdr_t *, isphdr_t *);
|
|
void isp_get_hdr(ispsoftc_t *, isphdr_t *, isphdr_t *);
|
|
int isp_get_response_type(ispsoftc_t *, isphdr_t *);
|
|
void isp_put_request(ispsoftc_t *, ispreq_t *, ispreq_t *);
|
|
void isp_put_marker(ispsoftc_t *, isp_marker_t *, isp_marker_t *);
|
|
void isp_put_marker_24xx(ispsoftc_t *, isp_marker_24xx_t *, isp_marker_24xx_t *);
|
|
void isp_put_request_t2(ispsoftc_t *, ispreqt2_t *, ispreqt2_t *);
|
|
void isp_put_request_t2e(ispsoftc_t *, ispreqt2e_t *, ispreqt2e_t *);
|
|
void isp_put_request_t3(ispsoftc_t *, ispreqt3_t *, ispreqt3_t *);
|
|
void isp_put_request_t3e(ispsoftc_t *, ispreqt3e_t *, ispreqt3e_t *);
|
|
void isp_put_extended_request(ispsoftc_t *, ispextreq_t *, ispextreq_t *);
|
|
void isp_put_request_t7(ispsoftc_t *, ispreqt7_t *, ispreqt7_t *);
|
|
void isp_put_24xx_tmf(ispsoftc_t *, isp24xx_tmf_t *, isp24xx_tmf_t *);
|
|
void isp_put_24xx_abrt(ispsoftc_t *, isp24xx_abrt_t *, isp24xx_abrt_t *);
|
|
void isp_put_cont_req(ispsoftc_t *, ispcontreq_t *, ispcontreq_t *);
|
|
void isp_put_cont64_req(ispsoftc_t *, ispcontreq64_t *, ispcontreq64_t *);
|
|
void isp_get_response(ispsoftc_t *, ispstatusreq_t *, ispstatusreq_t *);
|
|
void isp_get_24xx_response(ispsoftc_t *, isp24xx_statusreq_t *, isp24xx_statusreq_t *);
|
|
void isp_get_24xx_abrt(ispsoftc_t *, isp24xx_abrt_t *, isp24xx_abrt_t *);
|
|
void isp_get_rio2(ispsoftc_t *, isp_rio2_t *, isp_rio2_t *);
|
|
void isp_put_icb(ispsoftc_t *, isp_icb_t *, isp_icb_t *);
|
|
void isp_put_icb_2400(ispsoftc_t *, isp_icb_2400_t *, isp_icb_2400_t *);
|
|
void isp_put_icb_2400_vpinfo(ispsoftc_t *, isp_icb_2400_vpinfo_t *, isp_icb_2400_vpinfo_t *);
|
|
void isp_put_vp_port_info(ispsoftc_t *, vp_port_info_t *, vp_port_info_t *);
|
|
void isp_get_vp_port_info(ispsoftc_t *, vp_port_info_t *, vp_port_info_t *);
|
|
void isp_put_vp_ctrl_info(ispsoftc_t *, vp_ctrl_info_t *, vp_ctrl_info_t *);
|
|
void isp_get_vp_ctrl_info(ispsoftc_t *, vp_ctrl_info_t *, vp_ctrl_info_t *);
|
|
void isp_put_vp_modify(ispsoftc_t *, vp_modify_t *, vp_modify_t *);
|
|
void isp_get_vp_modify(ispsoftc_t *, vp_modify_t *, vp_modify_t *);
|
|
void isp_get_pdb_21xx(ispsoftc_t *, isp_pdb_21xx_t *, isp_pdb_21xx_t *);
|
|
void isp_get_pdb_24xx(ispsoftc_t *, isp_pdb_24xx_t *, isp_pdb_24xx_t *);
|
|
void isp_get_ridacq(ispsoftc_t *, isp_ridacq_t *, isp_ridacq_t *);
|
|
void isp_get_plogx(ispsoftc_t *, isp_plogx_t *, isp_plogx_t *);
|
|
void isp_put_plogx(ispsoftc_t *, isp_plogx_t *, isp_plogx_t *);
|
|
void isp_get_ct_pt(ispsoftc_t *isp, isp_ct_pt_t *, isp_ct_pt_t *);
|
|
void isp_get_ms(ispsoftc_t *isp, isp_ms_t *, isp_ms_t *);
|
|
void isp_put_ct_pt(ispsoftc_t *isp, isp_ct_pt_t *, isp_ct_pt_t *);
|
|
void isp_put_ms(ispsoftc_t *isp, isp_ms_t *, isp_ms_t *);
|
|
void isp_put_sns_request(ispsoftc_t *, sns_screq_t *, sns_screq_t *);
|
|
void isp_put_gid_ft_request(ispsoftc_t *, sns_gid_ft_req_t *, sns_gid_ft_req_t *);
|
|
void isp_put_gxn_id_request(ispsoftc_t *, sns_gxn_id_req_t *, sns_gxn_id_req_t *);
|
|
void isp_get_sns_response(ispsoftc_t *, sns_scrsp_t *, sns_scrsp_t *, int);
|
|
void isp_get_gid_ft_response(ispsoftc_t *, sns_gid_ft_rsp_t *, sns_gid_ft_rsp_t *, int);
|
|
void isp_get_gxn_id_response(ispsoftc_t *, sns_gxn_id_rsp_t *, sns_gxn_id_rsp_t *);
|
|
void isp_get_gff_id_response(ispsoftc_t *, sns_gff_id_rsp_t *, sns_gff_id_rsp_t *);
|
|
void isp_get_ga_nxt_response(ispsoftc_t *, sns_ga_nxt_rsp_t *, sns_ga_nxt_rsp_t *);
|
|
void isp_get_els(ispsoftc_t *, els_t *, els_t *);
|
|
void isp_put_els(ispsoftc_t *, els_t *, els_t *);
|
|
void isp_get_fc_hdr(ispsoftc_t *, fc_hdr_t *, fc_hdr_t *);
|
|
void isp_get_fcp_cmnd_iu(ispsoftc_t *, fcp_cmnd_iu_t *, fcp_cmnd_iu_t *);
|
|
void isp_put_rft_id(ispsoftc_t *, rft_id_t *, rft_id_t *);
|
|
void isp_get_ct_hdr(ispsoftc_t *isp, ct_hdr_t *, ct_hdr_t *);
|
|
void isp_put_ct_hdr(ispsoftc_t *isp, ct_hdr_t *, ct_hdr_t *);
|
|
|
|
#define ISP_HANDLE_MASK 0x7fff
|
|
|
|
#ifdef ISP_TARGET_MODE
|
|
#if defined(__NetBSD__) || defined(__OpenBSD__)
|
|
#include <dev/ic/isp_target.h>
|
|
#elif defined(__FreeBSD__)
|
|
#include <dev/isp/isp_target.h>
|
|
#else
|
|
#include "isp_target.h"
|
|
#endif
|
|
|
|
int isp_send_tgt_cmd(ispsoftc_t *, void *, void *, uint32_t, uint32_t, isp_ddir_t, void *, uint32_t);
|
|
|
|
#define IS_TARGET_HANDLE(x) ((x) & 0x8000)
|
|
|
|
int isp_save_xs_tgt(ispsoftc_t *, void *, uint32_t *);
|
|
void *isp_find_xs_tgt(ispsoftc_t *, uint32_t);
|
|
uint32_t isp_find_tgt_handle(ispsoftc_t *, void *);
|
|
void isp_destroy_tgt_handle(ispsoftc_t *, uint32_t);
|
|
|
|
int isp_find_pdb_by_wwn(ispsoftc_t *, int, uint64_t, fcportdb_t **);
|
|
int isp_find_pdb_by_loopid(ispsoftc_t *, int, uint32_t, fcportdb_t **);
|
|
int isp_find_pdb_by_sid(ispsoftc_t *, int, uint32_t, fcportdb_t **);
|
|
void isp_find_chan_by_did(ispsoftc_t *, uint32_t, uint16_t *);
|
|
void isp_add_wwn_entry(ispsoftc_t *, int, uint64_t, uint16_t, uint32_t);
|
|
void isp_del_wwn_entry(ispsoftc_t *, int, uint64_t, uint16_t, uint32_t);
|
|
void isp_del_all_wwn_entries(ispsoftc_t *, int);
|
|
void isp_del_wwn_entries(ispsoftc_t *, isp_notify_t *);
|
|
|
|
void isp_put_atio(ispsoftc_t *, at_entry_t *, at_entry_t *);
|
|
void isp_get_atio(ispsoftc_t *, at_entry_t *, at_entry_t *);
|
|
void isp_put_atio2(ispsoftc_t *, at2_entry_t *, at2_entry_t *);
|
|
void isp_put_atio2e(ispsoftc_t *, at2e_entry_t *, at2e_entry_t *);
|
|
void isp_get_atio2(ispsoftc_t *, at2_entry_t *, at2_entry_t *);
|
|
void isp_get_atio2e(ispsoftc_t *, at2e_entry_t *, at2e_entry_t *);
|
|
void isp_get_atio7(ispsoftc_t *isp, at7_entry_t *, at7_entry_t *);
|
|
void isp_put_ctio(ispsoftc_t *, ct_entry_t *, ct_entry_t *);
|
|
void isp_get_ctio(ispsoftc_t *, ct_entry_t *, ct_entry_t *);
|
|
void isp_put_ctio2(ispsoftc_t *, ct2_entry_t *, ct2_entry_t *);
|
|
void isp_put_ctio2e(ispsoftc_t *, ct2e_entry_t *, ct2e_entry_t *);
|
|
void isp_put_ctio7(ispsoftc_t *, ct7_entry_t *, ct7_entry_t *);
|
|
void isp_get_ctio2(ispsoftc_t *, ct2_entry_t *, ct2_entry_t *);
|
|
void isp_get_ctio2e(ispsoftc_t *, ct2e_entry_t *, ct2e_entry_t *);
|
|
void isp_get_ctio7(ispsoftc_t *, ct7_entry_t *, ct7_entry_t *);
|
|
void isp_put_enable_lun(ispsoftc_t *, lun_entry_t *, lun_entry_t *);
|
|
void isp_get_enable_lun(ispsoftc_t *, lun_entry_t *, lun_entry_t *);
|
|
void isp_put_notify(ispsoftc_t *, in_entry_t *, in_entry_t *);
|
|
void isp_get_notify(ispsoftc_t *, in_entry_t *, in_entry_t *);
|
|
void isp_put_notify_fc(ispsoftc_t *, in_fcentry_t *, in_fcentry_t *);
|
|
void isp_put_notify_fc_e(ispsoftc_t *, in_fcentry_e_t *, in_fcentry_e_t *);
|
|
void isp_put_notify_24xx(ispsoftc_t *, in_fcentry_24xx_t *, in_fcentry_24xx_t *);
|
|
void isp_get_notify_fc(ispsoftc_t *, in_fcentry_t *, in_fcentry_t *);
|
|
void isp_get_notify_fc_e(ispsoftc_t *, in_fcentry_e_t *, in_fcentry_e_t *);
|
|
void isp_get_notify_24xx(ispsoftc_t *, in_fcentry_24xx_t *, in_fcentry_24xx_t *);
|
|
void isp_put_notify_ack(ispsoftc_t *, na_entry_t *, na_entry_t *);
|
|
void isp_get_notify_ack(ispsoftc_t *, na_entry_t *, na_entry_t *);
|
|
void isp_put_notify_24xx_ack(ispsoftc_t *, na_fcentry_24xx_t *, na_fcentry_24xx_t *);
|
|
void isp_put_notify_ack_fc(ispsoftc_t *, na_fcentry_t *, na_fcentry_t *);
|
|
void isp_put_notify_ack_fc_e(ispsoftc_t *, na_fcentry_e_t *, na_fcentry_e_t *);
|
|
void isp_put_notify_ack_24xx(ispsoftc_t *, na_fcentry_24xx_t *, na_fcentry_24xx_t *);
|
|
void isp_get_notify_ack_fc(ispsoftc_t *, na_fcentry_t *, na_fcentry_t *);
|
|
void isp_get_notify_ack_fc_e(ispsoftc_t *, na_fcentry_e_t *, na_fcentry_e_t *);
|
|
void isp_get_notify_ack_24xx(ispsoftc_t *, na_fcentry_24xx_t *, na_fcentry_24xx_t *);
|
|
void isp_get_abts(ispsoftc_t *, abts_t *, abts_t *);
|
|
void isp_put_abts_rsp(ispsoftc_t *, abts_rsp_t *, abts_rsp_t *);
|
|
void isp_get_abts_rsp(ispsoftc_t *, abts_rsp_t *, abts_rsp_t *);
|
|
#endif /* ISP_TARGET_MODE */
|
|
#endif /* _ISP_LIBRARY_H */
|