1bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo/* Copyright (c) 2011, The Linux Foundation. All rights reserved.
234ee09551764b045fdc02df754157473125edf60Kevin Tang *
334ee09551764b045fdc02df754157473125edf60Kevin Tang * Redistribution and use in source and binary forms, with or without
434ee09551764b045fdc02df754157473125edf60Kevin Tang * modification, are permitted provided that the following conditions are
534ee09551764b045fdc02df754157473125edf60Kevin Tang * met:
634ee09551764b045fdc02df754157473125edf60Kevin Tang *     * Redistributions of source code must retain the above copyright
734ee09551764b045fdc02df754157473125edf60Kevin Tang *       notice, this list of conditions and the following disclaimer.
834ee09551764b045fdc02df754157473125edf60Kevin Tang *     * Redistributions in binary form must reproduce the above
934ee09551764b045fdc02df754157473125edf60Kevin Tang *       copyright notice, this list of conditions and the following
1034ee09551764b045fdc02df754157473125edf60Kevin Tang *       disclaimer in the documentation and/or other materials provided
1134ee09551764b045fdc02df754157473125edf60Kevin Tang *       with the distribution.
12bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo *     * Neither the name of The Linux Foundation nor the names of its
1334ee09551764b045fdc02df754157473125edf60Kevin Tang *       contributors may be used to endorse or promote products derived
1434ee09551764b045fdc02df754157473125edf60Kevin Tang *       from this software without specific prior written permission.
1534ee09551764b045fdc02df754157473125edf60Kevin Tang *
1634ee09551764b045fdc02df754157473125edf60Kevin Tang * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
1734ee09551764b045fdc02df754157473125edf60Kevin Tang * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
1834ee09551764b045fdc02df754157473125edf60Kevin Tang * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
1934ee09551764b045fdc02df754157473125edf60Kevin Tang * ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
2034ee09551764b045fdc02df754157473125edf60Kevin Tang * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
2134ee09551764b045fdc02df754157473125edf60Kevin Tang * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
2234ee09551764b045fdc02df754157473125edf60Kevin Tang * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
2334ee09551764b045fdc02df754157473125edf60Kevin Tang * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
2434ee09551764b045fdc02df754157473125edf60Kevin Tang * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
2534ee09551764b045fdc02df754157473125edf60Kevin Tang * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
2634ee09551764b045fdc02df754157473125edf60Kevin Tang * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
2734ee09551764b045fdc02df754157473125edf60Kevin Tang */
28bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo
29bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo#ifndef DEBUG_H
30bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo#define DEBUG_H
31bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo
32bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo#include <stdio.h>
33bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo
34bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo#define LOG_TAG "LocSvc_rpc"
35bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo#include <utils/Log.h>
36bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo
37bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo#define PRINT(x...) do {                                    \
38bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo        fprintf(stdout, "%s(%d) ", __FUNCTION__, __LINE__); \
39bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo        fprintf(stdout, ##x);                               \
40bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo        ALOGD(x);                               \
41bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo    } while(0)
42bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo
43bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo#ifdef DEBUG
44bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo#define D PRINT
45bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo#else
46bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo#define D(x...) do { } while(0)
47bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo#endif
48bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo
49bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo#ifdef VERBOSE
50bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo#define V PRINT
51bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo#else
52bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo#define V(x...) do { } while(0)
53bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo#endif
54bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo
55bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo#define E(x...) do {                                        \
56bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo        fprintf(stderr, "%s(%d) ", __FUNCTION__, __LINE__); \
57bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo        fprintf(stderr, ##x);                               \
58bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo        ALOGE(x);                                            \
59bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo    } while(0)
60bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo
61bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo#define FAILIF(cond, msg...) do {                                              \
62bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo        if (__builtin_expect (cond, 0)) {                                      \
63bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo            fprintf(stderr, "%s:%s:(%d): ", __FILE__, __FUNCTION__, __LINE__); \
64bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo            fprintf(stderr, ##msg);                                            \
65bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo            ALOGE(##msg);                                                       \
66bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo        }                                                                      \
67bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo    } while(0)
68bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo
69bfff6343845ad9ff062c5fd97bb3b9be1053340eDante Russo#endif/*DEBUG_H*/
70