⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 debug.c

📁 嵌入式文件系统 EFSL 0.3.5 / 嵌入式文件系统 EFSL 0.3.5
💻 C
字号:
/*****************************************************************************\*                     EFSL - Embedded Filesystems Library                     **                     -----------------------------------                     **                                                                             ** Filename : debug.c                                                          ** Release  : 0.3 - devel                                                      ** Description : These functions are used for debugging output on different    **               environments                                                  **                                                                             ** This program is free software; you can redistribute it and/or               ** modify it under the terms of the GNU General Public License                 ** as published by the Free Software Foundation; version 2                     ** of the License.                                                             **                                                                             ** 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.                                **                                                                             ** As a special exception, if other files instantiate templates or             ** use macros or inline functions from this file, or you compile this          ** file and link it with other works to produce a work based on this file,     ** this file does not by itself cause the resulting work to be covered         ** by the GNU General Public License. However the source code for this         ** file must still be made available in accordance with section (3) of         ** the GNU General Public License.                                             **                                                                             ** This exception does not invalidate any other reasons why a work based       ** on this file might be covered by the GNU General Public License.            **                                                                             **                                                    (c)2006 Lennart Yseboodt **                                                    (c)2006 Michael De Nil   *\*****************************************************************************//* COMMENT REGARDING FUNCTION COMMENTS IN THIS FILE * Only the linuxfile debug functions are commented since all functions * perform the same logical task.*//*****************************************************************************/#include "debug.h"/*****************************************************************************//*****************************************************************************/#ifdef DEBUG#ifdef HW_ENDPOINT_LINUX_ALL/*****************************************************************************//* ****************************************************************************   * void debug(const eint8 *format, ...) * Description: This function prints debug output to the screen (target dependant) * and if DO_FUNC_DEBUG is defined also to a localfile. * Return value: void*/void debug(const eint8 *format, ...){	va_list ap;	#ifdef DO_FUNC_DEBUG	euint8 c;	extern  FILE* debugfile;	extern volatile euint8 tw;	#endif		va_start(ap, format);	vprintf(format,ap);	#ifdef DO_FUNC_DEBUG		for(c=0;c<tw+1;c++)		{			fprintf(debugfile,"  ");		}		vfprintf(debugfile,format,ap);	#endif	va_end(ap);}/*****************************************************************************//* ****************************************************************************   * void debug_funcin(const eint8 *format, ...) * Description: This function marks the entrance of a function, which * increments a tabfieldcounter. A tree like structure can the be found in the * debugging file. * Return value: void*/void debug_funcin(const eint8 *format, ...){	#ifdef DO_FUNC_DEBUG	eint8 c;	va_list ap;	extern  FILE* debugfile;	extern volatile unsigned char tw;		if(debugfile==NULL)return;		for(c=0;c<tw;c++){		fprintf(debugfile,"  ");	}		va_start(ap, format);	vfprintf(debugfile,format,ap);	va_end(ap);	fprintf(debugfile,"\n");		tw++;	#endif}/*****************************************************************************//* ****************************************************************************   * void debug_funcout(const eint8 *format, ...) * Description: Decrements the tabfieldcounter. This function is called everywhere * a function is left. * Return value: void*/void debug_funcout(const eint8 *format, ...){	#ifdef DO_FUNC_DEBUG	eint8 c;	va_list ap;	extern  FILE* debugfile;	extern volatile euint8 tw;		if(debugfile==NULL)return;		if(tw>0)tw--;		for(c=0;c<tw;c++){		fprintf(debugfile,"  ");	}		va_start(ap, format);	vfprintf(debugfile,format,ap);	va_end(ap);	fprintf(debugfile,"\n");	#endif}/*****************************************************************************//* ****************************************************************************   * void debug_init() * Description: This function optionally opens the debugfile, or does any other * initialisation to enable debugoutput. * Return value: void*/void debug_init(){	#ifdef DO_FUNC_DEBUG	extern  FILE* debugfile;	extern volatile unsigned char tw;	debugfile=NULL;	tw=0;		debugfile=fopen("DBG.OUT","w");	#endif}/*****************************************************************************//* ****************************************************************************   * void debug_end() * Description: This function closes the debugfile. * Return value: void*/void debug_end(){	#ifdef DO_FUNC_DEBUG	extern  FILE* debugfile;		fflush(debugfile);	fclose(debugfile);	#endif}/*****************************************************************************//*****************************************************************************/#endif#endif/*****************************************************************************//*****************************************************************************/#ifdef DEBUG#ifdef HW_ENDPOINT_ATMEGA128_SD/*****************************************************************************/void debug(const eint8 *format, ...){	eint8 dbgstring[90];	va_list ap;	euint8 i=0;	eint8 c;		va_start(ap, format);	vsprintf_P(dbgstring, format, ap);	va_end(ap);			while (( (c=dbgstring[i++]) && (i<90) ))		debug_sendByte(c);			if(i>=90)		debug(PSTR("<BREAK>\n"));}/*****************************************************************************/void debug_init(void){	unsigned short ubrr;		ubrr = ((unsigned short)DEBUG_UBRR);		switch(DEBUG_PORT){		case 0:			UBRR0H = (euint8) (ubrr>>8);			UBRR0L = (euint8) (ubrr);			UCSR0B = ( (1<<RXEN) | (1<<TXEN) );			break;		case 1:				UBRR1H = (euint8) (ubrr>>8);			UBRR1L = (euint8) (ubrr);			UCSR1B = ( (1<<RXEN) | (1<<TXEN) );			break;		default:			/* INVALID CONFIG FILE */			break;	}}/*****************************************************************************/void debug_end(void){	/* Nothing to do here, function is here for compatibility */}/*****************************************************************************/void debug_sendByte(euint8 data){	/* If sending a newline, add a return first */	if(data=='\n')		debug_sendByte('\r');	switch(DEBUG_PORT){		case 0:			while ( !(UCSR0A & (1<<UDRE0)) )				_NOP(); 	/* Wait for empty transmit buffer */			UDR0 = data;    /* Start transmittion */			break;		case 1:			while ( !(UCSR1A & (1<<UDRE1)) ) 				_NOP(); 	/* Wait for empty transmit buffer */			UDR1 = data;	/* Start transmittion */			break;		default:			/* INVALID CONFIG FILE */			break;	}}/*****************************************************************************/unsigned char debug_getByte(){	switch(DEBUG_PORT){		case 0:			while ( !(UCSR0A & (1<<RXC0)) )				_NOP();			return(UDR0);			break;		case 1:			while ( !(UCSR1A & (1<<RXC1)) )				_NOP();			return(UDR1);			break;	}}/*****************************************************************************/euint8 debug_getString(euint8 *data,euint16 length){	euint8 i=0;	euint8 c;	do	{		c=debug_getByte();		if(c!='\n' && c!='\r')			data[i++]=c;		debug_sendByte(c);	}	while(c!='\n' && c!='\r' && i<length);	data[i]='\0';	return(i);}/*****************************************************************************//*****************************************************************************/#endif#endif/*****************************************************************************//*****************************************************************************/#ifdef DEBUG#ifdef HW_ENDPOINT_DSP_TI6713_SD/*****************************************************************************/void dbg(const char *format, ...){	printf(format);}/*****************************************************************************/void debug_init(){}/*****************************************************************************/void debug_end(){}/*****************************************************************************//*****************************************************************************/#endif#endif/*****************************************************************************/

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -