mirror of
https://github.com/Llewellynvdm/conky.git
synced 2025-01-28 09:38:38 +00:00
Make sure char-arrays filled with read() are null-terminated
This commit is contained in:
parent
a8d633009d
commit
c1933dc186
@ -1988,7 +1988,7 @@ static void main_loop(void)
|
|||||||
#ifdef HAVE_SYS_INOTIFY_H
|
#ifdef HAVE_SYS_INOTIFY_H
|
||||||
int inotify_config_wd = -1;
|
int inotify_config_wd = -1;
|
||||||
#define INOTIFY_EVENT_SIZE (sizeof(struct inotify_event))
|
#define INOTIFY_EVENT_SIZE (sizeof(struct inotify_event))
|
||||||
#define INOTIFY_BUF_LEN (20 * (INOTIFY_EVENT_SIZE + 16))
|
#define INOTIFY_BUF_LEN (20 * (INOTIFY_EVENT_SIZE + 16)) + 1
|
||||||
char inotify_buff[INOTIFY_BUF_LEN];
|
char inotify_buff[INOTIFY_BUF_LEN];
|
||||||
#endif /* HAVE_SYS_INOTIFY_H */
|
#endif /* HAVE_SYS_INOTIFY_H */
|
||||||
|
|
||||||
@ -2408,7 +2408,7 @@ static void main_loop(void)
|
|||||||
select(inotify_fd + 1, &descriptors, NULL, NULL, &time_to_wait);
|
select(inotify_fd + 1, &descriptors, NULL, NULL, &time_to_wait);
|
||||||
if (FD_ISSET(inotify_fd, &descriptors)) {
|
if (FD_ISSET(inotify_fd, &descriptors)) {
|
||||||
/* process inotify events */
|
/* process inotify events */
|
||||||
len = read(inotify_fd, inotify_buff, INOTIFY_BUF_LEN);
|
len = read(inotify_fd, inotify_buff, INOTIFY_BUF_LEN - 1);
|
||||||
while (len > 0 && idx < len) {
|
while (len > 0 && idx < len) {
|
||||||
struct inotify_event *ev = (struct inotify_event *) &inotify_buff[idx];
|
struct inotify_event *ev = (struct inotify_event *) &inotify_buff[idx];
|
||||||
if (ev->wd == inotify_config_wd && (ev->mask & IN_MODIFY || ev->mask & IN_IGNORED)) {
|
if (ev->wd == inotify_config_wd && (ev->mask & IN_MODIFY || ev->mask & IN_IGNORED)) {
|
||||||
|
10
src/linux.cc
10
src/linux.cc
@ -2454,7 +2454,7 @@ static unsigned long long calc_cpu_total(void)
|
|||||||
KFLAG_ISSET(KFLAG_IS_LONGSTAT) ? TMPL_LONGPROC : TMPL_SHORTPROC;
|
KFLAG_ISSET(KFLAG_IS_LONGSTAT) ? TMPL_LONGPROC : TMPL_SHORTPROC;
|
||||||
|
|
||||||
ps = open("/proc/stat", O_RDONLY);
|
ps = open("/proc/stat", O_RDONLY);
|
||||||
rc = read(ps, line, sizeof(line));
|
rc = read(ps, line, BUFFER_LEN - 1);
|
||||||
close(ps);
|
close(ps);
|
||||||
if (rc < 0) {
|
if (rc < 0) {
|
||||||
return 0;
|
return 0;
|
||||||
@ -2535,7 +2535,7 @@ static void process_parse_stat(struct process *process)
|
|||||||
/* Mark process as up-to-date. */
|
/* Mark process as up-to-date. */
|
||||||
process->time_stamp = g_time;
|
process->time_stamp = g_time;
|
||||||
|
|
||||||
rc = read(ps, line, sizeof(line));
|
rc = read(ps, line, BUFFER_LEN - 1);
|
||||||
close(ps);
|
close(ps);
|
||||||
if (rc < 0) {
|
if (rc < 0) {
|
||||||
return;
|
return;
|
||||||
@ -2572,11 +2572,9 @@ static void process_parse_stat(struct process *process)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
endl = read(ps, line, sizeof(line));
|
endl = read(ps, line, BUFFER_LEN - 1);
|
||||||
close(ps);
|
close(ps);
|
||||||
|
|
||||||
/* null terminate the input */
|
|
||||||
line[endl] = 0;
|
|
||||||
/* account for "kdeinit: " */
|
/* account for "kdeinit: " */
|
||||||
if ((char *) line == strstr(line, "kdeinit: ")) {
|
if ((char *) line == strstr(line, "kdeinit: ")) {
|
||||||
r = ((char *) line) + 9;
|
r = ((char *) line) + 9;
|
||||||
@ -2647,7 +2645,7 @@ static void process_parse_io(struct process *process)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
rc = read(ps, line, sizeof(line));
|
rc = read(ps, line, BUFFER_LEN - 1);
|
||||||
close(ps);
|
close(ps);
|
||||||
if (rc < 0) {
|
if (rc < 0) {
|
||||||
return;
|
return;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user