]> granicus.if.org Git - sysstat/blobdiff - sa.h
sar/sadc: Add stable identifier support for disks statistics
[sysstat] / sa.h
diff --git a/sa.h b/sa.h
index 88315ce646aa0c1a85ff3483c3f869ccc22e17a0..3082485bb0d323d17baa15ce0779ff2b5638ba62 100644 (file)
--- a/sa.h
+++ b/sa.h
@@ -1,6 +1,6 @@
 /*
  * sar/sadc: Report system activity
- * (C) 1999-2017 by Sebastien Godard (sysstat <at> orange.fr)
+ * (C) 1999-2019 by Sebastien Godard (sysstat <at> orange.fr)
  */
 
 #ifndef _SA_H
 #define A_NET_ICMP6    27
 #define A_NET_EICMP6   28
 #define A_NET_UDP6     29
-#define A_PWR_CPUFREQ  30
+#define A_PWR_CPU      30
 #define A_PWR_FAN      31
 #define A_PWR_TEMP     32
 #define A_PWR_IN       33
 #define A_HUGE         34
-#define A_PWR_WGHFREQ  35
+#define A_PWR_FREQ     35
 #define A_PWR_USB      36
-#define A_FILESYSTEM   37
+#define A_FS           37
 #define A_NET_FC       38
 #define A_NET_SOFT     39
 
@@ -82,7 +82,8 @@
  */
 
 #define S_F_SINCE_BOOT         0x00000001
-#define S_F_SA_ROTAT           0x00000002
+#define S_F_SA_ROTAT           0x00000002      /* Only used by sadc */
+#define S_F_DEV_SID            0x00000002      /* Only used by sar/sadf */
 #define S_F_DEV_PRETTY         0x00000004
 #define S_F_FORCE_FILE         0x00000008
 #define S_F_INTERVAL_SET       0x00000010
 #define S_F_PREFD_TIME_OUTPUT  0x00008000
 #define S_F_SVG_SKIP           0x00010000
 /* Same value as S_F_SVG_SKIP above. Used for a different output format */
-#define S_F_RAW_SHOW_HINTS     0x00010000
+#define S_F_RAW_DEBUG_MODE     0x00010000
 #define S_F_SVG_AUTOSCALE      0x00020000
 #define S_F_SVG_ONE_DAY                0x00040000
 #define S_F_SVG_SHOW_IDLE      0x00080000
 #define S_F_SVG_HEIGHT         0x00200000
 #define S_F_SVG_PACKED         0x00400000
 #define S_F_SVG_SHOW_INFO      0x00800000
+#define S_F_HUMAN_READ         0x01000000
+#define S_F_ZERO_OMIT          0x02000000
+#define S_F_SVG_SHOW_TOC       0x04000000
+#define S_F_FDATASYNC          0x08000000
+#define S_F_OPTION_A           0x10000000
+#define S_F_OPTION_P           0x20000000
+#define S_F_OPTION_I           0x40000000
 
 #define WANT_SINCE_BOOT(m)             (((m) & S_F_SINCE_BOOT)   == S_F_SINCE_BOOT)
 #define WANT_SA_ROTAT(m)               (((m) & S_F_SA_ROTAT)     == S_F_SA_ROTAT)
+#define USE_STABLE_ID(m)               (((m) & S_F_DEV_SID)      == S_F_DEV_SID)
 #define USE_PRETTY_OPTION(m)           (((m) & S_F_DEV_PRETTY)   == S_F_DEV_PRETTY)
 #define FORCE_FILE(m)                  (((m) & S_F_FORCE_FILE)   == S_F_FORCE_FILE)
 #define INTERVAL_SET(m)                        (((m) & S_F_INTERVAL_SET) == S_F_INTERVAL_SET)
 #define PRINT_LOCAL_TIME(m)            (((m) & S_F_LOCAL_TIME)   == S_F_LOCAL_TIME)
 #define USE_PREFD_TIME_OUTPUT(m)       (((m) & S_F_PREFD_TIME_OUTPUT)   == S_F_PREFD_TIME_OUTPUT)
 #define SKIP_EMPTY_VIEWS(m)            (((m) & S_F_SVG_SKIP)     == S_F_SVG_SKIP)
