summaryrefslogtreecommitdiff
path: root/sys/dev/ic/isp_library.h
diff options
context:
space:
mode:
Diffstat (limited to 'sys/dev/ic/isp_library.h')
-rw-r--r--sys/dev/ic/isp_library.h215
1 files changed, 145 insertions, 70 deletions
diff --git a/sys/dev/ic/isp_library.h b/sys/dev/ic/isp_library.h
index 3b9ec400c87..a42dcd322ec 100644
--- a/sys/dev/ic/isp_library.h
+++ b/sys/dev/ic/isp_library.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: isp_library.h,v 1.1 2008/11/16 00:00:13 krw Exp $ */
+/* $OpenBSD: isp_library.h,v 1.2 2009/06/24 11:00:53 krw Exp $ */
/* $FreeBSD: src/sys/dev/isp/isp_library.h,v 1.8 2007/04/02 01:04:20 mjacob Exp $ */
/*-
* Copyright (c) 1997-2007 by Matthew Jacob
@@ -29,122 +29,197 @@
#ifndef _ISP_LIBRARY_H
#define _ISP_LIBRARY_H
-#include <dev/ic/isp_openbsd.h>
-
-extern int isp_save_xs(struct ispsoftc *, XS_T *, u_int16_t *);
-extern XS_T *isp_find_xs(struct ispsoftc *, u_int16_t);
-extern u_int16_t isp_find_handle(struct ispsoftc *, XS_T *);
-extern int isp_handle_index(u_int16_t);
-extern void isp_destroy_handle(struct ispsoftc *, u_int16_t);
-extern void isp_remove_handle(struct ispsoftc *, XS_T *);
-
-extern int
-isp_getrqentry(struct ispsoftc *, u_int16_t *, u_int16_t *, void **);
-
+extern int isp_save_xs(ispsoftc_t *, XS_T *, u_int32_t *);
+extern XS_T *isp_find_xs(ispsoftc_t *, u_int32_t);
+extern u_int32_t isp_find_handle(ispsoftc_t *, XS_T *);
+extern u_int32_t isp_handle_index(u_int32_t);
+extern void isp_destroy_handle(ispsoftc_t *, u_int32_t);
+extern int isp_getrqentry(ispsoftc_t *, u_int32_t *, u_int32_t *, void **);
+extern void isp_print_qentry (ispsoftc_t *, char *, int, void *);
+extern void isp_print_bytes(ispsoftc_t *, const char *, int, void *);
+extern int isp_fc_runstate(ispsoftc_t *, int);
+extern void isp_dump_portdb(ispsoftc_t *);
+extern void isp_shutdown(ispsoftc_t *);
+extern void isp_put_hdr(ispsoftc_t *, isphdr_t *, isphdr_t *);
+extern void isp_get_hdr(ispsoftc_t *, isphdr_t *, isphdr_t *);
+extern int isp_get_response_type(ispsoftc_t *, isphdr_t *);
extern void
-isp_print_qentry (struct ispsoftc *, char *, int, void *);
-
-
-#define TBA (4 * (((QENTRY_LEN >> 2) * 3) + 1) + 1)
-
+isp_put_request(ispsoftc_t *, ispreq_t *, ispreq_t *);
extern void
-isp_print_bytes(struct ispsoftc *, char *, int, void *);
-
-extern int isp_fc_runstate(struct ispsoftc *, int);
-
-extern void isp_copy_out_hdr(struct ispsoftc *, isphdr_t *, isphdr_t *);
-extern void isp_copy_in_hdr(struct ispsoftc *, isphdr_t *, isphdr_t *);
-extern int isp_get_response_type(struct ispsoftc *, isphdr_t *);
-
+isp_put_marker(ispsoftc_t *, isp_marker_t *, isp_marker_t *);
+extern void
+isp_put_marker_24xx(ispsoftc_t *, isp_marker_24xx_t *, isp_marker_24xx_t *);
+extern void
+isp_put_request_t2(ispsoftc_t *, ispreqt2_t *, ispreqt2_t *);
+extern void
+isp_put_request_t2e(ispsoftc_t *, ispreqt2e_t *, ispreqt2e_t *);
extern void
-isp_put_request(struct ispsoftc *, ispreq_t *, ispreq_t *);
+isp_put_request_t3(ispsoftc_t *, ispreqt3_t *, ispreqt3_t *);
extern void
-isp_put_request_t2(struct ispsoftc *, ispreqt2_t *, ispreqt2_t *);
+isp_put_request_t3e(ispsoftc_t *, ispreqt3e_t *, ispreqt3e_t *);
extern void
-isp_put_request_t3(struct ispsoftc *, ispreqt3_t *, ispreqt3_t *);
+isp_put_extended_request(ispsoftc_t *, ispextreq_t *, ispextreq_t *);
extern void
-isp_put_extended_request(struct ispsoftc *, ispextreq_t *, ispextreq_t *);
+isp_put_request_t7(ispsoftc_t *, ispreqt7_t *, ispreqt7_t *);
extern void
-isp_put_cont_req(struct ispsoftc *, ispcontreq_t *, ispcontreq_t *);
+isp_put_24xx_abrt(ispsoftc_t *, isp24xx_abrt_t *, isp24xx_abrt_t *);
extern void
-isp_put_cont64_req(struct ispsoftc *, ispcontreq64_t *, ispcontreq64_t *);
+isp_put_cont_req(ispsoftc_t *, ispcontreq_t *, ispcontreq_t *);
extern void
-isp_get_response(struct ispsoftc *, ispstatusreq_t *, ispstatusreq_t *);
+isp_put_cont64_req(ispsoftc_t *, ispcontreq64_t *, ispcontreq64_t *);
extern void
-isp_get_response_x(struct ispsoftc *, ispstatus_cont_t *, ispstatus_cont_t *);
+isp_get_response(ispsoftc_t *, ispstatusreq_t *, ispstatusreq_t *);
+extern 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 *);
extern void
-isp_get_rio2(struct ispsoftc *, isp_rio2_t *, isp_rio2_t *);
+isp_get_rio2(ispsoftc_t *, isp_rio2_t *, isp_rio2_t *);
extern void
-isp_put_icb(struct ispsoftc *, isp_icb_t *, isp_icb_t *);
+isp_put_icb(ispsoftc_t *, isp_icb_t *, isp_icb_t *);
extern void
-isp_get_pdb(struct ispsoftc *, isp_pdb_t *, isp_pdb_t *);
+isp_put_icb_2400(ispsoftc_t *, isp_icb_2400_t *, isp_icb_2400_t *);
extern void
-isp_get_ct_hdr(struct ispsoftc *isp, ct_hdr_t *, ct_hdr_t *);
+isp_get_pdb_21xx(ispsoftc_t *, isp_pdb_21xx_t *, isp_pdb_21xx_t *);
extern void
-isp_put_sns_request(struct ispsoftc *, sns_screq_t *, sns_screq_t *);
+isp_get_pdb_24xx(ispsoftc_t *, isp_pdb_24xx_t *, isp_pdb_24xx_t *);
extern void
-isp_put_gid_ft_request(struct ispsoftc *, sns_gid_ft_req_t *,
+isp_get_plogx(ispsoftc_t *, isp_plogx_t *, isp_plogx_t *);
+extern void
+isp_put_plogx(ispsoftc_t *, isp_plogx_t *, isp_plogx_t *);
+extern void
+isp_get_ct_pt(ispsoftc_t *isp, isp_ct_pt_t *, isp_ct_pt_t *);
+extern void
+isp_get_ms(ispsoftc_t *isp, isp_ms_t *, isp_ms_t *);
+extern void
+isp_put_ct_pt(ispsoftc_t *isp, isp_ct_pt_t *, isp_ct_pt_t *);
+extern void
+isp_put_ms(ispsoftc_t *isp, isp_ms_t *, isp_ms_t *);
+extern void
+isp_put_sns_request(ispsoftc_t *, sns_screq_t *, sns_screq_t *);
+extern void
+isp_put_gid_ft_request(ispsoftc_t *, sns_gid_ft_req_t *,
sns_gid_ft_req_t *);
extern void
-isp_put_gxn_id_request(struct ispsoftc *, sns_gxn_id_req_t *,
+isp_put_gxn_id_request(ispsoftc_t *, sns_gxn_id_req_t *,
sns_gxn_id_req_t *);
extern void
-isp_get_sns_response(struct ispsoftc *, sns_scrsp_t *, sns_scrsp_t *, int);
+isp_get_sns_response(ispsoftc_t *, sns_scrsp_t *, sns_scrsp_t *, int);
extern void
-isp_get_gid_ft_response(struct ispsoftc *, sns_gid_ft_rsp_t *,
+isp_get_gid_ft_response(ispsoftc_t *, sns_gid_ft_rsp_t *,
sns_gid_ft_rsp_t *, int);
extern void
-isp_get_gxn_id_response(struct ispsoftc *, sns_gxn_id_rsp_t *,
+isp_get_gxn_id_response(ispsoftc_t *, sns_gxn_id_rsp_t *,
sns_gxn_id_rsp_t *);
extern void
-isp_get_gff_id_response(struct ispsoftc *, sns_gff_id_rsp_t *,
+isp_get_gff_id_response(ispsoftc_t *, sns_gff_id_rsp_t *,
sns_gff_id_rsp_t *);
extern void
-isp_get_ga_nxt_response(struct ispsoftc *, sns_ga_nxt_rsp_t *,
+isp_get_ga_nxt_response(ispsoftc_t *, sns_ga_nxt_rsp_t *,
sns_ga_nxt_rsp_t *);
+extern void
+isp_get_els(ispsoftc_t *, els_t *, els_t *);
+extern void
+isp_put_els(ispsoftc_t *, els_t *, els_t *);
+extern void
+isp_get_fc_hdr(ispsoftc_t *, fc_hdr_t *, fc_hdr_t *);
+extern void
+isp_get_fcp_cmnd_iu(ispsoftc_t *, fcp_cmnd_iu_t *, fcp_cmnd_iu_t *);
+extern void isp_put_rft_id(ispsoftc_t *, rft_id_t *, rft_id_t *);
+extern void isp_get_ct_hdr(ispsoftc_t *isp, ct_hdr_t *, ct_hdr_t *);
+extern void isp_put_ct_hdr(ispsoftc_t *isp, ct_hdr_t *, ct_hdr_t *);
+
+#define ISP_HANDLE_MASK 0x7fff
+
#ifdef ISP_TARGET_MODE
-#ifndef _ISP_TARGET_H
+#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
+
+#define IS_TARGET_HANDLE(x) ((x) & 0x8000)
+
+extern int isp_save_xs_tgt(ispsoftc_t *, void *, u_int32_t *);
+extern void *isp_find_xs_tgt(ispsoftc_t *, u_int32_t);
+extern u_int32_t isp_find_tgt_handle(ispsoftc_t *, void *);
+extern void isp_destroy_tgt_handle(ispsoftc_t *, u_int32_t);
+
extern void
-isp_put_atio(struct ispsoftc *, at_entry_t *, at_entry_t *);
+isp_put_atio(ispsoftc_t *, at_entry_t *, at_entry_t *);
extern void
-isp_get_atio(struct ispsoftc *, at_entry_t *, at_entry_t *);
+isp_get_atio(ispsoftc_t *, at_entry_t *, at_entry_t *);
extern void
-isp_put_atio2(struct ispsoftc *, at2_entry_t *, at2_entry_t *);
+isp_put_atio2(ispsoftc_t *, at2_entry_t *, at2_entry_t *);
extern void
-isp_get_atio2(struct ispsoftc *, at2_entry_t *, at2_entry_t *);
+isp_put_atio2e(ispsoftc_t *, at2e_entry_t *, at2e_entry_t *);
extern void
-isp_put_ctio(struct ispsoftc *, ct_entry_t *, ct_entry_t *);
+isp_get_atio2(ispsoftc_t *, at2_entry_t *, at2_entry_t *);
extern void
-isp_get_ctio(struct ispsoftc *, ct_entry_t *, ct_entry_t *);
+isp_get_atio2e(ispsoftc_t *, at2e_entry_t *, at2e_entry_t *);
extern void
-isp_put_ctio2(struct ispsoftc *, ct2_entry_t *, ct2_entry_t *);
+isp_get_atio7(ispsoftc_t *isp, at7_entry_t *, at7_entry_t *);
extern void
-isp_get_ctio2(struct ispsoftc *, ct2_entry_t *, ct2_entry_t *);
+isp_put_ctio(ispsoftc_t *, ct_entry_t *, ct_entry_t *);
extern void
-isp_put_enable_lun(struct ispsoftc *, lun_entry_t *, lun_entry_t *);
+isp_get_ctio(ispsoftc_t *, ct_entry_t *, ct_entry_t *);
extern void
-isp_get_enable_lun(struct ispsoftc *, lun_entry_t *, lun_entry_t *);
+isp_put_ctio2(ispsoftc_t *, ct2_entry_t *, ct2_entry_t *);
extern void
-isp_put_notify(struct ispsoftc *, in_entry_t *, in_entry_t *);
+isp_put_ctio2e(ispsoftc_t *, ct2e_entry_t *, ct2e_entry_t *);
extern void
-isp_get_notify(struct ispsoftc *, in_entry_t *, in_entry_t *);
+isp_put_ctio7(ispsoftc_t *, ct7_entry_t *, ct7_entry_t *);
extern void
-isp_put_notify_fc(struct ispsoftc *, in_fcentry_t *, in_fcentry_t *);
+isp_get_ctio2(ispsoftc_t *, ct2_entry_t *, ct2_entry_t *);
extern void
-isp_get_notify_fc(struct ispsoftc *, in_fcentry_t *, in_fcentry_t *);
+isp_get_ctio2e(ispsoftc_t *, ct2e_entry_t *, ct2e_entry_t *);
extern void
-isp_put_notify_ack(struct ispsoftc *, na_entry_t *, na_entry_t *);
+isp_get_ctio7(ispsoftc_t *, ct7_entry_t *, ct7_entry_t *);
extern void
-isp_get_notify_ack(struct ispsoftc *, na_entry_t *, na_entry_t *);
+isp_put_enable_lun(ispsoftc_t *, lun_entry_t *, lun_entry_t *);
extern void
-isp_put_notify_ack_fc(struct ispsoftc *, na_fcentry_t *, na_fcentry_t *);
+isp_get_enable_lun(ispsoftc_t *, lun_entry_t *, lun_entry_t *);
extern void
-isp_get_notify_ack_fc(struct ispsoftc *, na_fcentry_t *, na_fcentry_t *);
-#endif
-
-#define ISP_IS_SBUS(isp) \
- (ISP_SBUS_SUPPORTED && (isp)->isp_bustype == ISP_BT_SBUS)
-
+isp_put_notify(ispsoftc_t *, in_entry_t *, in_entry_t *);
+extern void
+isp_get_notify(ispsoftc_t *, in_entry_t *, in_entry_t *);
+extern void
+isp_put_notify_fc(ispsoftc_t *, in_fcentry_t *, in_fcentry_t *);
+extern void
+isp_put_notify_fc_e(ispsoftc_t *, in_fcentry_e_t *, in_fcentry_e_t *);
+extern void
+isp_put_notify_24xx(ispsoftc_t *, in_fcentry_24xx_t *, in_fcentry_24xx_t *);
+extern void
+isp_get_notify_fc(ispsoftc_t *, in_fcentry_t *, in_fcentry_t *);
+extern void
+isp_get_notify_fc_e(ispsoftc_t *, in_fcentry_e_t *, in_fcentry_e_t *);
+extern void
+isp_get_notify_24xx(ispsoftc_t *, in_fcentry_24xx_t *, in_fcentry_24xx_t *);
+extern void
+isp_put_notify_ack(ispsoftc_t *, na_entry_t *, na_entry_t *);
+extern void
+isp_get_notify_ack(ispsoftc_t *, na_entry_t *, na_entry_t *);
+extern void
+isp_put_notify_24xx_ack(ispsoftc_t *, na_fcentry_24xx_t *, na_fcentry_24xx_t *);
+extern void
+isp_put_notify_ack_fc(ispsoftc_t *, na_fcentry_t *, na_fcentry_t *);
+extern void
+isp_put_notify_ack_fc_e(ispsoftc_t *, na_fcentry_e_t *, na_fcentry_e_t *);
+extern void isp_put_notify_ack_24xx(ispsoftc_t *, na_fcentry_24xx_t *,
+ na_fcentry_24xx_t *);
+extern void
+isp_get_notify_ack_fc(ispsoftc_t *, na_fcentry_t *, na_fcentry_t *);
+extern void
+isp_get_notify_ack_fc_e(ispsoftc_t *, na_fcentry_e_t *, na_fcentry_e_t *);
+extern void isp_get_notify_ack_24xx(ispsoftc_t *, na_fcentry_24xx_t *,
+ na_fcentry_24xx_t *);
+extern void
+isp_get_abts(ispsoftc_t *, abts_t *, abts_t *);
+extern void
+isp_put_abts_rsp(ispsoftc_t *, abts_rsp_t *, abts_rsp_t *);
+extern void
+isp_get_abts_rsp(ispsoftc_t *, abts_rsp_t *, abts_rsp_t *);
+#endif /* ISP_TARGET_MODE */
#endif /* _ISP_LIBRARY_H */