committed by
					
						
						Robert Roth
					
				
			
			
				
	
			
			
			
						parent
						
							a067db0569
						
					
				
				
					commit
					48595809ed
				
			@@ -80,7 +80,7 @@ struct _glibtop
 | 
			
		||||
	int socket;			/* Accepted connection of a socket */
 | 
			
		||||
	int ncpu;			/* Number of CPUs, zero if single-processor */
 | 
			
		||||
	int real_ncpu;			/* Real number of CPUs. Only ncpu are monitored */
 | 
			
		||||
	int ndisk;			/* Number of DISKs, zero if single-disk */
 | 
			
		||||
	int ndisk;			    /* Number of DISKs, zero if single-disk */
 | 
			
		||||
	int real_ndisk;			/* Number of PHYSICAL DISKs. Only ncpu is monitored */
 | 
			
		||||
	unsigned long os_version_code;	/* Version code of the operating system */
 | 
			
		||||
	const char *name;		/* Program name for error messages */
 | 
			
		||||
 
 | 
			
		||||
@@ -42,6 +42,14 @@ G_BEGIN_DECLS
 | 
			
		||||
 | 
			
		||||
typedef struct _glibtop_disk	glibtop_disk;
 | 
			
		||||
 | 
			
		||||
struct _partition_info
 | 
			
		||||
{
 | 
			
		||||
	char name[256];
 | 
			
		||||
	char type[256];
 | 
			
		||||
   char raid_num[256];
 | 
			
		||||
	int max;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
struct _glibtop_disk
 | 
			
		||||
{
 | 
			
		||||
	guint64 xdisk_sectors_read [GLIBTOP_NDISK];	/* GLIBTOP_XDISK_SECTORS_READ		*/
 | 
			
		||||
@@ -50,7 +58,7 @@ struct _glibtop_disk
 | 
			
		||||
	guint64 xdisk_time_write  [GLIBTOP_NDISK];	/* GLIBTOP_XDISK_TIME_WRITE		*/
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
void glibtop_get_disk(glibtop_disk *buf);
 | 
			
		||||
void glibtop_get_disk (glibtop_disk *buf);
 | 
			
		||||
 | 
			
		||||
#if GLIBTOP_SUID_DISK
 | 
			
		||||
#define glibtop_get_disk_r	glibtop_get_disk_p
 | 
			
		||||
 
 | 
			
		||||
@@ -72,9 +72,9 @@ glibtop_get_cpu(glibtop_cpu *buf)
 | 
			
		||||
 *
 | 
			
		||||
 */
 | 
			
		||||
void
 | 
			
		||||
glibtop_get_cpu(glibtop_cpu *buf)
 | 
			
		||||
glibtop_get_cpu (glibtop_cpu *buf)
 | 
			
		||||
{
 | 
			
		||||
	glibtop_get_cpu_l(glibtop_global_server, buf);
 | 
			
		||||
	glibtop_get_cpu_l (glibtop_global_server, buf);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -39,58 +39,244 @@ _glibtop_init_disk_s (glibtop *server)
 | 
			
		||||
 | 
			
		||||
/* Provides information about disk usage. */
 | 
			
		||||
 | 
			
		||||
#define FILENAME	"/proc/diskstats" //kernel reports sectors by 512 bytes even for AF 4kn
 | 
			
		||||
// Linux kernel reports sectors by 512 bytes even for AF 4kn //
 | 
			
		||||
 | 
			
		||||
#define FILENAME	"/proc/diskstats" 
 | 
			
		||||
#define CMD_PIPE    "lsblk --output NAME,TYPE -i -n | sed 's/`-//'|sed 's/|-//'|sed 's/|//'| sed -e 's/^[ \t]*//'|tr -s ' '"
 | 
			
		||||
#define STAT_BUFSIZ     81920
 | 
			
		||||
 | 
			
		||||
// Handle LVM and RAID //
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
find_primary_part (_partition_info *primary_part, const char *m)
 | 
			
		||||
{
 | 
			
		||||
	int n = 0, tlvl = 0;
 | 
			
		||||
	char name[256]="",type[256]="";
 | 
			
		||||
 | 
			
		||||
	primary_part->max = 0;
 | 
			
		||||
 | 
			
		||||
	//scan by tree level
 | 
			
		||||
	//0 = disk (to lvl 0)
 | 
			
		||||
	//0 = disk, 1 = part (to lvl 1)
 | 
			
		||||
	//0 = disk, 1 = part, 2 = lvm or raid (to lvl 2)
 | 
			
		||||
	//0 = disk, 1 = part, 2 = raid, 3 = lvm (to lvl 3)
 | 
			
		||||
 | 
			
		||||
	while (sscanf(m, "%s %s", name, type) == 2)
 | 
			
		||||
	{
 | 
			
		||||
 | 
			
		||||
		if (tlvl == 0) {
 | 
			
		||||
 | 
			
		||||
			if (strcmp (type, "disk") == 0) {
 | 
			
		||||
 | 
			
		||||
				primary_part->max++;
 | 
			
		||||
 | 
			
		||||
			}
 | 
			
		||||
			else if ((strcmp (type, "part") == 0)){
 | 
			
		||||
 | 
			
		||||
				tlvl = 1;
 | 
			
		||||
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
		}
 | 
			
		||||
		else if(tlvl == 1){
 | 
			
		||||
 | 
			
		||||
			if (strcmp (type, "disk") == 0) {
 | 
			
		||||
 | 
			
		||||
				n--;
 | 
			
		||||
				tlvl = 0;
 | 
			
		||||
				primary_part->max++;
 | 
			
		||||
 | 
			
		||||
			}
 | 
			
		||||
			else if ((strcmp (type, "part") == 0)) {
 | 
			
		||||
 | 
			
		||||
				n--;
 | 
			
		||||
 | 
			
		||||
			}
 | 
			
		||||
			else if ((strcmp (type, "lvm") == 0)) {
 | 
			
		||||
 | 
			
		||||
				tlvl = 2;
 | 
			
		||||
				primary_part->max++;
 | 
			
		||||
 | 
			
		||||
			}
 | 
			
		||||
			else if ((strncmp (type, "raid", 4) == 0)) {
 | 
			
		||||
				
 | 
			
		||||
				tlvl = 2;
 | 
			
		||||
				primary_part->max++;
 | 
			
		||||
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
		}
 | 
			
		||||
		else if( tlvl == 2){
 | 
			
		||||
 | 
			
		||||
			if (strcmp(type, "disk") == 0) {
 | 
			
		||||
 | 
			
		||||
				n--;
 | 
			
		||||
				tlvl = 0;
 | 
			
		||||
				primary_part->max++;
 | 
			
		||||
 | 
			
		||||
			}
 | 
			
		||||
			else if ((strcmp (primary_part[n-1].type, "lvm") == 0) && (strcmp (type, "lvm") == 0)) {
 | 
			
		||||
 | 
			
		||||
				n--;
 | 
			
		||||
 | 
			
		||||
			}
 | 
			
		||||
			else if ((strcmp (primary_part[n-1].type, "raid") == 0) && (strncmp (type, "raid", 4) == 0)) {
 | 
			
		||||
 | 
			
		||||
				n--;
 | 
			
		||||
 | 
			
		||||
			}
 | 
			
		||||
			else if ((strcmp (primary_part[n-1].type, "lvm") == 0) && (strcmp (type, "part") == 0)) {
 | 
			
		||||
 | 
			
		||||
				n--;
 | 
			
		||||
				tlvl = 1;
 | 
			
		||||
 | 
			
		||||
			}
 | 
			
		||||
			else if ((strcmp (primary_part[n-1].type, "raid") == 0) && (strcmp (type, "part") == 0)) {
 | 
			
		||||
 | 
			
		||||
				n--;
 | 
			
		||||
				tlvl = 1;
 | 
			
		||||
 | 
			
		||||
			}
 | 
			
		||||
			else if ((strcmp (primary_part[n-1].type, "raid") == 0) && (strcmp (type, "lvm") == 0)){
 | 
			
		||||
				
 | 
			
		||||
				tlvl = 3;
 | 
			
		||||
				primary_part->max++;
 | 
			
		||||
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
		}
 | 
			
		||||
		else if (tlvl == 3) {
 | 
			
		||||
 | 
			
		||||
			if (strcmp (type, "disk") == 0) {
 | 
			
		||||
 | 
			
		||||
				n--;
 | 
			
		||||
				tlvl = 0;
 | 
			
		||||
				primary_part->max++;
 | 
			
		||||
 | 
			
		||||
			}
 | 
			
		||||
			else if ((strcmp (type, "lvm") == 0)) {
 | 
			
		||||
 | 
			
		||||
				n--;
 | 
			
		||||
 | 
			
		||||
			}
 | 
			
		||||
			else if ((strncmp (type, "raid", 4) == 0)) {
 | 
			
		||||
 | 
			
		||||
				n--;
 | 
			
		||||
				tlvl = 2;
 | 
			
		||||
 | 
			
		||||
			}
 | 
			
		||||
			else if ((strcmp (type, "part") == 0)) {
 | 
			
		||||
 | 
			
		||||
				n--;
 | 
			
		||||
				tlvl = 1;
 | 
			
		||||
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
		strcpy (primary_part[n].name, name);
 | 
			
		||||
		strncpy (primary_part[n].type, type, 4);
 | 
			
		||||
		
 | 
			
		||||
		if (strcmp (primary_part[n].type, "raid") == 0) {
 | 
			
		||||
 | 
			
		||||
			strcpy (primary_part[n].raid_num, type + 4);
 | 
			
		||||
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		m = skip_line (m);
 | 
			
		||||
		n++;
 | 
			
		||||
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
int
 | 
			
		||||
is_virtual_drive (_partition_info *primary_part, const char *p)
 | 
			
		||||
{
 | 
			
		||||
	int i;
 | 
			
		||||
	char name[256];
 | 
			
		||||
	int test = 1;
 | 
			
		||||
	sscanf (p, "%s", name);
 | 
			
		||||
 | 
			
		||||
	if (*p) {
 | 
			
		||||
 | 
			
		||||
		for (i=0; i<primary_part->max; i++) {
 | 
			
		||||
 | 
			
		||||
			if (strcmp (primary_part[i].name, name) == 0) {
 | 
			
		||||
 | 
			
		||||
				test = 0;
 | 
			
		||||
				break;
 | 
			
		||||
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
	}
 | 
			
		||||
	else {
 | 
			
		||||
 | 
			
		||||
		test = 0;
 | 
			
		||||
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return test;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void
 | 
			
		||||
glibtop_get_disk_s (glibtop *server, glibtop_disk *buf)
 | 
			
		||||
{
 | 
			
		||||
	char buffer [STAT_BUFSIZ], *p;
 | 
			
		||||
	_partition_info primary_part[GLIBTOP_NDISK];
 | 
			
		||||
	char buffer [STAT_BUFSIZ], *p, map_buffer [STAT_BUFSIZ], *m;
 | 
			
		||||
	int i;
 | 
			
		||||
 | 
			
		||||
	memset (buf, 0, sizeof (glibtop_disk));
 | 
			
		||||
 | 
			
		||||
	file_to_buffer(server, buffer, sizeof buffer, FILENAME);
 | 
			
		||||
	file_to_buffer (server, buffer, sizeof buffer, FILENAME);
 | 
			
		||||
 | 
			
		||||
	get_from_pipe (map_buffer, CMD_PIPE);
 | 
			
		||||
 | 
			
		||||
	server->ndisk = GLIBTOP_NDISK;
 | 
			
		||||
 | 
			
		||||
	/*
 | 
			
		||||
	 * GLOBAL
 | 
			
		||||
	 */
 | 
			
		||||
 | 
			
		||||
	p = buffer;	/* "disk" */
 | 
			
		||||
	m = map_buffer;
 | 
			
		||||
 | 
			
		||||
	/*
 | 
			
		||||
	 * PER DISK
 | 
			
		||||
	 */
 | 
			
		||||
 | 
			
		||||
	find_primary_part (primary_part, m);
 | 
			
		||||
 | 
			
		||||
	for (i = 0; i <= server->ndisk; i++) {
 | 
			
		||||
 | 
			
		||||
        p = skip_multiple_token(p,2);
 | 
			
		||||
		p = skip_multiple_token (p,2);
 | 
			
		||||
 | 
			
		||||
        // skip if disk is the raw device
 | 
			
		||||
        if(!check_alphanumeric_word(p)){
 | 
			
		||||
		// skip if disk is the raw device
 | 
			
		||||
		if (!is_virtual_drive (primary_part, p)) {
 | 
			
		||||
 | 
			
		||||
		    p = skip_line(p); /* move to ^ */
 | 
			
		||||
            p = skip_multiple_token(p,2);
 | 
			
		||||
			p = skip_line (p); /* move to ^ */
 | 
			
		||||
			p = skip_multiple_token (p, 2);
 | 
			
		||||
 | 
			
		||||
        }
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		if (!check_disk_line_warn(server, p, i))
 | 
			
		||||
		if (!check_disk_line_warn (server, p, i))
 | 
			
		||||
			break;
 | 
			
		||||
 | 
			
		||||
        p = skip_token(p); /* prev xdisk_name */
 | 
			
		||||
        p = skip_token(p); /* prev xdisk_reads_completed */
 | 
			
		||||
        p = skip_token(p); /* prev xdisk_reads_merged */
 | 
			
		||||
		p = skip_token (p); /* prev xdisk_name */
 | 
			
		||||
		p = skip_token (p); /* prev xdisk_reads_completed */
 | 
			
		||||
		p = skip_token (p); /* prev xdisk_reads_merged */
 | 
			
		||||
 | 
			
		||||
		buf->xdisk_sectors_read [i] = strtoull (p, &p, 0);
 | 
			
		||||
		buf->xdisk_time_read [i] = strtoull (p, &p, 0);
 | 
			
		||||
 | 
			
		||||
        p = skip_token(p); /* prev xdisk_writes_completed */
 | 
			
		||||
        p = skip_token(p); /* prev xdisk_writes_merged */
 | 
			
		||||
		p = skip_token (p); /* prev xdisk_writes_completed */
 | 
			
		||||
		p = skip_token (p); /* prev xdisk_writes_merged */
 | 
			
		||||
 | 
			
		||||
		buf->xdisk_sectors_write  [i] = strtoull (p, &p, 0);
 | 
			
		||||
		buf->xdisk_time_write [i] = strtoull (p, &p, 0);
 | 
			
		||||
 | 
			
		||||
        p = skip_line(p); /* move to ^ */
 | 
			
		||||
		p = skip_line (p); /* move to ^ */
 | 
			
		||||
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -57,21 +57,20 @@ skip_token (const char *p)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
int
 | 
			
		||||
check_alphanumeric_word (const char *p)
 | 
			
		||||
void
 | 
			
		||||
get_from_pipe (char *buffer, const char *cmd)
 | 
			
		||||
{
 | 
			
		||||
	int test = 0;
 | 
			
		||||
	p = next_token(p);
 | 
			
		||||
	while (*p && !g_ascii_isspace(*p)) {
 | 
			
		||||
		if(g_ascii_isalpha(*p)){
 | 
			
		||||
			test = 0;
 | 
			
		||||
		}else if(g_ascii_isdigit(*p)){
 | 
			
		||||
			test = 1;
 | 
			
		||||
		}
 | 
			
		||||
		p++;
 | 
			
		||||
	};
 | 
			
		||||
	p = next_token(p);
 | 
			
		||||
	return test;
 | 
			
		||||
	FILE* fp;
 | 
			
		||||
	long psize;
 | 
			
		||||
 | 
			
		||||
	fp = popen (cmd, "r");
 | 
			
		||||
 | 
			
		||||
	fseek (fp, 0, SEEK_END);
 | 
			
		||||
	psize = ftell (fp);
 | 
			
		||||
	fseek (fp, 0, SEEK_SET);
 | 
			
		||||
	fread(buffer,1,psize,fp);
 | 
			
		||||
 | 
			
		||||
	pclose (fp);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -61,8 +61,8 @@ skip_line (const char *p)
 | 
			
		||||
	return (char *) (*p ? p+1 : p);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
int
 | 
			
		||||
check_alphanumeric_word (const char *p);
 | 
			
		||||
void
 | 
			
		||||
get_from_pipe (char *buffer, const char *cmd)
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * Smart strtoul which handles binary suffixes
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user