-#define DISPLAY_HINTS(m)               (((m) & S_F_RAW_SHOW_HINTS) == S_F_RAW_SHOW_HINTS)
+#define DISPLAY_ZERO_OMIT(m)           (((m) & S_F_ZERO_OMIT)    == S_F_ZERO_OMIT)
+#define DISPLAY_DEBUG_MODE(m)          (((m) & S_F_RAW_DEBUG_MODE) == S_F_RAW_DEBUG_MODE)
 #define AUTOSCALE_ON(m)                        (((m) & S_F_SVG_AUTOSCALE) == S_F_SVG_AUTOSCALE)
-#define DISPLAY_ONE_DAY(m)             (((m) & S_F_SVG_ONE_DAY)   == S_F_SVG_ONE_DAY)
+#define DISPLAY_ONE_DAY(m)             (((m) & S_F_SVG_ONE_DAY)  == S_F_SVG_ONE_DAY)
 #define DISPLAY_IDLE(m)                        (((m) & S_F_SVG_SHOW_IDLE) == S_F_SVG_SHOW_IDLE)
 #define DISPLAY_INFO(m)                        (((m) & S_F_SVG_SHOW_INFO) == S_F_SVG_SHOW_INFO)
-#define DISPLAY_UNIT(m)                        (((m) & S_F_UNIT) == S_F_UNIT)
-#define SET_CANVAS_HEIGHT(m)           (((m) & S_F_SVG_HEIGHT) == S_F_SVG_HEIGHT)
-#define PACK_VIEWS(m)                  (((m) & S_F_SVG_PACKED) == S_F_SVG_PACKED)
+#define DISPLAY_UNIT(m)                        (((m) & S_F_UNIT)         == S_F_UNIT)
+#define SET_CANVAS_HEIGHT(m)           (((m) & S_F_SVG_HEIGHT)   == S_F_SVG_HEIGHT)
+#define PACK_VIEWS(m)                  (((m) & S_F_SVG_PACKED)   == S_F_SVG_PACKED)
+#define DISPLAY_HUMAN_READ(m)          (((m) & S_F_HUMAN_READ)   == S_F_HUMAN_READ)
+#define DISPLAY_TOC(m)                 (((m) & S_F_SVG_SHOW_TOC) == S_F_SVG_SHOW_TOC)
+#define FDATASYNC(m)                   (((m) & S_F_FDATASYNC)    == S_F_FDATASYNC)
+#define USE_OPTION_A(m)                        (((m) & S_F_OPTION_A)     == S_F_OPTION_A)
+#define USE_OPTION_P(m)                        (((m) & S_F_OPTION_P)     == S_F_OPTION_P)
+#define USE_OPTION_I(m)                        (((m) & S_F_OPTION_I)     == S_F_OPTION_I)
 
 #define AO_F_NULL              0x00000000
 
  */
 
 /* Keywords */
-#define K_XALL         "XALL"
-#define K_SUM          "SUM"
+#define K_A_NULL       "A_NULL"
+#define K_CPU          "CPU"
 #define K_DEV          "DEV"
 #define K_EDEV         "EDEV"
-#define K_NFS          "NFS"
-#define K_NFSD         "NFSD"
-#define K_SOCK         "SOCK"
-#define K_IP           "IP"
-#define K_EIP          "EIP"
-#define K_ICMP         "ICMP"
 #define K_EICMP                "EICMP"
-#define K_TCP          "TCP"
-#define K_ETCP         "ETCP"
-#define K_UDP          "UDP"
-#define K_SOCK6                "SOCK6"
-#define K_IP6          "IP6"
-#define K_EIP6         "EIP6"
-#define K_ICMP6                "ICMP6"
 #define K_EICMP6       "EICMP6"
-#define K_UDP6         "UDP6"
-#define K_CPU          "CPU"
+#define K_EIP          "EIP"
+#define K_EIP6         "EIP6"
+#define K_ETCP         "ETCP"
 #define K_FAN          "FAN"
