add function get_mounted_filesystems

pull/5/head
yuqing 2016-01-12 16:32:26 +08:00
parent 700f8d2c2b
commit 10c15228ec
4 changed files with 173 additions and 7 deletions

View File

@ -5,6 +5,7 @@ Version 1.24 2016-01-12
* make.sh: use sed to replace perl * make.sh: use sed to replace perl
* support get local mac addresses * support get local mac addresses
* add system_info.h and system_info.c * add system_info.h and system_info.c
* add function get_mounted_filesystems
Version 1.23 2015-11-16 Version 1.23 2015-11-16
* sched_thread.c: task can execute in a new thread * sched_thread.c: task can execute in a new thread

View File

@ -19,14 +19,17 @@
#include <netinet/in.h> #include <netinet/in.h>
#include <fcntl.h> #include <fcntl.h>
#include <errno.h> #include <errno.h>
#include <sys/vfs.h>
#include "logger.h" #include "logger.h"
#include "system_info.h" #include "system_info.h"
#ifdef OS_LINUX #ifdef OS_LINUX
#include <sys/sysinfo.h> #include <sys/sysinfo.h>
#include <mntent.h>
#else #else
#ifdef OS_FREEBSD #ifdef OS_FREEBSD
#include <sys/sysctl.h> #include <sys/sysctl.h>
#include <sys/ucred.h>
#endif #endif
#endif #endif
@ -82,9 +85,9 @@ int get_uptime(time_t *uptime)
struct sysinfo si; struct sysinfo si;
if (sysinfo(&si) != 0) if (sysinfo(&si) != 0)
{ {
logError("file: "__FILE__", line: %d, " \ logError("file: "__FILE__", line: %d, "
"call sysinfo fail, " \ "call sysinfo fail, "
"errno: %d, error info: %s", \ "errno: %d, error info: %s",
__LINE__, errno, STRERROR(errno)); __LINE__, errno, STRERROR(errno));
return errno != 0 ? errno : EPERM; return errno != 0 ? errno : EPERM;
} }
@ -108,9 +111,9 @@ int get_uptime(time_t *uptime)
else else
{ {
*uptime = 0; *uptime = 0;
logError("file: "__FILE__", line: %d, " \ logError("file: "__FILE__", line: %d, "
"call sysctl fail, " \ "call sysctl fail, "
"errno: %d, error info: %s", \ "errno: %d, error info: %s",
__LINE__, errno, STRERROR(errno)); __LINE__, errno, STRERROR(errno));
return errno != 0 ? errno : EPERM; return errno != 0 ? errno : EPERM;
} }
@ -120,3 +123,118 @@ int get_uptime(time_t *uptime)
#endif #endif
} }
#define SET_STATFS_FIELDS(left, right) \
do { \
left.f_type = right.f_type; \
left.f_bsize = right.f_bsize; \
left.f_blocks = right.f_blocks; \
left.f_bfree = right.f_bfree; \
left.f_bavail = right.f_bavail; \
left.f_files = right.f_files; \
left.f_ffree = right.f_ffree; \
left.f_fsid = right.f_fsid; \
} while (0)
#define SET_MNT_FIELDS(left, fstypename, mntfromname, mntonname) \
do { \
snprintf(left.f_fstypename, sizeof(left.f_fstypename), "%s", fstypename); \
snprintf(left.f_mntfromname, sizeof(left.f_mntfromname), "%s", mntfromname); \
snprintf(left.f_mntonname, sizeof(left.f_mntonname), "%s", mntonname); \
} while (0)
int get_mounted_filesystems(struct fast_statfs *stats, const int size, int *count)
{
#ifdef OS_LINUX
const char *filename = "/proc/mounts";
FILE *fp;
struct mntent *mnt;
struct statfs buf;
int result;
int i;
*count = 0;
fp = setmntent(filename, "r");
if (fp == NULL)
{
result = errno != 0 ? errno : ENOENT;
logError("file: "__FILE__", line: %d, "
"call setmntent fail, "
"errno: %d, error info: %s",
__LINE__, errno, STRERROR(errno));
return result;
}
memset(stats, 0, sizeof(struct fast_statfs) * size);
result = 0;
while ((mnt=getmntent(fp)) != NULL)
{
if (*count >= size)
{
result = ENOSPC;
break;
}
SET_MNT_FIELDS(stats[*count], mnt->mnt_type,
mnt->mnt_fsname, mnt->mnt_dir);
(*count)++;
}
endmntent(fp);
for (i=0; i<*count; i++)
{
if (statfs(stats[i].f_mntonname, &buf) == 0)
{
SET_STATFS_FIELDS(stats[i], buf);
}
else
{
logWarning("file: "__FILE__", line: %d, "
"call statfs fail, "
"errno: %d, error info: %s",
__LINE__, errno, STRERROR(errno));
}
}
return result;
#else
#ifdef OS_FREEBSD
struct statfs *mnts;
int result;
int i;
mnts = NULL;
*count = getmntinfo(&mnts, 0);
if (*count == 0)
{
result = errno != 0 ? errno : EPERM;
logError("file: "__FILE__", line: %d, "
"call getmntinfo fail, "
"errno: %d, error info: %s",
__LINE__, errno, STRERROR(errno));
return result;
}
if (*count <= size)
{
result = 0;
}
else
{
*count = size;
result = ENOSPC;
}
for (i=0; i<*count; i++)
{
SET_STATFS_FIELDS(stats[i], mnts[i]);
SET_MNT_FIELDS(stats[i], mnts[i].f_fstypename,
mnts[i].f_mntfromname, mnts[i].f_mntonname);
}
return result;
#else
#error port me!
#endif
#endif
}

