18c2d3d5afc51d3f35150f748f263870367771b6fEd Tam/* Copyright (c) 2011, The Linux Foundation. All rights reserved. 28c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * 38c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * Redistribution and use in source and binary forms, with or without 48c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * modification, are permitted provided that the following conditions are 58c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * met: 68c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * * Redistributions of source code must retain the above copyright 78c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * notice, this list of conditions and the following disclaimer. 88c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * * Redistributions in binary form must reproduce the above 98c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * copyright notice, this list of conditions and the following 108c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * disclaimer in the documentation and/or other materials provided 118c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * with the distribution. 128c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * * Neither the name of The Linux Foundation nor the names of its 138c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * contributors may be used to endorse or promote products derived 148c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * from this software without specific prior written permission. 158c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * 168c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED 178c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF 188c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT 198c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS 208c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 218c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 228c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR 238c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 248c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE 258c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN 268c2d3d5afc51d3f35150f748f263870367771b6fEd Tam * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 278c2d3d5afc51d3f35150f748f263870367771b6fEd Tam */ 288c2d3d5afc51d3f35150f748f263870367771b6fEd Tam 298c2d3d5afc51d3f35150f748f263870367771b6fEd Tam#ifndef DEBUG_H 308c2d3d5afc51d3f35150f748f263870367771b6fEd Tam#define DEBUG_H 318c2d3d5afc51d3f35150f748f263870367771b6fEd Tam 328c2d3d5afc51d3f35150f748f263870367771b6fEd Tam#include <stdio.h> 338c2d3d5afc51d3f35150f748f263870367771b6fEd Tam 348c2d3d5afc51d3f35150f748f263870367771b6fEd Tam#define LOG_TAG "LocSvc_rpc" 358c2d3d5afc51d3f35150f748f263870367771b6fEd Tam#include <utils/Log.h> 368c2d3d5afc51d3f35150f748f263870367771b6fEd Tam 378c2d3d5afc51d3f35150f748f263870367771b6fEd Tam#define PRINT(x...) do { \ 388c2d3d5afc51d3f35150f748f263870367771b6fEd Tam fprintf(stdout, "%s(%d) ", __FUNCTION__, __LINE__); \ 398c2d3d5afc51d3f35150f748f263870367771b6fEd Tam fprintf(stdout, ##x); \ 408c2d3d5afc51d3f35150f748f263870367771b6fEd Tam ALOGD(x); \ 418c2d3d5afc51d3f35150f748f263870367771b6fEd Tam } while(0) 428c2d3d5afc51d3f35150f748f263870367771b6fEd Tam 438c2d3d5afc51d3f35150f748f263870367771b6fEd Tam#ifdef DEBUG 448c2d3d5afc51d3f35150f748f263870367771b6fEd Tam#define D PRINT 458c2d3d5afc51d3f35150f748f263870367771b6fEd Tam#else 468c2d3d5afc51d3f35150f748f263870367771b6fEd Tam#define D(x...) do { } while(0) 478c2d3d5afc51d3f35150f748f263870367771b6fEd Tam#endif 488c2d3d5afc51d3f35150f748f263870367771b6fEd Tam 498c2d3d5afc51d3f35150f748f263870367771b6fEd Tam#ifdef VERBOSE 508c2d3d5afc51d3f35150f748f263870367771b6fEd Tam#define V PRINT 518c2d3d5afc51d3f35150f748f263870367771b6fEd Tam#else 528c2d3d5afc51d3f35150f748f263870367771b6fEd Tam#define V(x...) do { } while(0) 538c2d3d5afc51d3f35150f748f263870367771b6fEd Tam#endif 548c2d3d5afc51d3f35150f748f263870367771b6fEd Tam 558c2d3d5afc51d3f35150f748f263870367771b6fEd Tam#define E(x...) do { \ 568c2d3d5afc51d3f35150f748f263870367771b6fEd Tam fprintf(stderr, "%s(%d) ", __FUNCTION__, __LINE__); \ 578c2d3d5afc51d3f35150f748f263870367771b6fEd Tam fprintf(stderr, ##x); \ 588c2d3d5afc51d3f35150f748f263870367771b6fEd Tam ALOGE(x); \ 598c2d3d5afc51d3f35150f748f263870367771b6fEd Tam } while(0) 608c2d3d5afc51d3f35150f748f263870367771b6fEd Tam 618c2d3d5afc51d3f35150f748f263870367771b6fEd Tam#define FAILIF(cond, msg...) do { \ 628c2d3d5afc51d3f35150f748f263870367771b6fEd Tam if (__builtin_expect (cond, 0)) { \ 638c2d3d5afc51d3f35150f748f263870367771b6fEd Tam fprintf(stderr, "%s:%s:(%d): ", __FILE__, __FUNCTION__, __LINE__); \ 648c2d3d5afc51d3f35150f748f263870367771b6fEd Tam fprintf(stderr, ##msg); \ 658c2d3d5afc51d3f35150f748f263870367771b6fEd Tam ALOGE(##msg); \ 668c2d3d5afc51d3f35150f748f263870367771b6fEd Tam } \ 678c2d3d5afc51d3f35150f748f263870367771b6fEd Tam } while(0) 688c2d3d5afc51d3f35150f748f263870367771b6fEd Tam 698c2d3d5afc51d3f35150f748f263870367771b6fEd Tam#endif/*DEBUG_H*/ 70