/* * Copyright (c) 2005-2010 Brocade Communications Systems, Inc. * All rights reserved * www.brocade.com * * Linux driver for Brocade Fibre Channel Host Bus Adapter. * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License (GPL) Version 2 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. */ /** * Contains declarations all OS Specific files needed for BFA layer */ #ifndef __BFA_OS_INC_H__ #define __BFA_OS_INC_H__ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #ifdef __BIG_ENDIAN #define __BIGENDIAN #endif static inline u64 bfa_os_get_clock(void) { return jiffies; } static inline u64 bfa_os_get_log_time(void) { u64 system_time = 0; struct timeval tv; do_gettimeofday(&tv); /* We are interested in seconds only. */ system_time = tv.tv_sec; return system_time; } #define bfa_io_lat_clock_res_div HZ #define bfa_io_lat_clock_res_mul 1000 #define BFA_ASSERT(p) do { \ if (!(p)) { \ printk(KERN_ERR "assert(%s) failed at %s:%d\n", \ #p, __FILE__, __LINE__); \ } \ } while (0) #define BFA_LOG(level, bfad, mask, fmt, arg...) \ do { \ if (((mask) == 4) || (level[1] <= '4')) \ dev_printk(level, &((bfad)->pcidev)->dev, fmt, ##arg); \ } while (0) #define bfa_swap_3b(_x) \ ((((_x) & 0xff) << 16) | \ ((_x) & 0x00ff00) | \ (((_x) & 0xff0000) >> 16)) #define bfa_swap_8b(_x) \ ((((_x) & 0xff00000000000000ull) >> 56) \ | (((_x) & 0x00ff000000000000ull) >> 40) \ | (((_x) & 0x0000ff0000000000ull) >> 24) \ | (((_x) & 0x000000ff00000000ull) >> 8) \ | (((_x) & 0x00000000ff000000ull) << 8) \ | (((_x) & 0x0000000000ff0000ull) << 24) \ | (((_x) & 0x000000000000ff00ull) << 40) \ | (((_x) & 0x00000000000000ffull) << 56)) #define bfa_os_swap32(_x) \ ((((_x) & 0xff) << 24) | \ (((_x) & 0x0000ff00) << 8) | \ (((_x) & 0x00ff0000) >> 8) | \ (((_x) & 0xff000000) >> 24)) #define bfa_os_swap_sgaddr(_x) ((u64)( \ (((u64)(_x) & (u64)0x00000000000000ffull) << 32) | \ (((u64)(_x) & (u64)0x000000000000ff00ull) << 32) | \ (((u64)(_x) & (u64)0x0000000000ff0000ull) << 32) | \ (((u64)(_x) & (u64)0x00000000ff000000ull) << 32) | \ (((u64)(_x) & (u64)0x000000ff00000000ull) >> 32) | \ (((u64)(_x) & (u64)0x0000ff0000000000ull) >> 32) | \ (((u64)(_x) & (u64)0x00ff000000000000ull) >> 32) | \ (((u64)(_x) & (u64)0xff00000000000000ull) >> 32))) #ifndef __BIGENDIAN #define bfa_os_htons(_x) ((u16)((((_x) & 0xff00) >> 8) | \ (((_x) & 0x00ff) << 8))) #define bfa_os_htonl(_x) bfa_os_swap32(_x) #define bfa_os_htonll(_x) bfa_swap_8b(_x) #define bfa_os_hton3b(_x) bfa_swap_3b(_x) #define bfa_os_wtole(_x) (_x) #define bfa_os_sgaddr(_x) (_x) #else #define bfa_os_htons(_x) (_x) #define bfa_os_htonl(_x) (_x) #define bfa_os_hton3b(_x) (_x) #define bfa_os_htonll(_x) (_x) #define bfa_os_wtole(_x) bfa_os_swap32(_x) #define bfa_os_sgaddr(_x) bfa_os_swap_sgaddr(_x) #endif #define bfa_os_ntohs(_x) bfa_os_htons(_x) #define bfa_os_ntohl(_x) bfa_os_htonl(_x) #define bfa_os_ntohll(_x) bfa_os_htonll(_x) #define bfa_os_ntoh3b(_x) bfa_os_hton3b(_x) #define bfa_os_u32(__pa64) ((__pa64) >> 32) #define bfa_os_memset memset #define bfa_os_memcpy memcpy #define bfa_os_udelay udelay #define bfa_os_vsprintf vsprintf #define bfa_os_snprintf snprintf #define bfa_os_assign(__t, __s) __t = __s #define bfa_os_addr_t void __iomem * #define bfa_os_reg_read(_raddr) readl(_raddr) #define bfa_os_reg_write(_raddr, _val) writel((_val), (_raddr)) #define bfa_os_mem_read(_raddr, _off) \ bfa_os_swap32(readl(((_raddr) + (_off)))) #define bfa_os_mem_write(_raddr, _off, _val) \ writel(bfa_os_swap32((_val)), ((_raddr) + (_off))) #define BFA_TRC_TS(_trcm) \ ({ \ struct timeval tv; \ \ do_gettimeofday(&tv); \ (tv.tv_sec*1000000+tv.tv_usec); \ }) #define boolean_t int /** * For current time stamp, OS API will fill-in */ struct bfa_timeval_s { u32 tv_sec; /* seconds */ u32 tv_usec; /* microseconds */ }; static inline void bfa_os_gettimeofday(struct bfa_timeval_s *tv) { struct timeval tmp_tv; do_gettimeofday(&tmp_tv); tv->tv_sec = (u32) tmp_tv.tv_sec; tv->tv_usec = (u32) tmp_tv.tv_usec; } static inline void wwn2str(char *wwn_str, u64 wwn) { union { u64 wwn; u8 byte[8]; } w; w.wwn = wwn; sprintf(wwn_str, "%02x:%02x:%02x:%02x:%02x:%02x:%02x:%02x", w.byte[0], w.byte[1], w.byte[2], w.byte[3], w.byte[4], w.byte[5], w.byte[6], w.byte[7]); } static inline void fcid2str(char *fcid_str, u32 fcid) { union { u32 fcid; u8 byte[4]; } f; f.fcid = fcid; sprintf(fcid_str, "%02x:%02x:%02x", f.byte[1], f.byte[2], f.byte[3]); } #endif /* __BFA_OS_INC_H__ */