forked from len0rd/rockbox
		
	Also, add dummy defines for application targets so that ERRORF, etc map to DEBUGF instead of a compile error and add a new line at the end of logf.c. Change-Id: Ie7c5bc3397a853af619e810defce6123114e7a51
		
			
				
	
	
		
			85 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /***************************************************************************
 | |
|  *             __________               __   ___.
 | |
|  *   Open      \______   \ ____   ____ |  | _\_ |__   _______  ___
 | |
|  *   Source     |       _//  _ \_/ ___\|  |/ /| __ \ /  _ \  \/  /
 | |
|  *   Jukebox    |    |   (  <_> )  \___|    < | \_\ (  <_> > <  <
 | |
|  *   Firmware   |____|_  /\____/ \___  >__|_ \|___  /\____/__/\_ \
 | |
|  *                     \/            \/     \/    \/            \/
 | |
|  * $Id$
 | |
|  *
 | |
|  * Copyright (C) 2012 by Michael Giacomelli
 | |
|  *
 | |
|  * 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; either version 2
 | |
|  * of the License, or (at your option) any later version.
 | |
|  *
 | |
|  * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
 | |
|  * KIND, either express or implied.
 | |
|  *
 | |
|  ****************************************************************************/
 | |
| #ifndef LOGDISKF_H
 | |
| #define LOGDISKF_H
 | |
| #include <config.h>
 | |
| #include <stdbool.h>
 | |
| #include "gcc_extensions.h"
 | |
| #include "debug.h"
 | |
| 
 | |
| #ifdef ROCKBOX_HAS_LOGDISKF
 | |
| 
 | |
| void init_logdiskf(void);
 | |
| 
 | |
| /*large memory devices spin up the disk much less often*/
 | |
| #if MEMORYSIZE > 32
 | |
|  #define MAX_LOGDISKF_SIZE 8192
 | |
| #elif MEMORYSIZE > 8
 | |
|  #define MAX_LOGDISKF_SIZE 4096
 | |
| #else
 | |
|  #define MAX_LOGDISKF_SIZE 1024
 | |
| #endif
 | |
| 
 | |
| extern unsigned char logdiskfbuffer[MAX_LOGDISKF_SIZE];
 | |
| extern int logfdiskindex;
 | |
| 
 | |
| #define LOGDISK_LEVEL 1
 | |
| 
 | |
| #if LOGDISK_LEVEL > 0       /*serious errors or problems*/
 | |
|  #define ERRORF(...) _logdiskf(__func__,'E', __VA_ARGS__)
 | |
| #else
 | |
|  #define ERRORF(...)
 | |
| #endif
 | |
| 
 | |
| #if LOGDISK_LEVEL > 1       /*matters of concern*/
 | |
|  #define WARNF(...) _logdiskf(__func__, 'W', __VA_ARGS__)
 | |
| #else
 | |
|  #define WARNF(...)
 | |
| #endif
 | |
| 
 | |
| #if LOGDISK_LEVEL > 2       /*useful for debug only*/
 | |
|  #define NOTEF(...) _logdiskf(__func__, 'N', __VA_ARGS__)
 | |
| #else
 | |
|  #define NOTEF(...)     /*TODO:  rename DEBUGF later*/
 | |
| #endif
 | |
| 
 | |
| /*__FILE__ would be better but is difficult to make work with the build system*/
 | |
| //#define logdiskf(...) _logdiskf(__func__, 1, __VA_ARGS__)
 | |
| 
 | |
| void _logdiskf(const char* file, const char level,
 | |
|                 const char *format, ...) ATTRIBUTE_PRINTF(3, 4);
 | |
| 
 | |
| #else /* !ROCKBOX_HAS_LOGF */
 | |
| 
 | |
| /* built without logdiskf() support enabled, replace logdiskf() by DEBUGF() */
 | |
| #define logdiskf(f,args...) DEBUGF(f"\n",##args)
 | |
| 
 | |
| #endif /* !ROCKBOX_HAS_LOGDISKF */
 | |
| 
 | |
| #else
 | |
| 
 | |
| #define ERRORF DEBUGF
 | |
| #define WARNF DEBUGF
 | |
| #define NOTEF DEBUGF
 | |
| 
 | |
| #endif /* LOGDISKF_H */
 | |
|     
 | |
|     
 |