![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /proc/self/root/opt/rh/gcc-toolset-11/root/usr/share/systemtap/tapset/ |
// logging tapset // Copyright (C) 2005-2019 Red Hat Inc. // // This file is part of systemtap, and is free software. You can // redistribute it and/or modify it under the terms of the GNU General // Public License (GPL); either version 2, or (at your option) any // later version. /** * sfunction log - Send a line to the common trace buffer * * @msg: The formatted message string * * Description: This function logs data. log sends the * message immediately to staprun and to the bulk transport * (relayfs) if it is being used. If the last character given * is not a newline, then one is added. This function is not * as efficient as printf and should be used only for urgent * messages. */ function log (msg:string) %( runtime != "bpf" %? %{ /* unprivileged */ /* unmodified-fnargs */ STAP_PRINTF ("%s\n", STAP_ARG_msg); %} %: { /* unprivileged */ /* bpf */ printf("%s\n", msg) } %) /** * sfunction warn - Send a line to the warning stream * * @msg: The formatted message string * * Description: This function sends a warning message immediately to * staprun. It is also sent over the bulk transport (relayfs) if it is * being used. If the last characater is not a newline, the one is added. */ function warn (msg:string) %( runtime != "bpf" %? %{ /* unprivileged */ /* unmodified-fnargs */ _stp_warn ("%s", STAP_ARG_msg); %} %: { /* unprivileged */ /* bpf */ // TODO: _stp_warn intelligently determines whether msg has a newline printf("WARNING: %s\n", msg) } %) /** * sfunction exit - Start shutting down probing script. * * Description: This only enqueues a request to start * shutting down the script. New probes will not fire * (except "end" probes), but all currently * running ones may complete their work. */ function exit () %( runtime != "bpf" %? %{ /* unprivileged */ atomic_set (session_state(), STAP_SESSION_STOPPING); _stp_exit (); %} %: { /* unprivileged */ /* bpf */ _set_exit_status() _send_exit_msg() } %) %(systemtap_v >= "4.0" %? /** * sfunction abort - Immediately shutting down probing script. * * Description: This is similar to exit() but immediately aborts * the current probe handler instead of waiting for its * completion. Probe handlers already running on *other* CPU cores, * however, will still continue to their completion. Unlike error(), * this function call cannot be caught by 'try ... catch'. */ function abort () %( runtime != "bpf" %? %{ /* unprivileged */ atomic_set (session_state(), STAP_SESSION_STOPPING); _stp_exit (); CONTEXT->aborted = 1; CONTEXT->last_stmt = NULL; %} %: { /* unprivileged */ /* bpf */ printf("ERROR: abort() not supported in eBPF backend\n") exit() /* TODO: need to abort the execution flow immediately -- consider using terminate statement */ } %) %) /** * sfunction error - Send an error message * * @msg: The formatted message string * * Description: An implicit end-of-line is added. staprun prepends * the string "ERROR:". Sending an error message aborts the currently * running probe. Depending on the MAXERRORS parameter, it may * trigger an exit(). */ function error (msg:string) %( runtime != "bpf" %? %{ /* unprivileged */ /* unmodified-fnargs */ /* NB: we used to reuse msg[] for an assignment to last_error; this is clearer & safer. */ strlcpy (CONTEXT->error_buffer, STAP_ARG_msg, MAXSTRINGLEN); CONTEXT->last_error = CONTEXT->error_buffer; CONTEXT->last_stmt = NULL; %} %: { /* unprivileged */ /* bpf */ // If error is called within a try block, the instruction flow // will switch to the corresponding catch block. _jump_to_catch(msg) // Execution will reach here if error was called outside a try // block. In this case, the error message will be stored for // printing and the error status will be set. _register_error(msg) // Short-circuit the program to its exit. _terminate() } %) /** * sfunction assert - evaluate assertion * * @expression: The expression to evaluate * * Description: This function checks the expression and aborts the * current running probe if expression evaluates to zero. Uses error() * and may be caught by try{} catch{}. A default message will be * displayed. */ function assert(expression:long) { /* bpf */ /* unprivileged */ if (!expression) { error("Assertion failed") } } /** * sfunction assert - evaluate assertion * * @expression: The expression to evaluate * @msg: The formatted message string * * Description: This function checks the expression and aborts the * current running probe if expression evaluates to zero. Uses error() * and may be caught by try{} catch{}. The specified message will be * displayed. */ function assert(expression:long, msg:string) { /* bpf */ /* unprivileged */ if (!expression) { error(msg) } } function stp_print_binary(n:long, arg1:long, arg2:long, arg3:long, arg4:long) %{ _stp_print_binary (STAP_ARG_n, STAP_ARG_arg1, STAP_ARG_arg2, STAP_ARG_arg3, STAP_ARG_arg4); %}