xref: /aosp_15_r20/external/aws-crt-java/src/native/logging.c (revision 3c7ae9de214676c52d19f01067dc1a404272dc11)
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