1/* 2 * Definitions and interface for Linux - z/VM Monitor Stream. 3 * 4 * Copyright IBM Corp. 2003, 2008 5 * 6 * Author: Gerald Schaefer <gerald.schaefer@de.ibm.com> 7 */ 8 9#define APPLDATA_MAX_REC_SIZE 4024 /* Maximum size of the */ 10 /* data buffer */ 11#define APPLDATA_MAX_PROCS 100 12 13#define APPLDATA_PROC_NAME_LENGTH 16 /* Max. length of /proc name */ 14 15#define APPLDATA_RECORD_MEM_ID 0x01 /* IDs to identify the */ 16#define APPLDATA_RECORD_OS_ID 0x02 /* individual records, */ 17#define APPLDATA_RECORD_NET_SUM_ID 0x03 /* must be < 256 ! */ 18#define APPLDATA_RECORD_PROC_ID 0x04 19 20#define CTL_APPLDATA_TIMER 2121 /* sysctl IDs, must be unique */ 21#define CTL_APPLDATA_INTERVAL 2122 22#define CTL_APPLDATA_MEM 2123 23#define CTL_APPLDATA_OS 2124 24#define CTL_APPLDATA_NET_SUM 2125 25#define CTL_APPLDATA_PROC 2126 26 27struct appldata_ops { 28 struct list_head list; 29 struct ctl_table_header *sysctl_header; 30 struct ctl_table *ctl_table; 31 int active; /* monitoring status */ 32 33 /* fill in from here */ 34 char name[APPLDATA_PROC_NAME_LENGTH]; /* name of /proc fs node */ 35 unsigned char record_nr; /* Record Nr. for Product ID */ 36 void (*callback)(void *data); /* callback function */ 37 void *data; /* record data */ 38 unsigned int size; /* size of record */ 39 struct module *owner; /* THIS_MODULE */ 40 char mod_lvl[2]; /* modification level, EBCDIC */ 41}; 42 43extern int appldata_register_ops(struct appldata_ops *ops); 44extern void appldata_unregister_ops(struct appldata_ops *ops); 45extern int appldata_diag(char record_nr, u16 function, unsigned long buffer, 46 u16 length, char *mod_lvl); 47 48