1*3c7ae9deSAndroid Build Coastguard Worker /**
2*3c7ae9deSAndroid Build Coastguard Worker * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
3*3c7ae9deSAndroid Build Coastguard Worker * SPDX-License-Identifier: Apache-2.0.
4*3c7ae9deSAndroid Build Coastguard Worker */
5*3c7ae9deSAndroid Build Coastguard Worker
6*3c7ae9deSAndroid Build Coastguard Worker #include <aws/common/logging.h>
7*3c7ae9deSAndroid Build Coastguard Worker
8*3c7ae9deSAndroid Build Coastguard Worker #include "crt.h"
9*3c7ae9deSAndroid Build Coastguard Worker #include "java_class_ids.h"
10*3c7ae9deSAndroid Build Coastguard Worker #include "logging.h"
11*3c7ae9deSAndroid Build Coastguard Worker
12*3c7ae9deSAndroid Build Coastguard Worker /* on 32-bit platforms, casting pointers to longs throws a warning we don't need */
13*3c7ae9deSAndroid Build Coastguard Worker #if UINTPTR_MAX == 0xffffffff
14*3c7ae9deSAndroid Build Coastguard Worker # if defined(_MSC_VER)
15*3c7ae9deSAndroid Build Coastguard Worker # pragma warning(push)
16*3c7ae9deSAndroid Build Coastguard Worker # pragma warning(disable : 4305) /* 'type cast': truncation from 'jlong' to 'jni_tls_ctx_options *' */
17*3c7ae9deSAndroid Build Coastguard Worker # else
18*3c7ae9deSAndroid Build Coastguard Worker # pragma GCC diagnostic push
19*3c7ae9deSAndroid Build Coastguard Worker # pragma GCC diagnostic ignored "-Wpointer-to-int-cast"
20*3c7ae9deSAndroid Build Coastguard Worker # pragma GCC diagnostic ignored "-Wint-to-pointer-cast"
21*3c7ae9deSAndroid Build Coastguard Worker # endif
22*3c7ae9deSAndroid Build Coastguard Worker #endif
23*3c7ae9deSAndroid Build Coastguard Worker
24*3c7ae9deSAndroid Build Coastguard Worker #if _MSC_VER
25*3c7ae9deSAndroid Build Coastguard Worker # pragma warning(disable : 4204) /* non-constant aggregate initializer */
26*3c7ae9deSAndroid Build Coastguard Worker #endif
27*3c7ae9deSAndroid Build Coastguard Worker
28*3c7ae9deSAndroid Build Coastguard Worker JNIEXPORT
Java_software_amazon_awssdk_crt_Log_log(JNIEnv * env,jclass jni_class,jint jni_level,jint jni_subject,jstring jni_logstring)29*3c7ae9deSAndroid Build Coastguard Worker void JNICALL Java_software_amazon_awssdk_crt_Log_log(
30*3c7ae9deSAndroid Build Coastguard Worker JNIEnv *env,
31*3c7ae9deSAndroid Build Coastguard Worker jclass jni_class,
32*3c7ae9deSAndroid Build Coastguard Worker jint jni_level,
33*3c7ae9deSAndroid Build Coastguard Worker jint jni_subject,
34*3c7ae9deSAndroid Build Coastguard Worker jstring jni_logstring) {
35*3c7ae9deSAndroid Build Coastguard Worker (void)jni_class;
36*3c7ae9deSAndroid Build Coastguard Worker aws_cache_jni_ids(env);
37*3c7ae9deSAndroid Build Coastguard Worker
38*3c7ae9deSAndroid Build Coastguard Worker const char *raw_string = (*env)->GetStringUTFChars(env, jni_logstring, NULL);
39*3c7ae9deSAndroid Build Coastguard Worker AWS_LOGF((enum aws_log_level)jni_level, jni_subject, "%s", raw_string);
40*3c7ae9deSAndroid Build Coastguard Worker (*env)->ReleaseStringUTFChars(env, jni_logstring, raw_string);
41*3c7ae9deSAndroid Build Coastguard Worker }
42*3c7ae9deSAndroid Build Coastguard Worker
43*3c7ae9deSAndroid Build Coastguard Worker static struct aws_logger s_logger;
44*3c7ae9deSAndroid Build Coastguard Worker static bool s_initialized_logger = false;
45*3c7ae9deSAndroid Build Coastguard Worker
46*3c7ae9deSAndroid Build Coastguard Worker extern int g_memory_tracing;
47*3c7ae9deSAndroid Build Coastguard Worker
s_aws_init_logging_internal(JNIEnv * env,struct aws_logger_standard_options * options)48*3c7ae9deSAndroid Build Coastguard Worker static void s_aws_init_logging_internal(JNIEnv *env, struct aws_logger_standard_options *options) {
49*3c7ae9deSAndroid Build Coastguard Worker /* Clean up logger, in case it was already initialized */
50*3c7ae9deSAndroid Build Coastguard Worker aws_jni_cleanup_logging();
51*3c7ae9deSAndroid Build Coastguard Worker
52*3c7ae9deSAndroid Build Coastguard Worker /* NOT using aws_jni_get_allocator to avoid trace leak outside the test */
53*3c7ae9deSAndroid Build Coastguard Worker struct aws_allocator *allocator = aws_default_allocator();
54*3c7ae9deSAndroid Build Coastguard Worker
55*3c7ae9deSAndroid Build Coastguard Worker if (g_memory_tracing == 0) {
56*3c7ae9deSAndroid Build Coastguard Worker if (aws_logger_init_standard(&s_logger, allocator, options)) {
57*3c7ae9deSAndroid Build Coastguard Worker aws_jni_throw_runtime_exception(env, "Failed to initialize standard logger");
58*3c7ae9deSAndroid Build Coastguard Worker return;
59*3c7ae9deSAndroid Build Coastguard Worker }
60*3c7ae9deSAndroid Build Coastguard Worker } else {
61*3c7ae9deSAndroid Build Coastguard Worker if (aws_logger_init_noalloc(&s_logger, allocator, options)) {
62*3c7ae9deSAndroid Build Coastguard Worker aws_jni_throw_runtime_exception(env, "Failed to initialize no-alloc logger");
63*3c7ae9deSAndroid Build Coastguard Worker return;
64*3c7ae9deSAndroid Build Coastguard Worker }
65*3c7ae9deSAndroid Build Coastguard Worker }
66*3c7ae9deSAndroid Build Coastguard Worker
67*3c7ae9deSAndroid Build Coastguard Worker aws_logger_set(&s_logger);
68*3c7ae9deSAndroid Build Coastguard Worker s_initialized_logger = true;
69*3c7ae9deSAndroid Build Coastguard Worker }
70*3c7ae9deSAndroid Build Coastguard Worker
71*3c7ae9deSAndroid Build Coastguard Worker JNIEXPORT
Java_software_amazon_awssdk_crt_Log_initLoggingToStdout(JNIEnv * env,jclass jni_crt_class,jint level)72*3c7ae9deSAndroid Build Coastguard Worker void JNICALL Java_software_amazon_awssdk_crt_Log_initLoggingToStdout(JNIEnv *env, jclass jni_crt_class, jint level) {
73*3c7ae9deSAndroid Build Coastguard Worker (void)jni_crt_class;
74*3c7ae9deSAndroid Build Coastguard Worker aws_cache_jni_ids(env);
75*3c7ae9deSAndroid Build Coastguard Worker
76*3c7ae9deSAndroid Build Coastguard Worker struct aws_logger_standard_options log_options = {.level = level, .file = stdout};
77*3c7ae9deSAndroid Build Coastguard Worker
78*3c7ae9deSAndroid Build Coastguard Worker s_aws_init_logging_internal(env, &log_options);
79*3c7ae9deSAndroid Build Coastguard Worker }
80*3c7ae9deSAndroid Build Coastguard Worker
81*3c7ae9deSAndroid Build Coastguard Worker JNIEXPORT
Java_software_amazon_awssdk_crt_Log_initLoggingToStderr(JNIEnv * env,jclass jni_crt_class,jint level)82*3c7ae9deSAndroid Build Coastguard Worker void JNICALL Java_software_amazon_awssdk_crt_Log_initLoggingToStderr(JNIEnv *env, jclass jni_crt_class, jint level) {
83*3c7ae9deSAndroid Build Coastguard Worker (void)jni_crt_class;
84*3c7ae9deSAndroid Build Coastguard Worker aws_cache_jni_ids(env);
85*3c7ae9deSAndroid Build Coastguard Worker
86*3c7ae9deSAndroid Build Coastguard Worker struct aws_logger_standard_options log_options = {.level = level, .file = stderr};
87*3c7ae9deSAndroid Build Coastguard Worker
88*3c7ae9deSAndroid Build Coastguard Worker s_aws_init_logging_internal(env, &log_options);
89*3c7ae9deSAndroid Build Coastguard Worker }
90*3c7ae9deSAndroid Build Coastguard Worker
91*3c7ae9deSAndroid Build Coastguard Worker JNIEXPORT
Java_software_amazon_awssdk_crt_Log_initLoggingToFile(JNIEnv * env,jclass jni_crt_class,jint level,jstring jni_filename)92*3c7ae9deSAndroid Build Coastguard Worker void JNICALL Java_software_amazon_awssdk_crt_Log_initLoggingToFile(
93*3c7ae9deSAndroid Build Coastguard Worker JNIEnv *env,
94*3c7ae9deSAndroid Build Coastguard Worker jclass jni_crt_class,
95*3c7ae9deSAndroid Build Coastguard Worker jint level,
96*3c7ae9deSAndroid Build Coastguard Worker jstring jni_filename) {
97*3c7ae9deSAndroid Build Coastguard Worker (void)jni_crt_class;
98*3c7ae9deSAndroid Build Coastguard Worker aws_cache_jni_ids(env);
99*3c7ae9deSAndroid Build Coastguard Worker
100*3c7ae9deSAndroid Build Coastguard Worker const char *filename = (*env)->GetStringUTFChars(env, jni_filename, NULL);
101*3c7ae9deSAndroid Build Coastguard Worker struct aws_logger_standard_options log_options = {.level = level, .filename = filename};
102*3c7ae9deSAndroid Build Coastguard Worker s_aws_init_logging_internal(env, &log_options);
103*3c7ae9deSAndroid Build Coastguard Worker (*env)->ReleaseStringUTFChars(env, jni_filename, filename);
104*3c7ae9deSAndroid Build Coastguard Worker }
105*3c7ae9deSAndroid Build Coastguard Worker
aws_jni_cleanup_logging(void)106*3c7ae9deSAndroid Build Coastguard Worker void aws_jni_cleanup_logging(void) {
107*3c7ae9deSAndroid Build Coastguard Worker if (aws_logger_get() == &s_logger) {
108*3c7ae9deSAndroid Build Coastguard Worker aws_logger_set(NULL);
109*3c7ae9deSAndroid Build Coastguard Worker }
110*3c7ae9deSAndroid Build Coastguard Worker
111*3c7ae9deSAndroid Build Coastguard Worker if (s_initialized_logger) {
112*3c7ae9deSAndroid Build Coastguard Worker aws_logger_clean_up(&s_logger);
113*3c7ae9deSAndroid Build Coastguard Worker s_initialized_logger = false;
114*3c7ae9deSAndroid Build Coastguard Worker }
115*3c7ae9deSAndroid Build Coastguard Worker }
116*3c7ae9deSAndroid Build Coastguard Worker
117*3c7ae9deSAndroid Build Coastguard Worker #if UINTPTR_MAX == 0xffffffff
118*3c7ae9deSAndroid Build Coastguard Worker # if defined(_MSC_VER)
119*3c7ae9deSAndroid Build Coastguard Worker # pragma warning(pop)
120*3c7ae9deSAndroid Build Coastguard Worker # else
121*3c7ae9deSAndroid Build Coastguard Worker # pragma GCC diagnostic pop
122*3c7ae9deSAndroid Build Coastguard Worker # endif
123*3c7ae9deSAndroid Build Coastguard Worker #endif
124