14035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin/* Copyright (c) 2011, The Linux Foundation. All rights reserved.
24035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin *
34035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin * Redistribution and use in source and binary forms, with or without
44035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin * modification, are permitted provided that the following conditions are
54035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin * met:
64035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin *     * Redistributions of source code must retain the above copyright
74035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin *       notice, this list of conditions and the following disclaimer.
84035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin *     * Redistributions in binary form must reproduce the above
94035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin *       copyright notice, this list of conditions and the following
104035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin *       disclaimer in the documentation and/or other materials provided
114035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin *       with the distribution.
124035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin *     * Neither the name of The Linux Foundation nor the names of its
134035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin *       contributors may be used to endorse or promote products derived
144035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin *       from this software without specific prior written permission.
154035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin *
164035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
174035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
184035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
194035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin * ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
204035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
214035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
224035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
234035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
244035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
254035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
264035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
274035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin */
284035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
294035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#ifndef DEBUG_H
304035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define DEBUG_H
314035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
324035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#include <stdio.h>
334035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
344035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define LOG_TAG "LocSvc_rpc"
354035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#include <utils/Log.h>
364035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
374035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define PRINT(x...) do {                                    \
384035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin        fprintf(stdout, "%s(%d) ", __FUNCTION__, __LINE__); \
394035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin        fprintf(stdout, ##x);                               \
404035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin        ALOGD(x);                               \
414035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin    } while(0)
424035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
434035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#ifdef DEBUG
444035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define D PRINT
454035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#else
464035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define D(x...) do { } while(0)
474035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#endif
484035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
494035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#ifdef VERBOSE
504035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define V PRINT
514035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#else
524035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define V(x...) do { } while(0)
534035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#endif
544035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
554035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define E(x...) do {                                        \
564035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin        fprintf(stderr, "%s(%d) ", __FUNCTION__, __LINE__); \
574035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin        fprintf(stderr, ##x);                               \
584035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin        ALOGE(x);                                            \
594035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin    } while(0)
604035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
614035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define FAILIF(cond, msg...) do {                                              \
624035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin        if (__builtin_expect (cond, 0)) {                                      \
634035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin            fprintf(stderr, "%s:%s:(%d): ", __FILE__, __FUNCTION__, __LINE__); \
644035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin            fprintf(stderr, ##msg);                                            \
654035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin            ALOGE(##msg);                                                       \
664035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin        }                                                                      \
674035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin    } while(0)
684035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
694035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#endif/*DEBUG_H*/
70