2015-09-17 06:54:14 +08:00
|
|
|
//
|
|
|
|
// Copyright (C) 2008-2014 The Android Open Source Project
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
//
|
|
|
|
|
2016-03-02 05:45:42 +08:00
|
|
|
liblog_sources = [
|
|
|
|
"log_event_list.c",
|
2015-09-17 06:54:14 +08:00
|
|
|
"log_event_write.c",
|
2016-03-02 05:45:42 +08:00
|
|
|
"logger_write.c",
|
|
|
|
"config_write.c",
|
|
|
|
"logger_name.c",
|
|
|
|
"logger_lock.c",
|
2016-12-15 04:52:50 +08:00
|
|
|
"log_ratelimit.cpp",
|
2016-03-02 05:45:42 +08:00
|
|
|
]
|
|
|
|
liblog_host_sources = [
|
2015-09-17 06:54:14 +08:00
|
|
|
"fake_log_device.c",
|
2016-03-02 05:45:42 +08:00
|
|
|
"fake_writer.c",
|
2015-09-17 06:54:14 +08:00
|
|
|
]
|
|
|
|
liblog_target_sources = [
|
2016-11-22 04:00:03 +08:00
|
|
|
"event_tag_map.cpp",
|
2016-03-02 05:45:42 +08:00
|
|
|
"config_read.c",
|
2015-09-17 06:54:14 +08:00
|
|
|
"log_time.cpp",
|
2016-12-15 04:52:50 +08:00
|
|
|
"properties.c",
|
2015-09-17 06:54:14 +08:00
|
|
|
"logprint.c",
|
2016-03-02 05:45:42 +08:00
|
|
|
"pmsg_reader.c",
|
|
|
|
"pmsg_writer.c",
|
|
|
|
"logd_reader.c",
|
|
|
|
"logd_writer.c",
|
|
|
|
"logger_read.c",
|
2015-09-17 06:54:14 +08:00
|
|
|
]
|
|
|
|
|
|
|
|
// Shared and static library for host and device
|
|
|
|
// ========================================================
|
|
|
|
cc_library {
|
|
|
|
name: "liblog",
|
|
|
|
host_supported: true,
|
|
|
|
|
2016-03-02 05:45:42 +08:00
|
|
|
srcs: liblog_sources,
|
|
|
|
|
2015-09-17 06:54:14 +08:00
|
|
|
target: {
|
|
|
|
host: {
|
|
|
|
srcs: liblog_host_sources,
|
|
|
|
cflags: ["-DFAKE_LOG_DEVICE=1"],
|
|
|
|
},
|
|
|
|
android: {
|
|
|
|
srcs: liblog_target_sources,
|
|
|
|
// AddressSanitizer runtime library depends on liblog.
|
2016-04-08 04:30:22 +08:00
|
|
|
sanitize: {
|
2016-11-30 07:02:30 +08:00
|
|
|
address: false,
|
2016-04-08 04:30:22 +08:00
|
|
|
},
|
2015-09-17 06:54:14 +08:00
|
|
|
},
|
|
|
|
android_arm: {
|
2015-09-29 01:40:35 +08:00
|
|
|
// TODO: This is to work around b/24465209. Remove after root cause is fixed
|
2015-09-17 06:54:14 +08:00
|
|
|
ldflags: ["-Wl,--hash-style=both"],
|
|
|
|
},
|
|
|
|
windows: {
|
|
|
|
srcs: ["uio.c"],
|
2015-12-01 07:35:09 +08:00
|
|
|
enabled: true,
|
2015-09-17 06:54:14 +08:00
|
|
|
},
|
|
|
|
not_windows: {
|
2016-11-22 04:00:03 +08:00
|
|
|
srcs: ["event_tag_map.cpp"],
|
2015-09-17 06:54:14 +08:00
|
|
|
},
|
|
|
|
linux: {
|
|
|
|
host_ldlibs: ["-lrt"],
|
|
|
|
},
|
2016-11-30 05:39:55 +08:00
|
|
|
linux_bionic: {
|
|
|
|
enabled: true,
|
|
|
|
},
|
2015-09-17 06:54:14 +08:00
|
|
|
},
|
|
|
|
|
2017-01-26 02:52:17 +08:00
|
|
|
export_include_dirs: ["include"],
|
|
|
|
|
2015-09-17 06:54:14 +08:00
|
|
|
cflags: [
|
|
|
|
"-Werror",
|
2016-03-02 05:45:42 +08:00
|
|
|
"-fvisibility=hidden",
|
2015-09-17 06:54:14 +08:00
|
|
|
// This is what we want to do:
|
|
|
|
// liblog_cflags := $(shell \
|
|
|
|
// sed -n \
|
|
|
|
// 's/^\([0-9]*\)[ \t]*liblog[ \t].*/-DLIBLOG_LOG_TAG=\1/p' \
|
|
|
|
// $(LOCAL_PATH)/event.logtags)
|
|
|
|
// so make sure we do not regret hard-coding it as follows:
|
2016-09-13 05:51:48 +08:00
|
|
|
"-DLIBLOG_LOG_TAG=1006",
|
2016-03-26 06:50:46 +08:00
|
|
|
"-DSNET_EVENT_LOG_TAG=1397638484",
|
2015-09-17 06:54:14 +08:00
|
|
|
],
|
2016-06-02 06:32:35 +08:00
|
|
|
logtags: ["event.logtags"],
|
2015-09-17 06:54:14 +08:00
|
|
|
compile_multilib: "both",
|
|
|
|
}
|
2016-09-24 06:43:23 +08:00
|
|
|
|
2016-10-06 04:47:31 +08:00
|
|
|
// system/core/android/log.h needs some work before it can be included in the
|
|
|
|
// NDK. It defines a *lot* of macros that previously were usable names in NDK
|
|
|
|
// sources that used android/log.h. As an example, the following file defines
|
|
|
|
// LOG_TAG as a variable, but the variable name gets macro replaced if we use
|
|
|
|
// the current android/log.h.
|
|
|
|
// https://android.googlesource.com/platform/external/deqp/+/4adc1515f867b26c19c2f7498e9de93a230a234d/framework/platform/android/tcuTestLogParserJNI.cpp#41
|
|
|
|
//
|
|
|
|
// For now, we keep a copy of the old NDK android/log.h in legacy-ndk-includes.
|
|
|
|
ndk_headers {
|
|
|
|
name: "liblog_headers",
|
|
|
|
from: "legacy-ndk-includes",
|
|
|
|
to: "android",
|
|
|
|
srcs: ["legacy-ndk-includes/log.h"],
|
2016-10-21 01:18:27 +08:00
|
|
|
license: "NOTICE",
|
2016-10-06 04:47:31 +08:00
|
|
|
}
|
|
|
|
|
2017-01-26 02:52:17 +08:00
|
|
|
cc_library_headers {
|
|
|
|
name: "liblog_vndk_headers",
|
|
|
|
export_include_dirs: ["include_vndk"],
|
|
|
|
}
|
|
|
|
|
2016-09-24 06:43:23 +08:00
|
|
|
ndk_library {
|
|
|
|
name: "liblog.ndk",
|
|
|
|
symbol_file: "liblog.map.txt",
|
|
|
|
first_version: "9",
|
2017-01-06 07:55:49 +08:00
|
|
|
unversioned_until: "current",
|
2016-09-24 06:43:23 +08:00
|
|
|
}
|