14035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin/* Copyright (c) 2013, 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 __PLATFORM_LIB_MACROS_H__
304035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define __PLATFORM_LIB_MACROS_H__
314035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
324035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#include <sys/time.h>
334035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
344035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define TS_PRINTF(format, x...)                                \
354035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin{                                                              \
364035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin  struct timeval tv;                                           \
374035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin  struct timezone tz;                                          \
384035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin  int hh, mm, ss;                                              \
394035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin  gettimeofday(&tv, &tz);                                      \
404035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin  hh = tv.tv_sec/3600%24;                                      \
414035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin  mm = (tv.tv_sec%3600)/60;                                    \
424035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin  ss = tv.tv_sec%60;                                           \
434035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin  fprintf(stdout,"%02d:%02d:%02d.%06ld]" format "\n", hh, mm, ss, tv.tv_usec,##x);    \
444035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin}
454035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
464035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
474035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#ifdef USE_GLIB
484035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
494035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define strlcat g_strlcat
504035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define strlcpy g_strlcpy
514035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
524035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define ALOGE(format, x...) TS_PRINTF("E/%s (%d): " format , LOG_TAG, getpid(), ##x)
534035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define ALOGW(format, x...) TS_PRINTF("W/%s (%d): " format , LOG_TAG, getpid(), ##x)
544035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define ALOGI(format, x...) TS_PRINTF("I/%s (%d): " format , LOG_TAG, getpid(), ##x)
554035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define ALOGD(format, x...) TS_PRINTF("D/%s (%d): " format , LOG_TAG, getpid(), ##x)
564035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define ALOGV(format, x...) TS_PRINTF("V/%s (%d): " format , LOG_TAG, getpid(), ##x)
574035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
584035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define GETTID_PLATFORM_LIB_ABSTRACTION (syscall(SYS_gettid))
594035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
604035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define LOC_EXT_CREATE_THREAD_CB_PLATFORM_LIB_ABSTRACTION createPthread
614035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define ELAPSED_MILLIS_SINCE_BOOT_PLATFORM_LIB_ABSTRACTION (elapsedMillisSinceBoot())
624035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
634035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
644035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#else
654035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
664035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#ifdef __cplusplus
674035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjinextern "C" {
684035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#endif
694035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjinpid_t gettid(void);
704035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
714035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#ifdef __cplusplus
724035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin}
734035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#endif
744035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
754035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define GETTID_PLATFORM_LIB_ABSTRACTION (gettid())
764035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define LOC_EXT_CREATE_THREAD_CB_PLATFORM_LIB_ABSTRACTION android::AndroidRuntime::createJavaThread
774035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#define ELAPSED_MILLIS_SINCE_BOOT_PLATFORM_LIB_ABSTRACTION  (android::elapsedRealtime())
784035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
794035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#endif
804035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin
814035be28a255eaa5605dbd9abeb2340db584249cPatrick Tjin#endif
82