-#define K_TEMP         "TEMP"
-#define K_IN           "IN"
+#define K_FC           "FC"
 #define K_FREQ         "FREQ"
+#define K_ICMP         "ICMP"
+#define K_ICMP6                "ICMP6"
+#define K_IN           "IN"
+#define K_IP           "IP"
+#define K_IP6          "IP6"
 #define K_MOUNT                "MOUNT"
-#define K_FC           "FC"
+#define K_NFS          "NFS"
+#define K_NFSD         "NFSD"
+#define K_SID          "SID"
+#define K_SOCK         "SOCK"
+#define K_SOCK6                "SOCK6"
 #define K_SOFT         "SOFT"
+#define K_SUM          "SUM"
+#define K_TCP          "TCP"
+#define K_TEMP         "TEMP"
+#define K_UDP          "UDP"
+#define K_UDP6         "UDP6"
+#define K_XALL         "XALL"
 
 #define K_INT          "INT"
 #define K_DISK         "DISK"
 #define K_ONEDAY       "oneday"
 #define K_SHOWIDLE     "showidle"
 #define K_SHOWINFO     "showinfo"
-#define K_SHOWHINTS    "showhints"
+#define K_DEBUG                "debug"
 #define K_HEIGHT       "height="
 #define K_PACKED       "packed"
+#define K_SHOWTOC      "showtoc"
+#define K_CUSTOMCOL    "customcol"
+#define K_BWCOL                "bwcol"
+#define K_PCPARCHIVE   "pcparchive="
+
+/* Environment variables */
+#define ENV_COLORS_PALETTE     "S_COLORS_PALETTE"
 
 /* Groups of activities */
 #define G_DEFAULT      0x00
 #define END_OF_DATA_UNEXPECTED 1
 #define INCONSISTENT_INPUT_DATA        2
 
+#define UEOF_STOP      0
+#define UEOF_CONT      1
+
 #define CLOSE_XML_MARKUP       0
 #define OPEN_XML_MARKUP                1
 
@@ -304,6 +332,7 @@ struct svg_parm {
        unsigned long long ust_time_first;      /* Time (in seconds since the epoch) for first sample */
        int graph_no;                           /* Total number of views already displayed */
        int restart;                            /* TRUE if we have just met a RESTART record */
+       int nr_act_dispd;                       /* Number of activities that will be displayed */
        struct file_header *file_hdr;           /* Pointer on file header structure */
 };
 
