2005-04-17 02:20:36 +04:00
/*
2005-10-27 22:10:08 +04:00
* QLogic Fibre Channel HBA Driver
2010-07-23 14:28:36 +04:00
* Copyright ( c ) 2003 - 2010 QLogic Corporation
2005-04-17 02:20:36 +04:00
*
2005-10-27 22:10:08 +04:00
* See LICENSE . qla2xxx for copyright and licensing details .
2005-04-17 02:20:36 +04:00
*/
/*
* qla2x00_debounce_register
* Debounce register .
*
* Input :
* port = register address .
*
* Returns :
* register value .
*/
static __inline__ uint16_t
2005-07-06 21:32:07 +04:00
qla2x00_debounce_register ( volatile uint16_t __iomem * addr )
2005-04-17 02:20:36 +04:00
{
volatile uint16_t first ;
volatile uint16_t second ;
do {
first = RD_REG_WORD ( addr ) ;
barrier ( ) ;
cpu_relax ( ) ;
second = RD_REG_WORD ( addr ) ;
} while ( first ! = second ) ;
return ( first ) ;
}
2005-07-06 21:32:07 +04:00
static inline void
2008-11-06 21:40:51 +03:00
qla2x00_poll ( struct rsp_que * rsp )
2005-04-17 02:20:36 +04:00
{
2008-05-13 09:21:14 +04:00
unsigned long flags ;
2008-11-06 21:40:51 +03:00
struct qla_hw_data * ha = rsp - > hw ;
2008-05-13 09:21:14 +04:00
local_irq_save ( flags ) ;
2010-04-13 04:59:55 +04:00
if ( IS_QLA82XX ( ha ) )
qla82xx_poll ( 0 , rsp ) ;
else
ha - > isp_ops - > intr_handler ( 0 , rsp ) ;
2008-05-13 09:21:14 +04:00
local_irq_restore ( flags ) ;
2005-04-17 02:20:36 +04:00
}
2005-07-06 21:31:17 +04:00
static inline uint8_t *
host_to_fcp_swap ( uint8_t * fcp , uint32_t bsize )
{
uint32_t * ifcp = ( uint32_t * ) fcp ;
uint32_t * ofcp = ( uint32_t * ) fcp ;
uint32_t iter = bsize > > 2 ;
for ( ; iter ; iter - - )
* ofcp + + = swab32 ( * ifcp + + ) ;
return fcp ;
}
2005-07-06 21:30:26 +04:00
static inline int
2008-11-06 21:40:51 +03:00
qla2x00_is_reserved_id ( scsi_qla_host_t * vha , uint16_t loop_id )
2005-07-06 21:30:26 +04:00
{
2008-11-06 21:40:51 +03:00
struct qla_hw_data * ha = vha - > hw ;
2007-07-20 02:05:56 +04:00
if ( IS_FWI2_CAPABLE ( ha ) )
2005-07-06 21:30:26 +04:00
return ( loop_id > NPH_LAST_HANDLE ) ;
2008-11-06 21:40:51 +03:00
return ( ( loop_id > ha - > max_loop_id & & loop_id < SNS_FIRST_LOOP_ID ) | |
2005-07-06 21:30:26 +04:00
loop_id = = MANAGEMENT_SERVER | | loop_id = = BROADCAST ) ;
2008-12-18 21:06:15 +03:00
}
2010-05-05 02:01:30 +04:00
static inline void
qla2x00_clean_dsd_pool ( struct qla_hw_data * ha , srb_t * sp )
{
struct dsd_dma * dsd_ptr , * tdsd_ptr ;
/* clean up allocated prev pool */
list_for_each_entry_safe ( dsd_ptr , tdsd_ptr ,
& ( ( struct crc_context * ) sp - > ctx ) - > dsd_list , list ) {
dma_pool_free ( ha - > dl_dma_pool , dsd_ptr - > dsd_addr ,
dsd_ptr - > dsd_list_dma ) ;
list_del ( & dsd_ptr - > list ) ;
kfree ( dsd_ptr ) ;
}
INIT_LIST_HEAD ( & ( ( struct crc_context * ) sp - > ctx ) - > dsd_list ) ;
}