From 5b4a6c4267074c40655213e443ab4997530a4a98 Mon Sep 17 00:00:00 2001 From: Thomas Martitz Date: Tue, 17 Jan 2012 07:55:20 +0100 Subject: Hosted: Merge debugf() implementations. Cleanup debug.h. Fixes debug build for ypr0. Change-Id: I9c0eff651dcf268a3fafed1a71fcc47f3e323d36 --- firmware/SOURCES | 5 +++ firmware/export/debug.h | 23 ++++--------- firmware/target/hosted/debug-hosted.c | 65 +++++++++++++++++++++++++++++++++++ uisimulator/common/io.c | 40 --------------------- 4 files changed, 77 insertions(+), 56 deletions(-) create mode 100644 firmware/target/hosted/debug-hosted.c diff --git a/firmware/SOURCES b/firmware/SOURCES index f2036734a5..18f877ba3d 100644 --- a/firmware/SOURCES +++ b/firmware/SOURCES @@ -16,6 +16,11 @@ target/hosted/cpuinfo-linux.c #ifndef SAMSUNG_YPR0 /* uses as3514 rtc */ target/hosted/rtc.c #endif + +#if (CONFIG_PLATFORM & PLATFORM_ANDROID) == 0 +target/hosted/debug-hosted.c +#endif + #endif system.c usb.c diff --git a/firmware/export/debug.h b/firmware/export/debug.h index b5458af487..3a4a774f42 100644 --- a/firmware/export/debug.h +++ b/firmware/export/debug.h @@ -29,16 +29,13 @@ extern void debugf(const char* fmt,...) ATTRIBUTE_PRINTF(1, 2); extern void ldebugf(const char* file, int line, const char *fmt, ...) ATTRIBUTE_PRINTF(3, 4); -#ifndef CODEC -#ifdef __GNUC__ +#ifndef CODEC -/* */ #if defined(SIMULATOR) && !defined(__PCTOOL__) \ - || ((CONFIG_PLATFORM & (PLATFORM_ANDROID|PLATFORM_MAEMO|PLATFORM_PANDORA)) && defined(DEBUG)) + || (defined(APPLICATION) && defined(DEBUG)) #define DEBUGF debugf #define LDEBUGF(...) ldebugf(__FILE__, __LINE__, __VA_ARGS__) -#else -#if defined(DEBUG) +#elif defined(DEBUG) /* DEBUG on native targets */ #ifdef HAVE_GDB_API void breakpoint(void); @@ -46,19 +43,13 @@ void breakpoint(void); #define DEBUGF debugf #define LDEBUGF debugf -#else -#define DEBUGF(...) do { } while(0) -#define LDEBUGF(...) do { } while(0) -#endif -#endif +#else /* !DEBUG */ -#else - -#define DEBUGF debugf -#define LDEBUGF debugf +#define DEBUGF(...) do { } while(0) +#define LDEBUGF(...) do { } while(0) -#endif /* GCC */ +#endif /* SIMULATOR && !__PCTOOL__ || APPLICATION && DEBUG */ #endif /* CODEC */ #endif diff --git a/firmware/target/hosted/debug-hosted.c b/firmware/target/hosted/debug-hosted.c new file mode 100644 index 0000000000..35c487958b --- /dev/null +++ b/firmware/target/hosted/debug-hosted.c @@ -0,0 +1,65 @@ +/*************************************************************************** + * __________ __ ___. + * Open \______ \ ____ ____ | | _\_ |__ _______ ___ + * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ / + * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < < + * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \ + * \/ \/ \/ \/ \/ + * $Id$ + * + * Copyright (c) 2002 Daniel Stenberg + * + * 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. + * + ****************************************************************************/ + +#include +#include +#include + +#ifdef WIN32 +static unsigned old_cp; + +void debug_exit(void) +{ + /* Reset console output codepage */ + SetConsoleOutputCP(old_cp); +} + +void debug_init(void) +{ + old_cp = GetConsoleOutputCP(); + /* Set console output codepage to UTF8. Only works + * correctly when the console uses a truetype font. */ + SetConsoleOutputCP(65001); + atexit(debug_exit); +} +#else +void debug_init(void) +{ + /* nothing to be done */ +} +#endif + +void debugf(const char *fmt, ...) +{ + va_list ap; + va_start( ap, fmt ); + vfprintf( stderr, fmt, ap ); + va_end( ap ); +} + +void ldebugf(const char* file, int line, const char *fmt, ...) +{ + va_list ap; + va_start( ap, fmt ); + fprintf( stderr, "%s:%d ", file, line ); + vfprintf( stderr, fmt, ap ); + va_end( ap ); +} diff --git a/uisimulator/common/io.c b/uisimulator/common/io.c index 02542d15e3..1df36d3b34 100644 --- a/uisimulator/common/io.c +++ b/uisimulator/common/io.c @@ -608,46 +608,6 @@ void lc_close(void *handle) } #endif /* __PCTOOL__ */ -#ifdef WIN32 -static unsigned old_cp; - -void debug_exit(void) -{ - /* Reset console output codepage */ - SetConsoleOutputCP(old_cp); -} - -void debug_init(void) -{ - old_cp = GetConsoleOutputCP(); - /* Set console output codepage to UTF8. Only works - * correctly when the console uses a truetype font. */ - SetConsoleOutputCP(65001); - atexit(debug_exit); -} -#else -void debug_init(void) -{ - /* nothing to be done */ -} -#endif - -void debugf(const char *fmt, ...) -{ - va_list ap; - va_start( ap, fmt ); - vfprintf( stderr, fmt, ap ); - va_end( ap ); -} - -void ldebugf(const char* file, int line, const char *fmt, ...) -{ - va_list ap; - va_start( ap, fmt ); - fprintf( stderr, "%s:%d ", file, line ); - vfprintf( stderr, fmt, ap ); - va_end( ap ); -} /* rockbox off_t may be different from system off_t */ int sim_ftruncate(int fd, long length) -- cgit v1.2.3