/* * Copyright (c) 2005-2009 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. */ #ifndef __BFA_TRC_H__ #define __BFA_TRC_H__ #include <bfa_os_inc.h> #ifndef BFA_TRC_MAX #define BFA_TRC_MAX (4 * 1024) #endif #ifndef BFA_TRC_TS #define BFA_TRC_TS(_trcm) ((_trcm)->ticks ++) #endif struct bfa_trc_s { #ifdef __BIGENDIAN u16 fileno; u16 line; #else u16 line; u16 fileno; #endif u32 timestamp; union { struct { u32 rsvd; u32 u32; } u32; u64 u64; } data; }; struct bfa_trc_mod_s { u32 head; u32 tail; u32 ntrc; u32 stopped; u32 ticks; u32 rsvd[3]; struct bfa_trc_s trc[BFA_TRC_MAX]; }; enum { BFA_TRC_FW = 1, /* firmware modules */ BFA_TRC_HAL = 2, /* BFA modules */ BFA_TRC_FCS = 3, /* BFA FCS modules */ BFA_TRC_LDRV = 4, /* Linux driver modules */ BFA_TRC_SDRV = 5, /* Solaris driver modules */ BFA_TRC_VDRV = 6, /* vmware driver modules */ BFA_TRC_WDRV = 7, /* windows driver modules */ BFA_TRC_AEN = 8, /* AEN module */ BFA_TRC_BIOS = 9, /* bios driver modules */ BFA_TRC_EFI = 10, /* EFI driver modules */ BNA_TRC_WDRV = 11, /* BNA windows driver modules */ BNA_TRC_VDRV = 12, /* BNA vmware driver modules */ BNA_TRC_SDRV = 13, /* BNA Solaris driver modules */ BNA_TRC_LDRV = 14, /* BNA Linux driver modules */ BNA_TRC_HAL = 15, /* BNA modules */ BFA_TRC_CNA = 16, /* Common modules */ BNA_TRC_IMDRV = 17 /* BNA windows intermediate driver modules */ }; #define BFA_TRC_MOD_SH 10 #define BFA_TRC_MOD(__mod) ((BFA_TRC_ ## __mod) << BFA_TRC_MOD_SH) /** * Define a new tracing file (module). Module should match one defined above. */ #define BFA_TRC_FILE(__mod, __submod) \ static int __trc_fileno = ((BFA_TRC_ ## __mod ## _ ## __submod) | \ BFA_TRC_MOD(__mod)) #define bfa_trc32(_trcp, _data) \ __bfa_trc((_trcp)->trcmod, __trc_fileno, __LINE__, (u32)_data) #ifndef BFA_BOOT_BUILD #define bfa_trc(_trcp, _data) \ __bfa_trc((_trcp)->trcmod, __trc_fileno, __LINE__, (u64)_data) #else void bfa_boot_trc(struct bfa_trc_mod_s *trcmod, u16 fileno, u16 line, u32 data); #define bfa_trc(_trcp, _data) \ bfa_boot_trc((_trcp)->trcmod, __trc_fileno, __LINE__, (u32)_data) #endif static inline void bfa_trc_init(struct bfa_trc_mod_s *trcm) { trcm->head = trcm->tail = trcm->stopped = 0; trcm->ntrc = BFA_TRC_MAX; } static inline void bfa_trc_stop(struct bfa_trc_mod_s *trcm) { trcm->stopped = 1; } #ifdef FWTRC extern void dc_flush(void *data); #else #define dc_flush(data) #endif static inline void __bfa_trc(struct bfa_trc_mod_s *trcm, int fileno, int line, u64 data) { int tail = trcm->tail; struct bfa_trc_s *trc = &trcm->trc[tail]; if (trcm->stopped) return; trc->fileno = (u16) fileno; trc->line = (u16) line; trc->data.u64 = data; trc->timestamp = BFA_TRC_TS(trcm); dc_flush(trc); trcm->tail = (trcm->tail + 1) & (BFA_TRC_MAX - 1); if (trcm->tail == trcm->head) trcm->head = (trcm->head + 1) & (BFA_TRC_MAX - 1); dc_flush(trcm); } static inline void __bfa_trc32(struct bfa_trc_mod_s *trcm, int fileno, int line, u32 data) { int tail = trcm->tail; struct bfa_trc_s *trc = &trcm->trc[tail]; if (trcm->stopped) return; trc->fileno = (u16) fileno; trc->line = (u16) line; trc->data.u32.u32 = data; trc->timestamp = BFA_TRC_TS(trcm); dc_flush(trc); trcm->tail = (trcm->tail + 1) & (BFA_TRC_MAX - 1); if (trcm->tail == trcm->head) trcm->head = (trcm->head + 1) & (BFA_TRC_MAX - 1); dc_flush(trcm); } #ifndef BFA_PERF_BUILD #define bfa_trc_fp(_trcp, _data) bfa_trc(_trcp, _data) #else #define bfa_trc_fp(_trcp, _data) #endif #endif /* __BFA_TRC_H__ */