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__ */
 | 
						|
 |