]> git.pld-linux.org Git - packages/monit.git/blob - monit-meminfo-vs-kcore.patch
- use /proc/meminfo instead of /proc/kcore
[packages/monit.git] / monit-meminfo-vs-kcore.patch
1 diff -urN monit-4.0.org/process/sysdep_LINUX.c monit-4.0/process/sysdep_LINUX.c
2 --- monit-4.0.org/process/sysdep_LINUX.c        2003-09-08 19:20:44.000000000 +0200
3 +++ monit-4.0/process/sysdep_LINUX.c    2003-09-08 19:20:23.000000000 +0200
4 @@ -84,24 +84,37 @@
5   *  @file
6   */
7  
8 -#define PAGE_TO_KBYTE_SHIFT PAGE_SHIFT-10
9 +#define FREEMEM         "MemFree:"
10 +#define FREESWAP        "SwapFree:"
11  
12  int init_process_info_sysdep(void) {
13  
14 -  struct stat buf;
15 -  
16 +  int memfd;
17 +  char buf[1024], *ptr1, *ptr2;
18  
19 -  /* I hope this is okay hack to get the total memsize. (-: */
20 +  if ((memfd = open("/proc/meminfo", O_RDONLY)) == -1) {
21 +      return FALSE;
22 +  }
23  
24 -  if ( stat("/proc/kcore", &buf) != 0 ) {
25 +  /* read the file */
26 +  if (read(memfd, buf, sizeof(buf)) < 0) {
27 +      close(memfd);
28 +      return FALSE;
29 +  }
30  
31 -    return FALSE;
32 +  close(memfd);
33 +  
34 +  ptr1 = strstr(buf, FREEMEM);
35 +  ptr2 = strstr(buf, FREESWAP);
36  
37 +  if (!ptr1 || !ptr2) {
38 +      return FALSE;
39    }
40  
41 -  num_cpus= sysconf(_SC_NPROCESSORS_CONF);
42 +  /* we only care about integer values */
43 +  mem_kbyte_max = atoi(ptr1+strlen(FREEMEM)) /* + atoi(ptr2+strlen(FREESWAP)) */ ;
44  
45 -  mem_kbyte_max = buf.st_size>>10;
46 +  num_cpus= sysconf(_SC_NPROCESSORS_CONF);
47  
48    return TRUE;
49  
This page took 0.077805 seconds and 3 git commands to generate.