177 lines
4.0 KiB
C
177 lines
4.0 KiB
C
|
/*
|
||
|
* 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__ */
|
||
|
|