Merge branch 'SIGAR-148'
This commit is contained in:
		
							parent
							
								
									5ac96fb803
								
							
						
					
					
						commit
						cb8eb6b183
					
				@ -120,6 +120,10 @@ int sigar_procfs_args_get(sigar_t *sigar, sigar_pid_t pid,
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
int sigar_mem_calc_ram(sigar_t *sigar, sigar_mem_t *mem);
 | 
					int sigar_mem_calc_ram(sigar_t *sigar, sigar_mem_t *mem);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int sigar_statvfs(sigar_t *sigar,
 | 
				
			||||||
 | 
					                  const char *dirname,
 | 
				
			||||||
 | 
					                  sigar_file_system_usage_t *fsusage);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
double sigar_file_system_usage_calc_used(sigar_t *sigar,
 | 
					double sigar_file_system_usage_calc_used(sigar_t *sigar,
 | 
				
			||||||
                                         sigar_file_system_usage_t *fs);
 | 
					                                         sigar_file_system_usage_t *fs);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -1058,7 +1058,6 @@ int sigar_thread_cpu_get(sigar_t *sigar,
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include <mntent.h>
 | 
					#include <mntent.h>
 | 
				
			||||||
#include <sys/statfs.h>
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
int sigar_os_fs_type_get(sigar_file_system_t *fsp)
 | 
					int sigar_os_fs_type_get(sigar_file_system_t *fsp)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
@ -1458,31 +1457,16 @@ int sigar_disk_usage_get(sigar_t *sigar, const char *name,
 | 
				
			|||||||
    return status;
 | 
					    return status;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include <sys/vfs.h>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#define SIGAR_FS_BLOCKS_TO_BYTES(val, bsize) ((val * bsize) >> 1)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
int sigar_file_system_usage_get(sigar_t *sigar,
 | 
					int sigar_file_system_usage_get(sigar_t *sigar,
 | 
				
			||||||
                                const char *dirname,
 | 
					                                const char *dirname,
 | 
				
			||||||
                                sigar_file_system_usage_t *fsusage)
 | 
					                                sigar_file_system_usage_t *fsusage)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    struct statfs buf;
 | 
					    int status = sigar_statvfs(sigar, dirname, fsusage);
 | 
				
			||||||
    sigar_uint64_t val, bsize;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if (statfs(dirname, &buf) != 0) {
 | 
					    if (status != SIGAR_OK) {
 | 
				
			||||||
        return errno;
 | 
					        return status;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    bsize = buf.f_bsize / 512;
 | 
					 | 
				
			||||||
    val = buf.f_blocks;
 | 
					 | 
				
			||||||
    fsusage->total = SIGAR_FS_BLOCKS_TO_BYTES(val, bsize);
 | 
					 | 
				
			||||||
    val = buf.f_bfree;
 | 
					 | 
				
			||||||
    fsusage->free  = SIGAR_FS_BLOCKS_TO_BYTES(val, bsize);
 | 
					 | 
				
			||||||
    val = buf.f_bavail;
 | 
					 | 
				
			||||||
    fsusage->avail = SIGAR_FS_BLOCKS_TO_BYTES(val, bsize);
 | 
					 | 
				
			||||||
    fsusage->used  = fsusage->total - fsusage->free;
 | 
					 | 
				
			||||||
    fsusage->files = buf.f_files;
 | 
					 | 
				
			||||||
    fsusage->free_files = buf.f_ffree;
 | 
					 | 
				
			||||||
    fsusage->use_percent = sigar_file_system_usage_calc_used(sigar, fsusage);
 | 
					    fsusage->use_percent = sigar_file_system_usage_calc_used(sigar, fsusage);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    (void)sigar_disk_usage_get(sigar, dirname, &fsusage->disk);
 | 
					    (void)sigar_disk_usage_get(sigar, dirname, &fsusage->disk);
 | 
				
			||||||
 | 
				
			|||||||
@ -1352,8 +1352,6 @@ int sigar_file_system_list_get(sigar_t *sigar,
 | 
				
			|||||||
    return SIGAR_OK;
 | 
					    return SIGAR_OK;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include <sys/statvfs.h>
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
typedef struct {
 | 
					typedef struct {
 | 
				
			||||||
    char device[PATH_MAX];
 | 
					    char device[PATH_MAX];
 | 
				
			||||||
    char name[8];
 | 
					    char name[8];
 | 
				
			||||||
@ -1716,29 +1714,16 @@ int sigar_disk_usage_get(sigar_t *sigar, const char *name,
 | 
				
			|||||||
    return status;
 | 
					    return status;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#define SIGAR_FS_BLOCKS_TO_BYTES(val, bsize) ((val * bsize) >> 1)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
int sigar_file_system_usage_get(sigar_t *sigar,
 | 
					int sigar_file_system_usage_get(sigar_t *sigar,
 | 
				
			||||||
                                const char *dirname,
 | 
					                                const char *dirname,
 | 
				
			||||||
                                sigar_file_system_usage_t *fsusage)
 | 
					                                sigar_file_system_usage_t *fsusage)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    struct statvfs buf;
 | 
					    int status = sigar_statvfs(sigar, dirname, fsusage);
 | 
				
			||||||
    sigar_uint64_t val, bsize;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if (statvfs(dirname, &buf) != 0) {
 | 
					    if (status != SIGAR_OK) {
 | 
				
			||||||
        return errno;
 | 
					        return status;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    bsize = buf.f_frsize / 512;
 | 
					 | 
				
			||||||
    val = buf.f_blocks;
 | 
					 | 
				
			||||||
    fsusage->total = SIGAR_FS_BLOCKS_TO_BYTES(val, bsize);
 | 
					 | 
				
			||||||
    val = buf.f_bfree;
 | 
					 | 
				
			||||||
    fsusage->free  = SIGAR_FS_BLOCKS_TO_BYTES(val, bsize);
 | 
					 | 
				
			||||||
    val = buf.f_bavail;
 | 
					 | 
				
			||||||
    fsusage->avail = SIGAR_FS_BLOCKS_TO_BYTES(val, bsize);
 | 
					 | 
				
			||||||
    fsusage->used  = fsusage->total - fsusage->free;
 | 
					 | 
				
			||||||
    fsusage->files = buf.f_files;
 | 
					 | 
				
			||||||
    fsusage->free_files = buf.f_ffree;
 | 
					 | 
				
			||||||
    fsusage->use_percent = sigar_file_system_usage_calc_used(sigar, fsusage);
 | 
					    fsusage->use_percent = sigar_file_system_usage_calc_used(sigar, fsusage);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    sigar_disk_usage_get(sigar, dirname, &fsusage->disk);
 | 
					    sigar_disk_usage_get(sigar, dirname, &fsusage->disk);
 | 
				
			||||||
 | 
				
			|||||||
@ -61,6 +61,40 @@
 | 
				
			|||||||
#  endif
 | 
					#  endif
 | 
				
			||||||
#endif
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "sigar.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#ifndef WIN32
 | 
				
			||||||
 | 
					#include <sys/statvfs.h>
 | 
				
			||||||
 | 
					#include <errno.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#define SIGAR_FS_BLOCKS_TO_BYTES(val, bsize) ((val * bsize) >> 1)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					int sigar_statvfs(sigar_t *sigar,
 | 
				
			||||||
 | 
					                  const char *dirname,
 | 
				
			||||||
 | 
					                  sigar_file_system_usage_t *fsusage)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    struct statvfs buf;
 | 
				
			||||||
 | 
					    sigar_uint64_t val, bsize;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (statvfs(dirname, &buf) != 0) {
 | 
				
			||||||
 | 
					        return errno;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    bsize = buf.f_frsize / 512;
 | 
				
			||||||
 | 
					    val = buf.f_blocks;
 | 
				
			||||||
 | 
					    fsusage->total = SIGAR_FS_BLOCKS_TO_BYTES(val, bsize);
 | 
				
			||||||
 | 
					    val = buf.f_bfree;
 | 
				
			||||||
 | 
					    fsusage->free  = SIGAR_FS_BLOCKS_TO_BYTES(val, bsize);
 | 
				
			||||||
 | 
					    val = buf.f_bavail;
 | 
				
			||||||
 | 
					    fsusage->avail = SIGAR_FS_BLOCKS_TO_BYTES(val, bsize);
 | 
				
			||||||
 | 
					    fsusage->used  = fsusage->total - fsusage->free;
 | 
				
			||||||
 | 
					    fsusage->files = buf.f_files;
 | 
				
			||||||
 | 
					    fsusage->free_files = buf.f_ffree;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return SIGAR_OK;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					#endif
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/*
 | 
					/*
 | 
				
			||||||
 * whittled down version of apr/file_info/{unix,win32}/filestat.c
 | 
					 * whittled down version of apr/file_info/{unix,win32}/filestat.c
 | 
				
			||||||
 * to fillin sigar_fileattrs_t
 | 
					 * to fillin sigar_fileattrs_t
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
		Reference in New Issue
	
	Block a user