1
0
mirror of https://github.com/Llewellynvdm/conky.git synced 2025-01-11 18:38:45 +00:00

head/tail rewrite patch

diskio read/write patch
added check for zlib to configure script

git-svn-id: https://conky.svn.sourceforge.net/svnroot/conky/trunk/conky1@823 7f574dfc-610e-0410-a909-a81674777703
This commit is contained in:
Brenden Matthews 2006-12-29 23:14:31 +00:00
parent 39d429b508
commit 5cfe6b093d
8 changed files with 269 additions and 137 deletions

View File

@ -13,6 +13,9 @@ Alex <godexsoft at bk dot ru>
affinity <affy at users dot sourceforge dot net> affinity <affy at users dot sourceforge dot net>
X-Mozilla-Status support X-Mozilla-Status support
Blondak <blondak_nesercz at users dot sourceforge dot net>
diskio read & write patch
Bobby Beckmann <bbeckmann at users dot sourceforge dot net> Bobby Beckmann <bbeckmann at users dot sourceforge dot net>
Interface IP and Wireless Quality patch Interface IP and Wireless Quality patch
@ -165,6 +168,9 @@ Roman Bogorodskiy <novel at clublife dot ru>
FreeBSD support FreeBSD support
BMPx support BMPx support
Ryan Twitchell <tryan2 at rochester dot rr dot com>
head/tail rewrite patch
Stepan Zastupov <redchrom at gmail dot com> Stepan Zastupov <redchrom at gmail dot com>
WiFi signal level detection support on FreeBSD WiFi signal level detection support on FreeBSD

View File

@ -3,6 +3,8 @@
2006-12-29 2006-12-29
* Update svn ebuild to new sourceforge url scheme. * Update svn ebuild to new sourceforge url scheme.
- requires deletion of existing wc: rm -rf /usr/portage/distfile/svn-src/conky/ - requires deletion of existing wc: rm -rf /usr/portage/distfile/svn-src/conky/
* Added head/tail rewrite patch (thanks Ryan Twitchell)
* Added diskio read/write sf.net patch 1542880 (thanks Blondak)
2006-12-26 2006-12-26
* Clear conky vars on disconnect/failure to open files. * Clear conky vars on disconnect/failure to open files.

View File

@ -33,7 +33,7 @@ DEPEND_COMMON="
audacious? ( media-sound/audacious ) audacious? ( media-sound/audacious )
infopipe? ( media-plugins/xmms-infopipe ) infopipe? ( media-plugins/xmms-infopipe )
xmms? ( media-sound/xmms ) xmms? ( media-sound/xmms )
xmms2? ( medis-sound/xmms2 ) xmms2? ( media-sound/xmms2 )
)" )"
RDEPEND="${DEPEND_COMMON}" RDEPEND="${DEPEND_COMMON}"

View File

@ -432,6 +432,14 @@ dnl
AC_CHECK_FUNCS([calloc malloc free popen sysinfo getloadavg]) AC_CHECK_FUNCS([calloc malloc free popen sysinfo getloadavg])
AC_SEARCH_LIBS(clock_gettime, [rt], [], AC_MSG_ERROR([clock_gettime() not found])) AC_SEARCH_LIBS(clock_gettime, [rt], [], AC_MSG_ERROR([clock_gettime() not found]))
dnl
dnl Check for zlib
dnl
AC_CHECK_HEADER(zlib.h,
[],
[AC_MSG_ERROR([zlib is missing; please install the headers first])])
dnl dnl
dnl Check doc stuff dnl Check doc stuff

View File

@ -381,6 +381,44 @@
<para></para></listitem> <para></para></listitem>
</varlistentry> </varlistentry>
<varlistentry>
<term>
<command><option>diskio_read</option></command>
</term>
<listitem>
Displays current disk IO for reads.
<para></para></listitem>
</varlistentry>
<varlistentry>
<term>
<command><option>diskio_readgraph</option></command>
<option>(height),(width) (gradient colour 1) (gradient colour 2) (scale)</option>
</term>
<listitem>
Disk IO graph for reads, colours defined in hex, minus the #. If scale is non-zero, it becomes the scale for the graph.
<para></para></listitem>
</varlistentry>
<varlistentry>
<term>
<command><option>diskio_write</option></command>
</term>
<listitem>
Displays current disk IO for writes.
<para></para></listitem>
</varlistentry>
<varlistentry>
<term>
<command><option>diskio_writegraph</option></command>
<option>(height),(width) (gradient colour 1) (gradient colour 2) (scale)</option>
</term>
<listitem>
Disk IO graph for writes, colours defined in hex, minus the #. If scale is non-zero, it becomes the scale for the graph.
<para></para></listitem>
</varlistentry>
<varlistentry> <varlistentry>
<term> <term>
<command><option>downspeed</option></command> <command><option>downspeed</option></command>

