18c2ecf20Sopenharmony_ci/* 28c2ecf20Sopenharmony_ci * Inline routines shareable across OS platforms. 38c2ecf20Sopenharmony_ci * 48c2ecf20Sopenharmony_ci * Copyright (c) 1994-2001 Justin T. Gibbs. 58c2ecf20Sopenharmony_ci * Copyright (c) 2000-2003 Adaptec Inc. 68c2ecf20Sopenharmony_ci * All rights reserved. 78c2ecf20Sopenharmony_ci * 88c2ecf20Sopenharmony_ci * Redistribution and use in source and binary forms, with or without 98c2ecf20Sopenharmony_ci * modification, are permitted provided that the following conditions 108c2ecf20Sopenharmony_ci * are met: 118c2ecf20Sopenharmony_ci * 1. Redistributions of source code must retain the above copyright 128c2ecf20Sopenharmony_ci * notice, this list of conditions, and the following disclaimer, 138c2ecf20Sopenharmony_ci * without modification. 148c2ecf20Sopenharmony_ci * 2. Redistributions in binary form must reproduce at minimum a disclaimer 158c2ecf20Sopenharmony_ci * substantially similar to the "NO WARRANTY" disclaimer below 168c2ecf20Sopenharmony_ci * ("Disclaimer") and any redistribution must be conditioned upon 178c2ecf20Sopenharmony_ci * including a substantially similar Disclaimer requirement for further 188c2ecf20Sopenharmony_ci * binary redistribution. 198c2ecf20Sopenharmony_ci * 3. Neither the names of the above-listed copyright holders nor the names 208c2ecf20Sopenharmony_ci * of any contributors may be used to endorse or promote products derived 218c2ecf20Sopenharmony_ci * from this software without specific prior written permission. 228c2ecf20Sopenharmony_ci * 238c2ecf20Sopenharmony_ci * Alternatively, this software may be distributed under the terms of the 248c2ecf20Sopenharmony_ci * GNU General Public License ("GPL") version 2 as published by the Free 258c2ecf20Sopenharmony_ci * Software Foundation. 268c2ecf20Sopenharmony_ci * 278c2ecf20Sopenharmony_ci * NO WARRANTY 288c2ecf20Sopenharmony_ci * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 298c2ecf20Sopenharmony_ci * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 308c2ecf20Sopenharmony_ci * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR 318c2ecf20Sopenharmony_ci * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 328c2ecf20Sopenharmony_ci * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 338c2ecf20Sopenharmony_ci * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 348c2ecf20Sopenharmony_ci * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 358c2ecf20Sopenharmony_ci * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 368c2ecf20Sopenharmony_ci * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING 378c2ecf20Sopenharmony_ci * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 388c2ecf20Sopenharmony_ci * POSSIBILITY OF SUCH DAMAGES. 398c2ecf20Sopenharmony_ci * 408c2ecf20Sopenharmony_ci * $Id: //depot/aic7xxx/aic7xxx/aic79xx_inline.h#59 $ 418c2ecf20Sopenharmony_ci * 428c2ecf20Sopenharmony_ci * $FreeBSD$ 438c2ecf20Sopenharmony_ci */ 448c2ecf20Sopenharmony_ci 458c2ecf20Sopenharmony_ci#ifndef _AIC79XX_INLINE_H_ 468c2ecf20Sopenharmony_ci#define _AIC79XX_INLINE_H_ 478c2ecf20Sopenharmony_ci 488c2ecf20Sopenharmony_ci/******************************** Debugging ***********************************/ 498c2ecf20Sopenharmony_cistatic inline char *ahd_name(struct ahd_softc *ahd); 508c2ecf20Sopenharmony_ci 518c2ecf20Sopenharmony_cistatic inline char *ahd_name(struct ahd_softc *ahd) 528c2ecf20Sopenharmony_ci{ 538c2ecf20Sopenharmony_ci return (ahd->name); 548c2ecf20Sopenharmony_ci} 558c2ecf20Sopenharmony_ci 568c2ecf20Sopenharmony_ci/************************ Sequencer Execution Control *************************/ 578c2ecf20Sopenharmony_cistatic inline void ahd_known_modes(struct ahd_softc *ahd, 588c2ecf20Sopenharmony_ci ahd_mode src, ahd_mode dst); 598c2ecf20Sopenharmony_cistatic inline ahd_mode_state ahd_build_mode_state(struct ahd_softc *ahd, 608c2ecf20Sopenharmony_ci ahd_mode src, 618c2ecf20Sopenharmony_ci ahd_mode dst); 628c2ecf20Sopenharmony_cistatic inline void ahd_extract_mode_state(struct ahd_softc *ahd, 638c2ecf20Sopenharmony_ci ahd_mode_state state, 648c2ecf20Sopenharmony_ci ahd_mode *src, ahd_mode *dst); 658c2ecf20Sopenharmony_ci 668c2ecf20Sopenharmony_civoid ahd_set_modes(struct ahd_softc *ahd, ahd_mode src, 678c2ecf20Sopenharmony_ci ahd_mode dst); 688c2ecf20Sopenharmony_ciahd_mode_state ahd_save_modes(struct ahd_softc *ahd); 698c2ecf20Sopenharmony_civoid ahd_restore_modes(struct ahd_softc *ahd, 708c2ecf20Sopenharmony_ci ahd_mode_state state); 718c2ecf20Sopenharmony_ciint ahd_is_paused(struct ahd_softc *ahd); 728c2ecf20Sopenharmony_civoid ahd_pause(struct ahd_softc *ahd); 738c2ecf20Sopenharmony_civoid ahd_unpause(struct ahd_softc *ahd); 748c2ecf20Sopenharmony_ci 758c2ecf20Sopenharmony_cistatic inline void 768c2ecf20Sopenharmony_ciahd_known_modes(struct ahd_softc *ahd, ahd_mode src, ahd_mode dst) 778c2ecf20Sopenharmony_ci{ 788c2ecf20Sopenharmony_ci ahd->src_mode = src; 798c2ecf20Sopenharmony_ci ahd->dst_mode = dst; 808c2ecf20Sopenharmony_ci ahd->saved_src_mode = src; 818c2ecf20Sopenharmony_ci ahd->saved_dst_mode = dst; 828c2ecf20Sopenharmony_ci} 838c2ecf20Sopenharmony_ci 848c2ecf20Sopenharmony_cistatic inline ahd_mode_state 858c2ecf20Sopenharmony_ciahd_build_mode_state(struct ahd_softc *ahd, ahd_mode src, ahd_mode dst) 868c2ecf20Sopenharmony_ci{ 878c2ecf20Sopenharmony_ci return ((src << SRC_MODE_SHIFT) | (dst << DST_MODE_SHIFT)); 888c2ecf20Sopenharmony_ci} 898c2ecf20Sopenharmony_ci 908c2ecf20Sopenharmony_cistatic inline void 918c2ecf20Sopenharmony_ciahd_extract_mode_state(struct ahd_softc *ahd, ahd_mode_state state, 928c2ecf20Sopenharmony_ci ahd_mode *src, ahd_mode *dst) 938c2ecf20Sopenharmony_ci{ 948c2ecf20Sopenharmony_ci *src = (state & SRC_MODE) >> SRC_MODE_SHIFT; 958c2ecf20Sopenharmony_ci *dst = (state & DST_MODE) >> DST_MODE_SHIFT; 968c2ecf20Sopenharmony_ci} 978c2ecf20Sopenharmony_ci 988c2ecf20Sopenharmony_ci/*********************** Scatter Gather List Handling *************************/ 998c2ecf20Sopenharmony_civoid *ahd_sg_setup(struct ahd_softc *ahd, struct scb *scb, 1008c2ecf20Sopenharmony_ci void *sgptr, dma_addr_t addr, 1018c2ecf20Sopenharmony_ci bus_size_t len, int last); 1028c2ecf20Sopenharmony_ci 1038c2ecf20Sopenharmony_ci/************************** Memory mapping routines ***************************/ 1048c2ecf20Sopenharmony_cistatic inline size_t ahd_sg_size(struct ahd_softc *ahd); 1058c2ecf20Sopenharmony_ci 1068c2ecf20Sopenharmony_civoid ahd_sync_sglist(struct ahd_softc *ahd, 1078c2ecf20Sopenharmony_ci struct scb *scb, int op); 1088c2ecf20Sopenharmony_ci 1098c2ecf20Sopenharmony_cistatic inline size_t ahd_sg_size(struct ahd_softc *ahd) 1108c2ecf20Sopenharmony_ci{ 1118c2ecf20Sopenharmony_ci if ((ahd->flags & AHD_64BIT_ADDRESSING) != 0) 1128c2ecf20Sopenharmony_ci return (sizeof(struct ahd_dma64_seg)); 1138c2ecf20Sopenharmony_ci return (sizeof(struct ahd_dma_seg)); 1148c2ecf20Sopenharmony_ci} 1158c2ecf20Sopenharmony_ci 1168c2ecf20Sopenharmony_ci/*********************** Miscellaneous Support Functions ***********************/ 1178c2ecf20Sopenharmony_cistruct ahd_initiator_tinfo * 1188c2ecf20Sopenharmony_ci ahd_fetch_transinfo(struct ahd_softc *ahd, 1198c2ecf20Sopenharmony_ci char channel, u_int our_id, 1208c2ecf20Sopenharmony_ci u_int remote_id, 1218c2ecf20Sopenharmony_ci struct ahd_tmode_tstate **tstate); 1228c2ecf20Sopenharmony_ciuint16_t 1238c2ecf20Sopenharmony_ci ahd_inw(struct ahd_softc *ahd, u_int port); 1248c2ecf20Sopenharmony_civoid ahd_outw(struct ahd_softc *ahd, u_int port, 1258c2ecf20Sopenharmony_ci u_int value); 1268c2ecf20Sopenharmony_ciuint32_t 1278c2ecf20Sopenharmony_ci ahd_inl(struct ahd_softc *ahd, u_int port); 1288c2ecf20Sopenharmony_civoid ahd_outl(struct ahd_softc *ahd, u_int port, 1298c2ecf20Sopenharmony_ci uint32_t value); 1308c2ecf20Sopenharmony_ciuint64_t 1318c2ecf20Sopenharmony_ci ahd_inq(struct ahd_softc *ahd, u_int port); 1328c2ecf20Sopenharmony_civoid ahd_outq(struct ahd_softc *ahd, u_int port, 1338c2ecf20Sopenharmony_ci uint64_t value); 1348c2ecf20Sopenharmony_ciu_int ahd_get_scbptr(struct ahd_softc *ahd); 1358c2ecf20Sopenharmony_civoid ahd_set_scbptr(struct ahd_softc *ahd, u_int scbptr); 1368c2ecf20Sopenharmony_ciu_int ahd_inb_scbram(struct ahd_softc *ahd, u_int offset); 1378c2ecf20Sopenharmony_ciu_int ahd_inw_scbram(struct ahd_softc *ahd, u_int offset); 1388c2ecf20Sopenharmony_cistruct scb * 1398c2ecf20Sopenharmony_ci ahd_lookup_scb(struct ahd_softc *ahd, u_int tag); 1408c2ecf20Sopenharmony_civoid ahd_queue_scb(struct ahd_softc *ahd, struct scb *scb); 1418c2ecf20Sopenharmony_ci 1428c2ecf20Sopenharmony_cistatic inline uint8_t *ahd_get_sense_buf(struct ahd_softc *ahd, 1438c2ecf20Sopenharmony_ci struct scb *scb); 1448c2ecf20Sopenharmony_cistatic inline uint32_t ahd_get_sense_bufaddr(struct ahd_softc *ahd, 1458c2ecf20Sopenharmony_ci struct scb *scb); 1468c2ecf20Sopenharmony_ci 1478c2ecf20Sopenharmony_ci#if 0 /* unused */ 1488c2ecf20Sopenharmony_ci 1498c2ecf20Sopenharmony_ci#define AHD_COPY_COL_IDX(dst, src) \ 1508c2ecf20Sopenharmony_cido { \ 1518c2ecf20Sopenharmony_ci dst->hscb->scsiid = src->hscb->scsiid; \ 1528c2ecf20Sopenharmony_ci dst->hscb->lun = src->hscb->lun; \ 1538c2ecf20Sopenharmony_ci} while (0) 1548c2ecf20Sopenharmony_ci 1558c2ecf20Sopenharmony_ci#endif 1568c2ecf20Sopenharmony_ci 1578c2ecf20Sopenharmony_cistatic inline uint8_t * 1588c2ecf20Sopenharmony_ciahd_get_sense_buf(struct ahd_softc *ahd, struct scb *scb) 1598c2ecf20Sopenharmony_ci{ 1608c2ecf20Sopenharmony_ci return (scb->sense_data); 1618c2ecf20Sopenharmony_ci} 1628c2ecf20Sopenharmony_ci 1638c2ecf20Sopenharmony_cistatic inline uint32_t 1648c2ecf20Sopenharmony_ciahd_get_sense_bufaddr(struct ahd_softc *ahd, struct scb *scb) 1658c2ecf20Sopenharmony_ci{ 1668c2ecf20Sopenharmony_ci return (scb->sense_busaddr); 1678c2ecf20Sopenharmony_ci} 1688c2ecf20Sopenharmony_ci 1698c2ecf20Sopenharmony_ci/************************** Interrupt Processing ******************************/ 1708c2ecf20Sopenharmony_ciint ahd_intr(struct ahd_softc *ahd); 1718c2ecf20Sopenharmony_ci 1728c2ecf20Sopenharmony_ci#endif /* _AIC79XX_INLINE_H_ */ 173