summaryrefslogtreecommitdiff
path: root/sys/dev/ic/aic7xxx.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/dev/ic/aic7xxx.c')
-rw-r--r--sys/dev/ic/aic7xxx.c287
1 files changed, 133 insertions, 154 deletions
diff --git a/sys/dev/ic/aic7xxx.c b/sys/dev/ic/aic7xxx.c
index e5e0f8b171d..0b07c254e17 100644
--- a/sys/dev/ic/aic7xxx.c
+++ b/sys/dev/ic/aic7xxx.c
@@ -33,7 +33,7 @@
* SUCH DAMAGE.
*
* $FreeBSD: src/sys/dev/aic7xxx/aic7xxx.c,v 1.40 2000/01/07 23:08:17 gibbs Exp $
- * $OpenBSD: aic7xxx.c,v 1.36 2002/03/19 02:49:20 millert Exp $
+ * $OpenBSD: aic7xxx.c,v 1.37 2002/03/19 21:07:25 millert Exp $
*/
/*
* A few notes on features of the driver.
@@ -211,43 +211,38 @@ void ahc_pci_intr(struct ahc_softc *ahc);
STATIC int ahcinitscbdata(struct ahc_softc *ahc);
STATIC void ahcfiniscbdata(struct ahc_softc *ahc);
-STATIC int ahc_poll __P((struct ahc_softc *ahc, int wait));
-STATIC void ahc_shutdown __P((void *arg));
-STATIC int ahc_execute_scb __P((void *arg, bus_dma_segment_t *dm_segs,
- int nsegments));
-STATIC int ahc_setup_data __P((struct ahc_softc *ahc,
- struct scsi_xfer *xs, struct scb *scb));
-STATIC void ahc_freeze_devq __P((struct ahc_softc *ahc,
- struct scsi_link *sc_link));
-STATIC void ahcallocscbs __P((struct ahc_softc *ahc));
-STATIC void ahc_fetch_devinfo __P((struct ahc_softc *ahc,
- struct ahc_devinfo *devinfo));
-STATIC void ahc_compile_devinfo __P((struct ahc_devinfo *devinfo,
- u_int our_id, u_int target,
- u_int lun, char channel,
- role_t role));
-STATIC u_int ahc_abort_wscb __P((struct ahc_softc *ahc,
- u_int scbpos, u_int prev));
-STATIC void ahc_done __P((struct ahc_softc *ahc, struct scb *scbp));
+STATIC int ahc_poll(struct ahc_softc *ahc, int wait);
+STATIC void ahc_shutdown(void *arg);
+STATIC int ahc_execute_scb(void *arg, bus_dma_segment_t *dm_segs,
+ int nsegments);
+STATIC int ahc_setup_data(struct ahc_softc *ahc, struct scsi_xfer *xs,
+ struct scb *scb);
+STATIC void ahc_freeze_devq(struct ahc_softc *ahc,
+ struct scsi_link *sc_link);
+STATIC void ahcallocscbs(struct ahc_softc *ahc);
+STATIC void ahc_fetch_devinfo(struct ahc_softc *ahc,
+ struct ahc_devinfo *devinfo);
+STATIC void ahc_compile_devinfo(struct ahc_devinfo *devinfo, u_int our_id,
+ u_int target, u_int lun, char channel, role_t role);
+STATIC u_int ahc_abort_wscb(struct ahc_softc *ahc, u_int scbpos, u_int prev);
+STATIC void ahc_done(struct ahc_softc *ahc, struct scb *scbp);
STATIC struct tmode_tstate *
- ahc_alloc_tstate __P((struct ahc_softc *ahc, u_int scsi_id,
- char channel));
-STATIC void ahc_handle_seqint __P((struct ahc_softc *ahc, u_int intstat));
-STATIC void ahc_handle_scsiint __P((struct ahc_softc *ahc, u_int intstat));
-STATIC void ahc_build_transfer_msg __P((struct ahc_softc *ahc,
- struct ahc_devinfo *devinfo));
-STATIC void ahc_setup_initiator_msgout __P((struct ahc_softc *ahc,
- struct ahc_devinfo *devinfo,
- struct scb *scb));
-STATIC void ahc_setup_target_msgin __P((struct ahc_softc *ahc,
- struct ahc_devinfo *devinfo));
-STATIC int ahc_handle_msg_reject __P((struct ahc_softc *ahc,
- struct ahc_devinfo *devinfo));
-STATIC void ahc_clear_msg_state __P((struct ahc_softc *ahc));
-STATIC void ahc_handle_message_phase __P((struct ahc_softc *ahc,
- struct scsi_link *sc_link));
-STATIC int ahc_sent_msg __P((struct ahc_softc *ahc, u_int msgtype,
- int full));
+ ahc_alloc_tstate(struct ahc_softc *ahc, u_int scsi_id,
+ char channel);
+STATIC void ahc_handle_seqint(struct ahc_softc *ahc, u_int intstat);
+STATIC void ahc_handle_scsiint(struct ahc_softc *ahc, u_int intstat);
+STATIC void ahc_build_transfer_msg(struct ahc_softc *ahc,
+ struct ahc_devinfo *devinfo);
+STATIC void ahc_setup_initiator_msgout(struct ahc_softc *ahc,
+ struct ahc_devinfo *devinfo, struct scb *scb);
+STATIC void ahc_setup_target_msgin(struct ahc_softc *ahc,
+ struct ahc_devinfo *devinfo);
+STATIC int ahc_handle_msg_reject(struct ahc_softc *ahc,
+ struct ahc_devinfo *devinfo);
+STATIC void ahc_clear_msg_state(struct ahc_softc *ahc);
+STATIC void ahc_handle_message_phase(struct ahc_softc *ahc,
+ struct scsi_link *sc_link);
+STATIC int ahc_sent_msg(struct ahc_softc *ahc, u_int msgtype, int full);
typedef enum {
MSGLOOP_IN_PROG,
@@ -255,133 +250,117 @@ typedef enum {
MSGLOOP_TERMINATED
} msg_loop_stat;
-STATIC int ahc_parse_msg __P((struct ahc_softc *ahc,
- struct scsi_link *sc_link,
- struct ahc_devinfo *devinfo));
-STATIC void ahc_handle_ign_wide_residue __P((struct ahc_softc *ahc,
- struct ahc_devinfo *devinfo));
-STATIC void ahc_handle_devreset __P((struct ahc_softc *ahc,
- struct ahc_devinfo *devinfo,
- int status, char *message,
- int verbose_level));
+STATIC int ahc_parse_msg(struct ahc_softc *ahc, struct scsi_link *sc_link,
+ struct ahc_devinfo *devinfo);
+STATIC void ahc_handle_ign_wide_residue(struct ahc_softc *ahc,
+ struct ahc_devinfo *devinfo);
+STATIC void ahc_handle_devreset(struct ahc_softc *ahc,
+ struct ahc_devinfo *devinfo, int status, char *message,
+ int verbose_level);
#ifdef AHC_DUMP_SEQ
-STATIC void ahc_dumpseq __P((struct ahc_softc *ahc));
+STATIC void ahc_dumpseq(struct ahc_softc *ahc);
#endif
-STATIC void ahc_loadseq __P((struct ahc_softc *ahc));
-STATIC int ahc_check_patch __P((struct ahc_softc *ahc,
- struct patch **start_patch,
- int start_instr, int *skip_addr));
-STATIC void ahc_download_instr __P((struct ahc_softc *ahc,
- int instrptr, u_int8_t *dconsts));
-STATIC int ahc_match_scb __P((struct scb *scb, int target, char channel,
- int lun, u_int tag, role_t role));
+STATIC void ahc_loadseq(struct ahc_softc *ahc);
+STATIC int ahc_check_patch(struct ahc_softc *ahc,
+ struct patch **start_patch, int start_instr,
+ int *skip_addr);
+STATIC void ahc_download_instr(struct ahc_softc *ahc, int instrptr,
+ u_int8_t *dconsts);
+STATIC int ahc_match_scb(struct scb *scb, int target, char channel,
+ int lun, u_int tag, role_t role);
#ifdef AHC_DEBUG
-STATIC void ahc_print_scb __P((struct scb *scb));
+STATIC void ahc_print_scb(struct scb *scb);
#endif
-STATIC int ahc_search_qinfifo __P((struct ahc_softc *ahc, int target,
- char channel, int lun, u_int tag,
- role_t role, u_int32_t status,
- ahc_search_action action));
-STATIC int ahc_reset_channel __P((struct ahc_softc *ahc, char channel,
- int initiate_reset));
-STATIC int ahc_abort_scbs __P((struct ahc_softc *ahc, int target,
- char channel, int lun, u_int tag,
- role_t role, u_int32_t status));
-STATIC int ahc_search_disc_list __P((struct ahc_softc *ahc, int target,
- char channel, int lun, u_int tag,
- int stop_on_first, int remove,
- int save_state));
-STATIC u_int ahc_rem_scb_from_disc_list __P((struct ahc_softc *ahc,
- u_int prev, u_int scbptr));
-STATIC void ahc_add_curscb_to_free_list __P((struct ahc_softc *ahc));
-STATIC void ahc_clear_intstat __P((struct ahc_softc *ahc));
-STATIC void ahc_reset_current_bus __P((struct ahc_softc *ahc));
+STATIC int ahc_search_qinfifo(struct ahc_softc *ahc, int target,
+ char channel, int lun, u_int tag, role_t role,
+ u_int32_t status, ahc_search_action action);
+STATIC int ahc_reset_channel(struct ahc_softc *ahc, char channel,
+ int initiate_reset);
+STATIC int ahc_abort_scbs(struct ahc_softc *ahc, int target, char channel,
+ int lun, u_int tag, role_t role, u_int32_t status);
+STATIC int ahc_search_disc_list(struct ahc_softc *ahc, int target,
+ char channel, int lun, u_int tag, int stop_on_first,
+ int remove, int save_state);
+STATIC u_int ahc_rem_scb_from_disc_list(struct ahc_softc *ahc, u_int prev,
+ u_int scbptr);
+STATIC void ahc_add_curscb_to_free_list(struct ahc_softc *ahc);
+STATIC void ahc_clear_intstat(struct ahc_softc *ahc);
+STATIC void ahc_reset_current_bus(struct ahc_softc *ahc);
STATIC struct ahc_syncrate *
- ahc_devlimited_syncrate __P((struct ahc_softc *ahc, u_int *period));
+ ahc_devlimited_syncrate(struct ahc_softc *ahc, u_int *period);
STATIC struct ahc_syncrate *
- ahc_find_syncrate __P((struct ahc_softc *ahc, u_int *period,
- u_int maxsync));
-STATIC u_int ahc_find_period __P((struct ahc_softc *ahc, u_int scsirate,
- u_int maxsync));
-STATIC void ahc_validate_offset __P((struct ahc_softc *ahc,
+ ahc_find_syncrate(struct ahc_softc *ahc, u_int *period,
+ u_int maxsync);
+STATIC u_int ahc_find_period(struct ahc_softc *ahc, u_int scsirate,
+ u_int maxsync);
+STATIC void ahc_validate_offset(struct ahc_softc *ahc,
struct ahc_syncrate *syncrate,
- u_int *offset, int wide));
-STATIC void ahc_update_target_msg_request __P((struct ahc_softc *ahc,
- struct ahc_devinfo *devinfo,
- struct ahc_initiator_tinfo *tinfo,
- int force, int paused));
-STATIC void ahc_set_syncrate __P((struct ahc_softc *ahc,
- struct ahc_devinfo *devinfo,
- struct ahc_syncrate *syncrate,
- u_int period, u_int offset,
- u_int type, int paused, int done));
-STATIC void ahc_set_width __P((struct ahc_softc *ahc,
- struct ahc_devinfo *devinfo,
- u_int width, u_int type, int paused, int done));
-STATIC void ahc_set_tags __P((struct ahc_softc *ahc,
- struct ahc_devinfo *devinfo,int enable));
-STATIC int ahc_istagged_device __P((struct ahc_softc *ahc,
- struct scsi_xfer *xs,
- int nocmdcheck));
-STATIC void ahc_check_tags __P((struct ahc_softc *ahc,
- struct scsi_xfer *xs));
-STATIC void ahc_construct_sdtr __P((struct ahc_softc *ahc,
- u_int period, u_int offset));
-STATIC void ahc_construct_wdtr __P((struct ahc_softc *ahc, u_int bus_width));
-
-STATIC void ahc_calc_residual __P((struct scb *scb));
-
-STATIC void ahc_update_pending_syncrates __P((struct ahc_softc *ahc));
-
-STATIC void ahc_set_recoveryscb __P((struct ahc_softc *ahc,
- struct scb *scb));
-STATIC void ahc_timeout __P((void *));
-
-static __inline int sequencer_paused __P((struct ahc_softc *ahc));
-static __inline void pause_sequencer __P((struct ahc_softc *ahc));
-static __inline void unpause_sequencer __P((struct ahc_softc *ahc));
-STATIC void restart_sequencer __P((struct ahc_softc *ahc));
-static __inline u_int ahc_index_busy_tcl __P((struct ahc_softc *ahc,
- u_int tcl, int unbusy));
+ u_int *offset, int wide);
+STATIC void ahc_update_target_msg_request(struct ahc_softc *ahc,
+ struct ahc_devinfo *devinfo,
+ struct ahc_initiator_tinfo *tinfo, int force, int paused);
+STATIC void ahc_set_syncrate(struct ahc_softc *ahc,
+ struct ahc_devinfo *devinfo, struct ahc_syncrate *syncrate,
+ u_int period, u_int offset, u_int type, int paused,
+ int done);
+STATIC void ahc_set_width(struct ahc_softc *ahc,
+ struct ahc_devinfo *devinfo, u_int width, u_int type,
+ int paused, int done);
+STATIC void ahc_set_tags(struct ahc_softc *ahc,
+ struct ahc_devinfo *devinfo,int enable);
+STATIC int ahc_istagged_device(struct ahc_softc *ahc,
+ struct scsi_xfer *xs, int nocmdcheck);
+STATIC void ahc_check_tags(struct ahc_softc *ahc, struct scsi_xfer *xs);
+STATIC void ahc_construct_sdtr(struct ahc_softc *ahc, u_int period,
+ u_int offset);
+STATIC void ahc_construct_wdtr(struct ahc_softc *ahc, u_int bus_width);
+
+STATIC void ahc_calc_residual(struct scb *scb);
+
+STATIC void ahc_update_pending_syncrates(struct ahc_softc *ahc);
+
+STATIC void ahc_set_recoveryscb(struct ahc_softc *ahc, struct scb *scb);
+STATIC void ahc_timeout(void *);
+
+static __inline int sequencer_paused(struct ahc_softc *ahc);
+static __inline void pause_sequencer(struct ahc_softc *ahc);
+static __inline void unpause_sequencer(struct ahc_softc *ahc);
+STATIC void restart_sequencer(struct ahc_softc *ahc);
+static __inline u_int ahc_index_busy_tcl(struct ahc_softc *ahc, u_int tcl,
+ int unbusy);
-static __inline void ahc_busy_tcl __P((struct ahc_softc *ahc,
- struct scb *scb));
-static __inline int ahc_isbusy_tcl __P((struct ahc_softc *ahc,
- struct scb *scb));
-static __inline void ahc_freeze_ccb __P((struct scb* scb));
-static __inline void ahcsetccbstatus __P((struct scsi_xfer *xs, int status));
-STATIC void ahc_run_qoutfifo __P((struct ahc_softc *ahc));
+static __inline void ahc_busy_tcl(struct ahc_softc *ahc, struct scb *scb);
+static __inline int ahc_isbusy_tcl(struct ahc_softc *ahc, struct scb *scb);
+static __inline void ahc_freeze_ccb(struct scb* scb);
+static __inline void ahcsetccbstatus(struct scsi_xfer *xs, int status);
+STATIC void ahc_run_qoutfifo(struct ahc_softc *ahc);
static __inline struct ahc_initiator_tinfo *
- ahc_fetch_transinfo __P((struct ahc_softc *ahc, char channel,
- u_int our_id, u_int target,
- struct tmode_tstate **tstate));
-STATIC void ahcfreescb __P((struct ahc_softc *ahc, struct scb *scb));
-static __inline struct scb *ahcgetscb __P((struct ahc_softc *ahc));
-int ahc_createdmamem __P((struct ahc_softc *ahc, int size,
- bus_dmamap_t *mapp, caddr_t *vaddr,
- bus_addr_t *baddr, bus_dma_segment_t *segs,
- int *nseg, const char *what));
-STATIC void ahc_freedmamem __P((bus_dma_tag_t tag, int size,
- bus_dmamap_t map, caddr_t vaddr,
- bus_dma_segment_t *seg, int nseg));
-STATIC void ahcminphys __P((struct buf *bp));
-
-STATIC INLINE struct scsi_xfer *ahc_first_xs __P((struct ahc_softc *));
-STATIC INLINE void ahc_list_insert_before __P((struct ahc_softc *ahc,
- struct scsi_xfer *xs,
- struct scsi_xfer *next_xs));
-STATIC INLINE void ahc_list_insert_head __P((struct ahc_softc *ahc,
- struct scsi_xfer *xs));
-STATIC INLINE void ahc_list_insert_tail __P((struct ahc_softc *ahc,
- struct scsi_xfer *xs));
-STATIC INLINE void ahc_list_remove __P((struct ahc_softc *ahc,
- struct scsi_xfer *xs));
-STATIC INLINE struct scsi_xfer *ahc_list_next __P((struct ahc_softc *ahc,
- struct scsi_xfer *xs));
-STATIC int32_t ahc_scsi_cmd __P((struct scsi_xfer *xs));
-static __inline void ahc_swap_hscb __P((struct hardware_scb *));
-static __inline void ahc_swap_sg __P((struct ahc_dma_seg *));
+ ahc_fetch_transinfo(struct ahc_softc *ahc, char channel, u_int our_id,
+ u_int target, struct tmode_tstate **tstate);
+STATIC void ahcfreescb(struct ahc_softc *ahc, struct scb *scb);
+static __inline struct scb *ahcgetscb(struct ahc_softc *ahc);
+int ahc_createdmamem(struct ahc_softc *ahc, int size, bus_dmamap_t *mapp,
+ caddr_t *vaddr, bus_addr_t *baddr, bus_dma_segment_t *segs,
+ int *nseg, const char *what);
+STATIC void ahc_freedmamem(bus_dma_tag_t tag, int size, bus_dmamap_t map,
+ caddr_t vaddr, bus_dma_segment_t *seg, int nseg);
+STATIC void ahcminphys(struct buf *bp);
+
+STATIC INLINE struct scsi_xfer *ahc_first_xs(struct ahc_softc *);
+STATIC INLINE void ahc_list_insert_before(struct ahc_softc *ahc,
+ struct scsi_xfer *xs, struct scsi_xfer *next_xs);
+STATIC INLINE void ahc_list_insert_head(struct ahc_softc *ahc,
+ struct scsi_xfer *xs);
+STATIC INLINE void ahc_list_insert_tail(struct ahc_softc *ahc,
+ struct scsi_xfer *xs);
+STATIC INLINE void ahc_list_remove(struct ahc_softc *ahc,
+ struct scsi_xfer *xs);
+STATIC INLINE struct scsi_xfer *ahc_list_next(struct ahc_softc *ahc,
+ struct scsi_xfer *xs);
+STATIC int32_t ahc_scsi_cmd(struct scsi_xfer *xs);
+static __inline void ahc_swap_hscb(struct hardware_scb *);
+static __inline void ahc_swap_sg(struct ahc_dma_seg *);
struct cfdriver ahc_cd = {
NULL, "ahc", DV_DULL