@@ -311,17 +340,19 @@ struct svg_parm {
 struct svg_hdr_parm {
        int graph_nr;      /* Number of rows of views to display or canvas height entered on the command line */
        int views_per_row; /* Maximum number of views on a single row */
+       int nr_act_dispd;  /* Number of activities that will be displayed */
 };
 
 /*
  ***************************************************************************
- * Definitions of header structures.
+ * System activity data files
  *
- * The rule is: "strict writing, broad reading", meaning that sar/sadc can
+ * The rule is: "strict writing, read any", meaning that sar/sadc can
  * only append data to a datafile whose format is strictly the same as that
  * of current version (checking FORMAT_MAGIC is not enough), but sar/sadf
  * can read data from different versions, providing that FORMAT_MAGIC value
- * has not changed.
+ * has not changed (note that we are talking here of data read from a file,
+ * not data that sar reads from sadc, in which case the "strict" rule applies).
  *
  * Format of system activity data files:
  *      __
@@ -340,21 +371,37 @@ struct svg_hdr_parm {
  *     |                             |
  *     | record_header structure     |
  *     |                             |
- *     |--                         --|
- *     |(__nr_t)       * 0+          |
- *     |--                           | * <count>
+ *     |--                           |
+ *     |(__nr_t)                     |
+ *     |--                           |
+ *     |                             |
+ *     | Statistics structure(s)     | * <count>
  *     |                             |
- *     | Statistics structures...    |
+ *     |--                           |
+ *     |(__nr_t)                     |
+ *     |--                           |
+ *     |                             |
+ *     | Statistics structure(s)...  |
  *     |                             |
  *     |--                         --|
  *
- * Note: A record_header structure is followed by 0+ __nr_t values giving
- * the number of statistics structures for activities whose number of items
- * may vary (ie. activities having a positive f_count_index value).
+ * Note: For activities with varying number of items, a __nr_t value, giving
+ * the number of items, arrives before the statistics structures so that
+ * we know how many of them have to be read.
+ * NB: This value exists for all the activities even if they share the same
+ * count function (e.g. A_NET_DEV and A_NET_EDEV). Indeed, statistics are not
+ * read atomically and the number of items (e.g. network interfaces) may have
+ * varied in between.
+ *
  * If the record header's type is R_COMMENT then we find only a comment
  * following the record_header structure.
+ *
  * If the record_header's type is R_RESTART then we find only the number of CPU
  * (of type __nr_t) of the machine following the record_header structure.
+ * This number is 1 for 1 CPU and not an SMP kernel (CPU "all"),
+ * 2 for 1 CPU and SMP kernel (CPU "all" and CPU 0), etc.
+ * Of course we display the real number of CPU (e.g. "1" for 1 CPU and SMP
+ * kernel) with the LINUX RESTART message.
  ***************************************************************************
  */
 
@@ -373,8 +420,11 @@ struct svg_hdr_parm {
 #define FORMAT_MAGIC   0x2175
 #define FORMAT_MAGIC_SWAPPED   (((FORMAT_MAGIC << 8) | (FORMAT_MAGIC >> 8)) & 0xffff)
 
-/* Previous datafile format magic number used by older sysstat versions */
-#define PREVIOUS_FORMAT_MAGIC  0x2173
+/* Previous datafile format magic numbers used by older sysstat versions */
+#define FORMAT_MAGIC_2171              0x2171
+#define FORMAT_MAGIC_2171_SWAPPED      (((FORMAT_MAGIC_2171 << 8) | (FORMAT_MAGIC_2171 >> 8)) & 0xffff)
+#define FORMAT_MAGIC_2173              0x2173
+#define FORMAT_MAGIC_2173_SWAPPED      (((FORMAT_MAGIC_2173 << 8) | (FORMAT_MAGIC_2173 >> 8)) & 0xffff)
 
 /* Padding in file_magic structure. See below. */
 #define FILE_MAGIC_PADDING     48
@@ -439,8 +489,10 @@ struct file_header {
        /*
         * Number of [online or offline] CPU (1 .. CPU_NR + 1)
         * when the datafile has been created.
-        * When reading a datafile, this value is updated whenever
-        * a RESTART record is found.
+        * When reading a datafile, this value is updated (in memory)
+        * whenever a RESTART record is found.
+        * When writing or appending data to a file, this field is updated
+        * neither in file nor in memory.
         */
        unsigned int sa_cpu_nr          __attribute__ ((aligned (8)));
        /*
@@ -522,13 +574,19 @@ struct file_activity {
         */
        unsigned int magic;
        /*
-        * Number of items for this activity.
+        * Number of items for this activity
+        * when the data file has been created.
         */
        __nr_t nr;
        /*
         * Number of sub-items for this activity.
         */
        __nr_t nr2;
+       /*
+        * Set to TRUE if statistics are preceded by
+        * a value giving the number of structures to read.
+        */
+       int has_nr;
        /*
         * Size of an item structure.
         */
@@ -544,7 +602,7 @@ struct file_activity {
 #define MAX_FILE_ACTIVITY_SIZE 1024    /* Used for sanity check */
 #define FILE_ACTIVITY_ULL_NR   0       /* Nr of unsigned long long in file_activity structure */
 #define FILE_ACTIVITY_UL_NR    0       /* Nr of unsigned long in file_activity structure */
-#define FILE_ACTIVITY_U_NR     8       /* Nr of [unsigned] int in file_activity structure */
+#define FILE_ACTIVITY_U_NR     9       /* Nr of [unsigned] int in file_activity structure */
 
 
 /* Record type */
@@ -620,9 +678,19 @@ struct record_header {
  */
 #define AO_SELECTED            0x02
 /*
- * 0x04: Unused.
- * 0x08: Unused.
+ * Indicate that corresponding activity has items that need to be counted.
+ * This means that its @f_count_index values is >= 0.
+ * (We use AO_COUNTED instead of @f_count_index because @f_count_index
+ * is available (initialized) only for sadc).
+ */
+#define AO_COUNTED             0x04
+/*
+ * Indicate that activity's metrics have persistent values when devices
+ * are registered again (this means that when the device is registered again,
+ * the metrics pick the values they had when they had been unregistered).
+ * Exclusively used for CPU related statistics at the present time.
  */
+#define AO_PERSISTENT          0x08
 /*
  * This flag should be set for every activity closing a markup used
  * by several activities. Used by sadf f_xml_print() functions to
@@ -646,15 +714,30 @@ struct record_header {
  * Indicate that this activity may have sub-items.
  */
 #define AO_MATRIX              0x80
+/*
+ * Indicate that a list of devices has been entered on the command
+ * line for this activity (see options --dev=, --iface=, ...)
+ */
+#define AO_LIST_ON_CMDLINE     0x100
+/*
+ * Indicate that the number of items for this activity should always
+ * be counted, even if the activity is not collected.
+ */
+#define AO_ALWAYS_COUNTED      0x200
 
 #define IS_COLLECTED(m)                (((m) & AO_COLLECTED)        == AO_COLLECTED)
 #define IS_SELECTED(m)         (((m) & AO_SELECTED)         == AO_SELECTED)
+#define HAS_COUNT_FUNCTION(m)  (((m) & AO_COUNTED)          == AO_COUNTED)
+#define HAS_PERSISTENT_VALUES(m) (((m) & AO_PERSISTENT)      == AO_PERSISTENT)
 #define CLOSE_MARKUP(m)                (((m) & AO_CLOSE_MARKUP)     == AO_CLOSE_MARKUP)
 #define HAS_MULTIPLE_OUTPUTS(m)        (((m) & AO_MULTIPLE_OUTPUTS) == AO_MULTIPLE_OUTPUTS)
 #define ONE_GRAPH_PER_ITEM(m)  (((m) & AO_GRAPH_PER_ITEM)   == AO_GRAPH_PER_ITEM)
 #define IS_MATRIX(m)           (((m) & AO_MATRIX)           == AO_MATRIX)
+#define HAS_LIST_ON_CMDLINE(m) (((m) & AO_LIST_ON_CMDLINE)  == AO_LIST_ON_CMDLINE)
+#define ALWAYS_COUNT_ITEMS(m)  (((m) & AO_ALWAYS_COUNTED)   == AO_ALWAYS_COUNTED)
 
 #define _buf0  buf[0]
+#define _nr0   nr[0]
 
 /* Structure used to define a bitmap needed by an activity */
 struct act_bitmap {
@@ -754,6 +837,27 @@ struct activity {
         * This function is used by sadf to display activity statistics in raw format.
         */
        __print_funct_t (*f_raw_print) (struct activity *, char *, int);
+       /*
+        * This function is used by sadf to display activity statistics in PCP format.
+        */
+       __print_funct_t (*f_pcp_print) (struct activity *, int, unsigned long long,
+                                       struct record_header *);
+       /*
+        * This function is used by sadf to count the number of new items in current
+        * sample and add them to the linked list @item_list.
+        */
+       __nr_t (*f_count_new) (struct activity *, int);
+       /*
+        * Linked list containing item names. This is either all the different items
+        * found in a file for activities that have a @f_count_function() (used by sadf),
+        * or a list entered on the command line (used by sadf and sar).
+        */
+       struct sa_item *item_list;
+       /*
+        * Number of different items found in file (calculated by sadf).
+        * This is also the number of items in @item_list if this list exists.
+        */
+       __nr_t item_list_sz;
        /*
         * Header string displayed by sadf -d.
         * Header lines for each output (for activities with multiple outputs) are
@@ -762,6 +866,10 @@ struct activity {
         * (eg. -r ALL) begins with a '&' character.
         */
        char *hdr_line;
+       /*
+        * Description of activity.
+        */
+       char *desc;
        /*
         * Name of activity.
         */
@@ -788,14 +896,14 @@ struct activity {
         */
        int g_nr;
        /*
-        * Number of items on the system.
+        * Number of items on the system, as counted when the system is initialized.
         * A negative value (-1) is the default value and indicates that this number
         * has still not been calculated by the f_count() function.
         * A value of 0 means that this number has been calculated, but no items have
         * been found.
         * A positive value (>0) has either been calculated or is a constant.
         */
-       __nr_t nr;
+       __nr_t nr_ini;
        /*
         * Number of sub-items on the system.
         * @nr2 is in fact the second dimension of a matrix of items, the first
@@ -820,6 +928,16 @@ struct activity {
         * is NR2_MAX.
         */
        __nr_t nr_max;
+       /*
+        * Number of items, as read and saved in corresponding buffer (@buf: See below).
+        * The value may be zero for a particular sample if no items have been found.
+        */
+       __nr_t nr[3];
+       /*
+        * Number of structures allocated in @buf[*]. This number should be greater
+        * than or equal to @nr[*].
+        */
+       __nr_t nr_allocated;
        /*
         * Size of an item.
         * This is the size of the corresponding structure, as read from or written
@@ -914,28 +1032,36 @@ struct report_format {
         * (data displayed once at the beginning of the report).
         */
        __printf_funct_t (*f_header) (void *, int, char *, struct file_magic *, struct file_header *,
-                                     struct activity * [], unsigned int []);
+                                     struct activity * [], unsigned int [], struct file_activity *);
        /*
         * This function defines the statistics part of the report.
-        * Used only with textual (XML-like) reports.
+        * Used only with textual (XML-like) reports and PCP archives.
         */
-       __printf_funct_t (*f_statistics) (int *, int);
+       __printf_funct_t (*f_statistics) (int *, int, struct activity * [], unsigned int []);
        /*
         * This function defines the timestamp part of the report.
         * Used only with textual (XML-like) reports.
         */
        __tm_funct_t (*f_timestamp) (void *, int, char *, char *, unsigned long long,
-                                    struct file_header *, unsigned int);
+                                    struct record_header *, struct file_header *, unsigned int);
        /*
         * This function displays the restart messages.
         */
-       __printf_funct_t (*f_restart) (int *, int, char *, char *, int, struct file_header *);
+       __printf_funct_t (*f_restart) (int *, int, char *, char *, int,
+                                      struct file_header *, struct record_header *);
        /*
         * This function displays the comments.
         */
-       __printf_funct_t (*f_comment) (int *, int, char *, char *, int, char *, struct file_header *);
+       __printf_funct_t (*f_comment) (int *, int, char *, char *, int, char *,
+                                      struct file_header *, struct record_header *);
+       /*
+        * This is the main function used to display all the statistics for current format.
+        */
+       void (*f_display) (int, char *, struct file_activity *, struct file_magic *,
+                          struct tm *, void *);
 };
 
+
 /* Possible actions for functions used to display reports */
 #define F_BEGIN        0x01
 #define F_MAIN 0x02
@@ -951,6 +1077,9 @@ struct report_format {
  *   ^
  * 1 | General header
  *   v
+ *   ^
+ * 9 | One line from table of contents (if any)
+ *   v
  *   ^   ^   ^
  *   |   | 4 | Graph title
  *   |   |   v
@@ -985,13 +1114,15 @@ struct report_format {
 /* #5 */
 #define SVG_G_YSIZE    200
 /* #1 */
-#define SVG_H_YSIZE    50
+#define SVG_H_YSIZE    60
 /* #4 */
 #define SVG_M_YSIZE    50
 /* #2 */
 #define SVG_T_YSIZE    310
 /* #3 */
 #define SVG_V_YSIZE    300
+/* #9 */
+#define SVG_C_YSIZE    20
 
 /* Grid: Nr of horizontal lines */
 #define SVG_H_GRIDNR   3
@@ -1010,6 +1141,23 @@ struct report_format {
 /* Maximum number of horizontal lines for the background grid */
 #define MAX_HLINES_NR  10
 
+/* Color palette constants */
+#define SVG_COLORS_IDX_MASK    0x0f
+#define SVG_COL_PALETTE_SIZE   24
+#define SVG_COL_PALETTE_NR     3
+#define SVG_COL_BCKGRD_IDX     16
+#define SVG_COL_AXIS_IDX       17
+#define SVG_COL_GRID_IDX       18
+#define SVG_COL_TITLE_IDX      19
+#define SVG_COL_INFO_IDX       20
+#define SVG_COL_DEFAULT_IDX    21
+#define SVG_COL_HEADER_IDX     22
+#define SVG_COL_ERROR_IDX      23
+
+#define SVG_DEFAULT_COL_PALETTE        0
+#define SVG_CUSTOM_COL_PALETTE 1
+#define SVG_BW_COL_PALETTE     2
+
 #define MAYBE  0x80
 
 /*
@@ -1045,6 +1193,12 @@ struct tstamp {
        int use;
 };
 
+/* Structure for items in list */
+struct sa_item {
+       char *item_name;
+       struct sa_item *next;
+};
+
 
 /*
  ***************************************************************************
@@ -1052,6 +1206,20 @@ struct tstamp {
  ***************************************************************************
  */
 
+/*
+ * Prototypes used to count new items
+ */
+__nr_t count_new_net_dev
+       (struct activity *, int);
+__nr_t count_new_net_edev
+       (struct activity *, int);
+__nr_t count_new_filesystem
+       (struct activity *, int);
+__nr_t count_new_fchost
+       (struct activity *, int);
+__nr_t count_new_disk
+       (struct activity *, int);
+
 /* Functions used to count number of items */
 __nr_t wrap_get_cpu_nr
        (struct activity *);
@@ -1147,7 +1315,7 @@ __read_funct_t wrap_read_in
        (struct activity *);
 __read_funct_t wrap_read_meminfo_huge
        (struct activity *);
-__read_funct_t wrap_read_time_in_state
+__read_funct_t wrap_read_cpu_wghfreq
        (struct activity *);
 __read_funct_t wrap_read_bus_usb_dev
        (struct activity *);
@@ -1159,17 +1327,35 @@ __read_funct_t wrap_read_softnet
        (struct activity *);
 
 /* Other functions */
+int check_alt_sa_dir
+       (char *, int, int);
+void enum_version_nr
+       (struct file_magic *);
+int get_activity_nr
+       (struct activity * [], unsigned int, int);
+int get_activity_position
+       (struct activity * [], unsigned int, int);
+void handle_invalid_sa_file
+       (int, struct file_magic *, char *, int);
+void print_collect_error
+       (void);
+int set_default_file
+       (char *, int, int);
+int write_all
+       (int, const void *, int);
+
+#ifndef SOURCE_SADC
+int add_list_item
+       (struct sa_item **, char *, int);
 void allocate_bitmaps
        (struct activity * []);
 void allocate_structures
        (struct activity * []);
-int check_alt_sa_dir
-       (char *, int, int);
 int check_disk_reg
        (struct activity *, int, int, int);
 void check_file_actlst
-       (int *, char *, struct activity * [], struct file_magic *, struct file_header *,
-        struct file_activity **, unsigned int [], int, int *, int *);
+       (int *, char *, struct activity * [], unsigned int, struct file_magic *,
+        struct file_header *, struct file_activity **, unsigned int [], int, int *, int *);
 int check_net_dev_reg
        (struct activity *, int, int, int);
 int check_net_edev_reg
@@ -1179,33 +1365,35 @@ double compute_ifutil
 void copy_structures
        (struct activity * [], unsigned int [], struct record_header [], int, int);
 int datecmp
-       (struct tm *, struct tstamp *);
+       (struct tm *, struct tstamp *, int);
 void display_sa_file_version
        (FILE *, struct file_magic *);
-void enum_version_nr
-       (struct file_magic *);
 void free_bitmaps
        (struct activity * []);
 void free_structures
        (struct activity * []);
-int get_activity_nr
-       (struct activity * [], unsigned int, int);
-int get_activity_position
-       (struct activity * [], unsigned int, int);
 char *get_devname
        (unsigned int, unsigned int, int);
+char *get_sa_devname
+       (unsigned int, unsigned int, unsigned long long [], unsigned int, unsigned int);
 void get_file_timestamp_struct
        (unsigned int, struct tm *, struct file_header *);
+unsigned long long get_global_cpu_statistics
+       (struct activity *, int, int, unsigned int, unsigned char []);
+void get_global_soft_statistics
+       (struct activity *, int, int, unsigned int, unsigned char []);
 void get_itv_value
        (struct record_header *, struct record_header *, unsigned long long *);
-void handle_invalid_sa_file
-       (int *, struct file_magic *, char *, int);
+void init_custom_color_palette
+       (void);
 int next_slice
        (unsigned long long, unsigned long long, int, long);
+void parse_sa_devices
+       (char *, struct activity *, int, int *, int);
 int parse_sar_opt
        (char * [], int *, struct activity * [], unsigned int *, int);
 int parse_sar_I_opt
-       (char * [], int *, struct activity * []);
+       (char * [], int *, unsigned int *, struct activity * []);
 int parse_sa_P_opt
        (char * [], int *, unsigned int *, struct activity * []);
 int parse_sar_m_opt
@@ -1217,42 +1405,45 @@ int parse_timestamp
 void print_report_hdr
        (unsigned int, struct tm *, struct file_header *);
 void print_sar_comment
-       (int *, int, char *, char *, int, char *, struct file_header *);
+       (int *, int, char *, char *, int, char *, struct file_header *,
+        struct record_header *);
 __printf_funct_t print_sar_restart
-       (int *, int, char *, char *, int, struct file_header *);
+       (int *, int, char *, char *, int, struct file_header *, struct record_header *);
 int print_special_record
        (struct record_header *, unsigned int, struct tstamp *, struct tstamp *,
-        int, int, struct tm *, struct tm *, char *, int, struct file_magic *,
+        int, int, struct tm *, char *, int, struct file_magic *,
         struct file_header *, struct activity * [], struct report_format *, int, int);
-void read_file_stat_bunch
-       (struct activity * [], int, int, int, struct file_activity *, int, int);
-__nr_t read_new_cpu_nr
-       (int, char *, struct file_magic *, int, int);
+int read_file_stat_bunch
+       (struct activity * [], int, int, int, struct file_activity *, int, int,
+        char *, struct file_magic *, int);
+__nr_t read_nr_value
+       (int, char *, struct file_magic *, int, int, int);
 int read_record_hdr
-       (int, void *, struct record_header *, struct file_header *, int, int);
-void remap_struct
-       (unsigned int [], unsigned int [], void *, unsigned int);
+       (int, void *, struct record_header *, struct file_header *, int, int,
+        int, size_t);
+void reallocate_all_buffers
+       (struct activity *, __nr_t);
 void replace_nonprintable_char
        (int, char *);
 int sa_fread
-       (int, void *, int, int);
+       (int, void *, size_t, int, int);
 int sa_get_record_timestamp_struct
-       (unsigned int, struct record_header *, struct tm *, struct tm *);
+       (unsigned int, struct record_header *, struct tm *);
 int sa_open_read_magic
-       (int *, char *, struct file_magic *, int, int *);
+       (int *, char *, struct file_magic *, int, int *, int);
+int search_list_item
+       (struct sa_item *, char *);
 void select_all_activities
        (struct activity * []);
 void select_default_activity
        (struct activity * []);
-void set_bitmap
-       (unsigned char [], unsigned char, unsigned int);
-void set_default_file
-       (char *, int, int);
+void set_bitmaps
+       (struct activity * [], unsigned int *);
 void set_hdr_rectime
        (unsigned int, struct tm *, struct file_header *);
 void set_record_timestamp_string
        (unsigned int, struct record_header *, char *, char *, int, struct tm *);
 void swap_struct
        (unsigned int [], void *, int);
-
+#endif /* SOURCE_SADC undefined */
 #endif  /* _SA_H */