runtime/transport/transport_msgs.h - systemtap

Global variables defined

Data types defined

Macros defined

Source code

/* -*- linux-c -*-
* transport_msgs.h - messages exchanged between module and userspace
*
* Copyright (C) Red Hat Inc, 2006-2011
*
* 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.
*/

/*
* NB: consider backward compatibility implications such as PR12612
* before changing existing message structures in any way.
*/

#define STP_MODULE_NAME_LEN 128
#define STP_SYMBOL_NAME_LEN 128
#define STP_TZ_NAME_LEN 64
#define STP_REMOTE_URI_LEN 128

struct _stp_trace {
    uint32_t sequence;    /* event number */
    uint32_t pdu_len;    /* length of data after this trace */
};

/* stp control channel command values */
enum
{
    /** stapio sends a STP_START after recieving a STP_TRANSPORT from
        the module. The module sends STP_START back with result of call
        systemtap_module_init() which will install all initial probes.  */
    STP_START,
    /** stapio sends STP_EXIT to signal it wants to stop the module
        itself or in response to receiving a STP_REQUEST_EXIT.
        The module sends STP_EXIT once _stp_clean_and_exit has been
        called (the first time) in reponse to a STP_EXIT or an rmmod.  */
    STP_EXIT,
    /** _stp_warn and _stp_error messages from the module.  stapio
        parses the start if the message payload string to determine
        whether it is a WARNING: or ERROR:.  */
    STP_OOB_DATA,
    /**  Send by the module (tapset/system.stp) to request stapio to
         execute a shell command with the given message payload.  */
    STP_SYSTEM,
    /** modules sends STP_TRANSPORT to stapio when ready to recieve a
        STP_START message.  stapio sends STP_BULK and then STP_START
        back.  */
    STP_TRANSPORT,
    /** Never used.  */
    STP_CONNECT,
    /** Never used.  */
    STP_DISCONNECT,
    /** Send by the staprun when initializing relayfs in response to a
        STP_TRANSPORT message with a (empty) 127 char payload.  Silently
        absorbed by module when in STP_BULKMODE (percpu files), otherwise
        returns -EINVAL to indicate bulkmode is disabled.  */
    STP_BULK,
    /** Send as first message from staprun stp_main_loop, but never
        never acted upon. Used to be initial message for message to
        start requestion symbol data (symbol data is now compiled
        into the module).  */
    STP_READY,
    /** Send by staprun at startup to notify module of where the kernel
        (_stext) and all other modules are loaded.  */
        STP_RELOCATION,
    /** Never used.  deprecated STP_TRANSPORT_VERSION == 1 **/
    STP_BUF_INFO,
    /** Never used.  */
    STP_SUBBUFS_CONSUMED,
    /** Used by the module only when STP_TRANSPORT_VERSION == 1 for
        stapio to write realtime data packet to disk.  */
    STP_REALTIME_DATA,
    /** Send by the module when it gets unloaded or STP_EXIT has been
        received by stapio.  */
    STP_REQUEST_EXIT,
    /** Send by staprun to notify module of current timezone.
            Only send once at startup.  */
        STP_TZINFO,
    /** Send by staprun to notify module of the user's privilege credentials.
            Only send once at startup.  */
        STP_PRIVILEGE_CREDENTIALS,
    /** Send by staprun to notify module of remote identity, if any.
            Only send once at startup.  */
        STP_REMOTE_ID,
    /** Max number of message types, sanity check only.  */
    STP_MAX_CMD
};

#ifdef DEBUG_TRANS
static const char *_stp_command_name[] = {
    "STP_START",
    "STP_EXIT",
    "STP_OOB_DATA",
    "STP_SYSTEM",
    "STP_TRANSPORT",
    "STP_CONNECT",
    "STP_DISCONNECT",
    "STP_BULK",
    "STP_READY",
    "STP_RELOCATION",
    "STP_BUF_INFO",
    "STP_SUBBUFS_CONSUMED",
    "STP_REALTIME_DATA",
    "STP_REQUEST_EXIT",
    "STP_TZINFO",
    "STP_PRIVILEGE_CREDENTIALS",
    "STP_REMOTE_ID",
};
#endif /* DEBUG_TRANS */

/* control channel messages */

/* command to execute: module->stapio */
struct _stp_msg_cmd
{
    char cmd[128];
};

/* Unwind data. stapio->module */
struct _stp_msg_unwind
{
    /* the module name, or "*" for all */
    char name[STP_MODULE_NAME_LEN];
    /* length of unwind data */
    uint32_t unwind_len;
    /* data ...*/
};

/* Request to start probes. */
/* stapio->module->stapio */
struct _stp_msg_start
{
    pid_t target;
        int32_t res;    // for reply: result of systemtap_module_init
};

#if STP_TRANSPORT_VERSION == 1
/**** for compatibility with old relayfs ****/
struct _stp_buf_info
{
        int32_t cpu;
        uint32_t produced;
        uint32_t consumed;
        int32_t flushing;
};
struct _stp_consumed_info
{
        int32_t cpu;
        uint32_t consumed;
};
#endif

/* Unwind data. stapio->module */
struct _stp_msg_relocation
{
    char module[STP_MODULE_NAME_LEN];
    char reloc[STP_SYMBOL_NAME_LEN];
    uint64_t address;
};

struct _stp_msg_tzinfo
{
        int64_t tz_gmtoff;
        char tz_name[STP_TZ_NAME_LEN];
};

struct _stp_msg_privilege_credentials
{
        int32_t pc_group_mask;
};

struct _stp_msg_remote_id
{
        int32_t remote_id;
        char remote_uri[STP_REMOTE_URI_LEN];
};