View File

@ -9,13 +9,11 @@
#include "conky.h" #include "conky.h"
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include <string.h>
#include <ctype.h> #include <ctype.h>
#include <time.h> #include <time.h>
#include <locale.h> #include <locale.h>
#include <signal.h> #include <signal.h>
#include <unistd.h> #include <unistd.h>
#include <string.h>
#include <errno.h> #include <errno.h>
#include <termios.h> #include <termios.h>
#include <string.h> #include <string.h>
@ -541,53 +539,79 @@ static struct special_t *new_special(char *buf, int t)
return &specials[special_count++]; return &specials[special_count++];
} }
typedef struct tailstring_list { long fwd_fcharfind(FILE* fp, char val, unsigned int step) {
char data[TEXT_BUFFER_SIZE]; #define BUFSZ 0x1000
struct tailstring_list *next; long ret = -1;
struct tailstring_list *first; long count = 0;
} tailstring; static char buf[BUFSZ];
long orig_pos = ftell(fp);
void addtail(tailstring ** head, char *data_in) long buf_pos = -1;
{ long buf_size = BUFSZ;
tailstring *tmp; char* cur_found = NULL;
if ((tmp = malloc(sizeof(*tmp))) == NULL) { while(count < step) {
CRIT_ERR("malloc"); if(cur_found == NULL) {
} buf_size = fread(buf, 1, buf_size, fp);
if (*head == NULL) { buf_pos = 0;
tmp->first = tmp; }
} else { cur_found = memchr(buf+buf_pos, val, buf_size-buf_pos);
tmp->first = (*head)->first; if(cur_found != NULL) {
} buf_pos = cur_found-buf+1;
strncpy(tmp->data, data_in, TEXT_BUFFER_SIZE); count++;
tmp->next = *head; }
*head = tmp; else {
} if(feof(fp))
break;
void freetail(tailstring * head)
{
tailstring *tmp;
while (head != NULL) {
tmp = head->next;
free(head);
head = tmp;
}
}
void freelasttail(tailstring * head)
{
tailstring * tmp = head;
while(tmp != NULL) {
if (tmp->next == head->first) {
tmp->next = NULL;
break;
} }
tmp = tmp->next;
} }
free(head->first); if(count == step)
while(head != NULL && tmp != NULL) { ret = ftell(fp) - buf_size + buf_pos - 1;
head->first = tmp; fseek(fp, orig_pos, SEEK_SET);
head = head->next; return ret;
#undef BUFSZ
}
long rev_fcharfind(FILE* fp, char val, unsigned int step) {
#define BUFSZ 0x1000
long ret = -1;
long count = 0;
static char buf[BUFSZ];
long orig_pos = ftell(fp);
long buf_pos = -1;
long file_pos = orig_pos;
long buf_size = BUFSZ;
char* cur_found;
while(count < step) {
if(buf_pos <= 0) {
if(file_pos > BUFSZ) {
fseek(fp, file_pos-BUFSZ, SEEK_SET);
}
else {
buf_size = file_pos;
fseek(fp, 0, SEEK_SET);
}
file_pos = ftell(fp);
buf_pos = fread(buf, 1, buf_size, fp);
}
cur_found =
memrchr(
buf,
(int)val,
(size_t)buf_pos);
if(cur_found != NULL) {
buf_pos = cur_found-buf;
count++;
} else {
buf_pos = -1;
if(file_pos == 0) {
break;
}
}
} }
fseek(fp, orig_pos, SEEK_SET);
if(count == step)
ret = file_pos + buf_pos;
return ret;
#undef BUFSZ
} }
static void new_bar(char *buf, int w, int h, int usage) static void new_bar(char *buf, int w, int h, int usage)
@ -900,7 +924,11 @@ enum text_object_type {
OBJ_cpubar, OBJ_cpubar,
OBJ_cpugraph, OBJ_cpugraph,
OBJ_diskio, OBJ_diskio,
OBJ_diskio_read,
OBJ_diskio_write,
OBJ_diskiograph, OBJ_diskiograph,
OBJ_diskiograph_read,
OBJ_diskiograph_write,
OBJ_downspeed, OBJ_downspeed,
OBJ_downspeedf, OBJ_downspeedf,
OBJ_downspeedgraph, OBJ_downspeedgraph,
@ -2169,7 +2197,11 @@ static struct text_object *construct_text_object(const char *s, const char *arg,
obj->data.cpu_index = 0; obj->data.cpu_index = 0;
} }
END OBJ(diskio, INFO_DISKIO) END OBJ(diskio, INFO_DISKIO)
END OBJ(diskiograph, INFO_DISKIO) (void) scan_graph(arg, &obj->a, &obj->b, &obj->c, &obj->d, &obj->e); END OBJ(diskio_read, INFO_DISKIO)
END OBJ(diskio_write, INFO_DISKIO)
END OBJ(diskiograph, INFO_DISKIO) (void) scan_graph(arg, &obj->a, &obj->b, &obj->c, &obj->d, &obj->e);
END OBJ(diskiograph_read, INFO_DISKIO) (void) scan_graph(arg, &obj->a, &obj->b, &obj->c, &obj->d, &obj->e);
END OBJ(diskiograph_write, INFO_DISKIO) (void) scan_graph(arg, &obj->a, &obj->b, &obj->c, &obj->d, &obj->e);
END OBJ(color, 0) END OBJ(color, 0)
#ifdef X11 #ifdef X11
obj->data.l = arg ? get_x11_color(arg) : default_fg_color; obj->data.l = arg ? get_x11_color(arg) : default_fg_color;
@ -2472,7 +2504,7 @@ static struct text_object *construct_text_object(const char *s, const char *arg,
obj->data.tail.logfile = obj->data.tail.logfile =
malloc(TEXT_BUFFER_SIZE); malloc(TEXT_BUFFER_SIZE);
strcpy(obj->data.tail.logfile, buf); strcpy(obj->data.tail.logfile, buf);
obj->data.tail.wantedlines = n1 - 1; obj->data.tail.wantedlines = n1;
obj->data.tail.interval = obj->data.tail.interval =
update_interval * 2; update_interval * 2;
fclose(fp); fclose(fp);
@ -2497,7 +2529,7 @@ static struct text_object *construct_text_object(const char *s, const char *arg,
obj->data.tail.logfile = obj->data.tail.logfile =
malloc(TEXT_BUFFER_SIZE); malloc(TEXT_BUFFER_SIZE);
strcpy(obj->data.tail.logfile, buf); strcpy(obj->data.tail.logfile, buf);
obj->data.tail.wantedlines = n1 - 1; obj->data.tail.wantedlines = n1;
obj->data.tail.interval = n2; obj->data.tail.interval = n2;
fclose(fp); fclose(fp);
} else { } else {
@ -2532,7 +2564,7 @@ static struct text_object *construct_text_object(const char *s, const char *arg,
obj->data.tail.logfile = obj->data.tail.logfile =
malloc(TEXT_BUFFER_SIZE); malloc(TEXT_BUFFER_SIZE);
strcpy(obj->data.tail.logfile, buf); strcpy(obj->data.tail.logfile, buf);
obj->data.tail.wantedlines = n1 - 1; obj->data.tail.wantedlines = n1;
obj->data.tail.interval = obj->data.tail.interval =
update_interval * 2; update_interval * 2;
fclose(fp); fclose(fp);
@ -2557,7 +2589,7 @@ static struct text_object *construct_text_object(const char *s, const char *arg,
obj->data.tail.logfile = obj->data.tail.logfile =
malloc(TEXT_BUFFER_SIZE); malloc(TEXT_BUFFER_SIZE);
strcpy(obj->data.tail.logfile, buf); strcpy(obj->data.tail.logfile, buf);
obj->data.tail.wantedlines = n1 - 1; obj->data.tail.wantedlines = n1;
obj->data.tail.interval = n2; obj->data.tail.interval = n2;
fclose(fp); fclose(fp);
} else { } else {
@ -3414,7 +3446,8 @@ static void generate_text_internal(char *p, int p_max_size, struct text_object *
new_font(p, obj->data.s); new_font(p, obj->data.s);
} }
#endif /* X11 */ #endif /* X11 */
OBJ(diskio) { void format_diskio(unsigned int diskio_value)
{
if (!use_spacer) { if (!use_spacer) {
if (diskio_value > 1024*1024) { if (diskio_value > 1024*1024) {
snprintf(p, p_max_size, "%.1fGiB", snprintf(p, p_max_size, "%.1fGiB",
@ -3441,12 +3474,30 @@ static void generate_text_internal(char *p, int p_max_size, struct text_object *
} }
} }
} }
OBJ(diskiograph) { OBJ(diskio) {
new_graph(p, obj->a, format_diskio(diskio_value);
obj->b, obj->c, obj->d,
diskio_value, obj->e, 1);
} }
OBJ(diskio_write) {
format_diskio(diskio_write_value);
}
OBJ(diskio_read) {
format_diskio(diskio_read_value);
}
OBJ(diskiograph) {
new_graph(p, obj->a,
obj->b, obj->c, obj->d,
diskio_value, obj->e, 1);
}
OBJ(diskiograph_read) {
new_graph(p, obj->a,
obj->b, obj->c, obj->d,
diskio_read_value, obj->e, 1);
}
OBJ(diskiograph_write) {
new_graph(p, obj->a,
obj->b, obj->c, obj->d,
diskio_write_value, obj->e, 1);
}
OBJ(downspeed) { OBJ(downspeed) {
if (!use_spacer) { if (!use_spacer) {
snprintf(p, p_max_size, "%d", snprintf(p, p_max_size, "%d",
@ -4593,108 +4644,112 @@ static void generate_text_internal(char *p, int p_max_size, struct text_object *
} else { } else {
obj->data.tail.last_update = current_update_time; obj->data.tail.last_update = current_update_time;
FILE *fp; FILE *fp;
int i; long nl, bsize;
int added = 0; int iter;
tailstring *head = NULL;
tailstring *headtmp = NULL;
tailstring *freetmp = NULL;
fp = fopen(obj->data.tail.logfile, "rt"); fp = fopen(obj->data.tail.logfile, "rt");
if (fp == NULL) { if (fp == NULL) {
ERR("tail logfile failed to open"); /* Send one message, but do not consistently spam on
* missing logfiles. */
if(obj->data.tail.readlines != 0) {
ERR("tail logfile failed to open");
strcpy(obj->data.tail.buffer, "Logfile Missing");
}
obj->data.tail.readlines = 0;
snprintf(p, p_max_size, "Logfile Missing");
} }
else { else {
obj->data.tail.readlines = 0; obj->data.tail.readlines = 0;
/* -1 instead of 0 to avoid counting a trailing newline */
while (fgets(obj->data.tail.buffer, TEXT_BUFFER_SIZE*20, fp) != NULL) { fseek(fp, -1, SEEK_END);
if (added >= 30) { bsize = ftell(fp) + 1;
freelasttail(head); for(iter = obj->data.tail.wantedlines; iter > 0; iter--) {
} nl = rev_fcharfind(fp, '\n', iter);
else { if(nl >= 0)
added++; break;
}
addtail(&head, obj->data.tail.buffer);
obj->data.tail.readlines++;
} }
obj->data.tail.readlines = iter;
if(obj->data.tail.readlines < obj->data.tail.wantedlines) {
fseek(fp, 0, SEEK_SET);
}
else {
fseek(fp, nl+1, SEEK_SET);
bsize -= ftell(fp);
}
/* Make sure bsize is at least 1 byte smaller than
* the buffer max size. */
if(bsize > TEXT_BUFFER_SIZE*20 - 1) {
fseek(fp, bsize - TEXT_BUFFER_SIZE*20 - 1, SEEK_CUR);
bsize = TEXT_BUFFER_SIZE*20 - 1;
}
bsize = fread(obj->data.tail.buffer, 1, bsize, fp);
fclose(fp); fclose(fp);
freetmp = head; if(bsize > 0) {
/* Clean up trailing newline, make sure the buffer
if (obj->data.tail.readlines > 0) { * is null terminated. */
for (i = 0;i < obj->data.tail.wantedlines + 1 && i < obj->data.tail.readlines; i++) { if(obj->data.tail.buffer[bsize-1] == '\n')
addtail(&headtmp, head->data); obj->data.tail.buffer[bsize-1] = '\0';
head = head->next; else
} obj->data.tail.buffer[bsize] = '\0';
freetail(freetmp);
freetmp = headtmp;
strcpy(obj->data.tail.buffer, headtmp->data);
headtmp = headtmp->next;
for (i = 1;i < obj->data.tail.wantedlines + 1 && i < obj->data.tail.readlines; i++) {
if (headtmp) {
strncat(obj->data.tail.buffer, headtmp->data, (TEXT_BUFFER_SIZE * 20) - strlen(obj->data.tail.buffer)); /* without strlen() at the end this becomes a possible */
headtmp = headtmp->next;
}
}
/* get rid of any ugly newlines at the end */
if (obj->data.tail.buffer[strlen(obj->data.tail.buffer)-1] == '\n') {
obj->data.tail.buffer[strlen(obj->data.tail.buffer)-1] = '\0';
}
snprintf(p, p_max_size, "%s", obj->data.tail.buffer); snprintf(p, p_max_size, "%s", obj->data.tail.buffer);
}
freetail(freetmp); else {
} else {
strcpy(obj->data.tail.buffer, "Logfile Empty"); strcpy(obj->data.tail.buffer, "Logfile Empty");
snprintf(p, p_max_size, "Logfile Empty"); snprintf(p, p_max_size, "Logfile Empty");
} /* if readlines */ } /* bsize > 0 */
} /* fp == NULL */ } /* fp == NULL */
} /* if cur_upd_time >= */ } /* if cur_upd_time >= */
//parse_conky_vars(obj->data.tail.buffer, p, cur); //parse_conky_vars(obj->data.tail.buffer, p, cur);
} }
OBJ(head) { OBJ(head) {
if (current_update_time -obj->data.tail.last_update < obj->data.tail.interval) { if (current_update_time -obj->data.tail.last_update < obj->data.tail.interval) {
snprintf(p, p_max_size, "%s", obj->data.tail.buffer); snprintf(p, p_max_size, "%s", obj->data.tail.buffer);
} else { } else {
obj->data.tail.last_update = current_update_time; obj->data.tail.last_update = current_update_time;
FILE *fp; FILE *fp;
tailstring *head = NULL; long nl;
tailstring *headtmp = NULL; int iter;
tailstring *freetmp = NULL;
fp = fopen(obj->data.tail.logfile, "rt"); fp = fopen(obj->data.tail.logfile, "rt");
if (fp == NULL) { if (fp == NULL) {
ERR("head logfile failed to open"); /* Send one message, but do not consistently spam on
* missing logfiles. */
if(obj->data.tail.readlines != 0) {
ERR("head logfile failed to open");
strcpy(obj->data.tail.buffer, "Logfile Missing");
}
obj->data.tail.readlines = 0;
snprintf(p, p_max_size, "Logfile Missing");
} else { } else {
obj->data.tail.readlines = 0; obj->data.tail.readlines = 0;
while (fgets(obj->data.tail.buffer, TEXT_BUFFER_SIZE*20, fp) != NULL && obj->data.tail.readlines <= obj->data.tail.wantedlines) { for(iter = obj->data.tail.wantedlines; iter > 0; iter--) {
addtail(&head, obj->data.tail.buffer); nl = fwd_fcharfind(fp, '\n', iter);
obj->data.tail.readlines++; if(nl >= 0)
break;
} }
obj->data.tail.readlines = iter;
/* Make sure nl is at least 1 byte smaller than
* the buffer max size. */
if(nl > TEXT_BUFFER_SIZE*20 - 1) {
nl = TEXT_BUFFER_SIZE*20 - 1;
}
nl = fread(obj->data.tail.buffer, 1, nl, fp);
fclose(fp); fclose(fp);
freetmp = head; if(nl > 0) {
if (obj->data.tail.readlines > 0) { /* Clean up trailing newline, make sure the buffer
while (head) { * is null terminated. */
addtail(&headtmp, head->data); if (obj->data.tail.buffer[nl-1] == '\n') {
head = head->next; obj->data.tail.buffer[nl-1] = '\0';
} }
freetail(freetmp); else {
freetmp = headtmp; obj->data.tail.buffer[nl] = '\0';
strcpy(obj->data.tail.buffer, headtmp->data);
headtmp = headtmp->next;
while (headtmp) {
strncat(obj->data.tail.buffer, headtmp->data, (TEXT_BUFFER_SIZE * 20) - strlen(obj->data.tail.buffer)); /* without strlen() at the end this becomes a possible */
headtmp = headtmp->next;
}
freetail(freetmp);
/* get rid of any ugly newlines at the end */
if (obj->data.tail.buffer[strlen(obj->data.tail.buffer)-1] == '\n') {
obj->data.tail.buffer[strlen(obj->data.tail.buffer)-1] = '\0';
} }
snprintf(p, p_max_size, "%s", obj->data.tail.buffer); snprintf(p, p_max_size, "%s", obj->data.tail.buffer);
} else { }
else {
strcpy(obj->data.tail.buffer, "Logfile Empty"); strcpy(obj->data.tail.buffer, "Logfile Empty");
snprintf(p, p_max_size, "Logfile Empty"); snprintf(p, p_max_size, "Logfile Empty");
} /* if readlines > 0 */ } /* nl > 0 */
} /* if fp == null */ } /* if fp == null */
} /* cur_upd_time >= */ } /* cur_upd_time >= */
@ -4808,6 +4863,11 @@ static void generate_text()
current_update_time = get_time(); current_update_time = get_time();
update_stuff(cur); update_stuff(cur);
/* fix diskio rates to b/s (use update_interval */
diskio_read_value = diskio_read_value / update_interval;
diskio_write_value = diskio_write_value / update_interval;
diskio_value = diskio_value / update_interval;
/* add things to the buffer */ /* add things to the buffer */

View File

@ -96,6 +96,8 @@ struct net_stat {
}; };
unsigned int diskio_value; unsigned int diskio_value;
unsigned int diskio_read_value;
unsigned int diskio_write_value;
struct fs_stat { struct fs_stat {
char *path; char *path;

View File

@ -1521,25 +1521,27 @@ void update_top()
void update_diskio() void update_diskio()
{ {
static unsigned int last = UINT_MAX; static unsigned int last = UINT_MAX;
static unsigned int last_read = UINT_MAX;
static unsigned int last_write = UINT_MAX;
FILE* fp; FILE* fp;
static int rep=0; static int rep=0;
char buf[512]; char buf[512];
int major, minor; int major, minor;
unsigned int current = 0; unsigned int current = 0;
unsigned int current_read = 0;
unsigned int current_write = 0;
unsigned int reads, writes = 0; unsigned int reads, writes = 0;
int col_count = 0; int col_count = 0;
if (!(fp =open_file("/proc/diskstats", &rep))) if (!(fp =open_file("/proc/diskstats", &rep))) {
{ diskio_value=0;
diskio_value=0; return;
return; }
}
/* read reads and writes from all disks (minor = 0), including /* read reads and writes from all disks (minor = 0), including
* cd-roms and floppies, and summ them up * cd-roms and floppies, and summ them up
*/ */
current = 0;
while (!feof(fp)) { while (!feof(fp)) {
fgets(buf, 512, fp); fgets(buf, 512, fp);
col_count = sscanf(buf, "%u %u %*s %*u %*u %u %*u %*u %*u %u", col_count = sscanf(buf, "%u %u %*s %*u %*u %u %*u %*u %*u %u",
@ -1553,6 +1555,8 @@ void update_diskio()
major != LVM_BLK_MAJOR && major != NBD_MAJOR && major != LVM_BLK_MAJOR && major != NBD_MAJOR &&
major != RAMDISK_MAJOR && major != LOOP_MAJOR) { major != RAMDISK_MAJOR && major != LOOP_MAJOR) {
current += reads + writes; current += reads + writes;
current_read += reads;
current_write += writes;
} }
} }
@ -1561,6 +1565,14 @@ void update_diskio()
* "sectors read", and we therefore have to divide by two to * "sectors read", and we therefore have to divide by two to
* get KB */ * get KB */
int tot = ((double)(current-last)/2); int tot = ((double)(current-last)/2);
int tot_read = ((double)(current_read-last_read)/2);
int tot_write = ((double)(current_write-last_write)/2);
if (last_read > current_read)
tot_read = 0;
if (last_write > current_write)
tot_write = 0;
if (last > current) { if (last > current) {
/* we hit this either if it's the very first time we /* we hit this either if it's the very first time we
* run this, or when /proc/diskstats overflows; while * run this, or when /proc/diskstats overflows; while
@ -1568,10 +1580,14 @@ void update_diskio()
tot = 0; tot = 0;
} }
last = current; last = current;
last_read = current_read;
last_write = current_write;
diskio_value = tot; diskio_value = tot;
diskio_read_value = tot_read;
diskio_write_value = tot_write;
fclose(fp); fclose(fp);
} }
/* Here come the IBM ACPI-specific things. For reference, see /* Here come the IBM ACPI-specific things. For reference, see