View File

@ -15,12 +15,37 @@
#include <sys/types.h> #include <sys/types.h>
#include <sys/time.h> #include <sys/time.h>
#include <sys/resource.h> #include <sys/resource.h>
#include <sys/param.h>
#include <sys/mount.h>
#include "common_define.h" #include "common_define.h"
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
#endif #endif
#ifndef MFSNAMELEN
#define MFSNAMELEN 16
#endif
#ifndef MNAMELEN
#define MNAMELEN 128
#endif
typedef struct fast_statfs {
long f_type; /* type of file system (see below) */
long f_bsize; /* optimal transfer block size */
long f_blocks; /* total data blocks in file system */
long f_bfree; /* free blocks in fs */
long f_bavail; /* free blocks avail to non-superuser */
long f_files; /* total file nodes in file system */
long f_ffree; /* free file nodes in fs */
fsid_t f_fsid; /* file system id */
char f_fstypename[MFSNAMELEN]; /* fs type name */
char f_mntfromname[MNAMELEN]; /* mounted file system */
char f_mntonname[MNAMELEN]; /* directory on which mounted */
} FastStatFS;
/** get system total memory size /** get system total memory size
* parameters: * parameters:
* mem_size: return the total memory size * mem_size: return the total memory size
@ -42,6 +67,15 @@ int get_sys_cpu_count();
*/ */
int get_uptime(time_t *uptime); int get_uptime(time_t *uptime);
/** get mounted file systems
* parameters:
* stats: the stat array
* size: max size of the array
* count: return the count of the array
* return: error no , 0 success, != 0 fail
*/
int get_mounted_filesystems(struct fast_statfs *stats, const int size, int *count);
#ifdef __cplusplus #ifdef __cplusplus
} }
#endif #endif

View File

@ -11,6 +11,7 @@
#include "ini_file_reader.h" #include "ini_file_reader.h"
#include "fast_mblock.h" #include "fast_mblock.h"
#include "sockopt.h" #include "sockopt.h"
#include "system_info.h"
struct my_struct { struct my_struct {
struct fast_mblock_man *mblock; struct fast_mblock_man *mblock;
@ -47,6 +48,7 @@ int main(int argc, char *argv[])
ScheduleEntry scheduleEntries[1]; ScheduleEntry scheduleEntries[1];
volatile bool continue_flag = true; volatile bool continue_flag = true;
FastIFConfig if_configs[32]; FastIFConfig if_configs[32];
struct fast_statfs stats[32];
if (argc > 1) { if (argc > 1) {
filename = argv[1]; filename = argv[1];
@ -65,13 +67,24 @@ int main(int argc, char *argv[])
return result; return result;
} }
getifconfigs(if_configs, 32, &count); getifconfigs(if_configs, sizeof(if_configs) / sizeof(if_configs[0]), &count);
printf("ifconfig count: %d\n", count);
for (i=0; i<count; i++) { for (i=0; i<count; i++) {
printf("%s ipv4: %s, ipv6: %s, mac: %s\n", printf("%s ipv4: %s, ipv6: %s, mac: %s\n",
if_configs[i].name, if_configs[i].ipv4, if_configs[i].name, if_configs[i].ipv4,
if_configs[i].ipv6, if_configs[i].mac); if_configs[i].ipv6, if_configs[i].mac);
} }
get_mounted_filesystems(stats, sizeof(stats) / sizeof(stats[0]), &count);
printf("mounted fs count: %d\n", count);
for (i=0; i<count; i++) {
printf("%s %s %s %ld %ld %ld %ld %ld %ld %ld\n",
stats[i].f_mntfromname, stats[i].f_mntonname, stats[i].f_fstypename,
stats[i].f_type, stats[i].f_bsize, stats[i].f_blocks,
stats[i].f_bfree, stats[i].f_bavail, stats[i].f_files,
stats[i].f_ffree);
}
//iniPrintItems(&iniContext); //iniPrintItems(&iniContext);
iniFreeContext(&iniContext); iniFreeContext(&iniContext);