Don't use kvm anymore. Patch by hua.zhang@sun.com. Closes #345811.
2006-06-24 Benoît Dejean <benoit@placenet.org> * msg_limits.c: (glibtop_init_msg_limits_p), (glibtop_get_msg_limits_p): * open_suid.c: (glibtop_open_p): * sem_limits.c: (glibtop_init_sem_limits_p), (glibtop_get_sem_limits_p): * shm_limits.c: (glibtop_init_shm_limits_p), (glibtop_get_shm_limits_p): Don't use kvm anymore. Patch by hua.zhang@sun.com. Closes #345811.
This commit is contained in:
committed by
Benoît Dejean
parent
e6d6b0bba7
commit
46c9f6ebeb
@@ -1,3 +1,17 @@
|
|||||||
|
2006-06-24 Benoît Dejean <benoit@placenet.org>
|
||||||
|
|
||||||
|
* msg_limits.c: (glibtop_init_msg_limits_p),
|
||||||
|
(glibtop_get_msg_limits_p):
|
||||||
|
* open_suid.c: (glibtop_open_p):
|
||||||
|
* sem_limits.c: (glibtop_init_sem_limits_p),
|
||||||
|
(glibtop_get_sem_limits_p):
|
||||||
|
* shm_limits.c: (glibtop_init_shm_limits_p),
|
||||||
|
(glibtop_get_shm_limits_p):
|
||||||
|
|
||||||
|
Don't use kvm anymore.
|
||||||
|
Patch by hua.zhang@sun.com.
|
||||||
|
Closes #345811.
|
||||||
|
|
||||||
2005-08-12 Benoît Dejean <benoit@placenet.org>
|
2005-08-12 Benoît Dejean <benoit@placenet.org>
|
||||||
|
|
||||||
* glibtop_server.h:
|
* glibtop_server.h:
|
||||||
|
@@ -26,28 +26,37 @@
|
|||||||
#include <glibtop/msg_limits.h>
|
#include <glibtop/msg_limits.h>
|
||||||
|
|
||||||
#include <kvm.h>
|
#include <kvm.h>
|
||||||
|
#include <rctl.h>
|
||||||
#include <sys/msg.h>
|
#include <sys/msg.h>
|
||||||
|
|
||||||
static const struct nlist nlst[] = { {"msginfo"}, {NULL} };
|
static const struct nlist nlst[] = { {"glibtop_msg_limits"}, {NULL} };
|
||||||
|
#if GLIBTOP_SOLARIS_RELEASE < 51000
|
||||||
static const unsigned long _glibtop_sysdeps_msg_limits =
|
static const unsigned long _glibtop_sysdeps_msg_limits =
|
||||||
#if GLIBTOP_SOLARIS_RELEASE <= 570
|
#if GLIBTOP_SOLARIS_RELEASE <= 50700
|
||||||
(1L << GLIBTOP_IPC_MSGMAP) + (1L << GLIBTOP_IPC_MSGSSZ) +
|
(1L << GLIBTOP_IPC_MSGMAP) + (1L << GLIBTOP_IPC_MSGSSZ) +
|
||||||
#endif
|
#endif
|
||||||
(1L << GLIBTOP_IPC_MSGPOOL) + (1L << GLIBTOP_IPC_MSGMAX) +
|
(1L << GLIBTOP_IPC_MSGPOOL) + (1L << GLIBTOP_IPC_MSGMAX) +
|
||||||
(1L << GLIBTOP_IPC_MSGMNB) + (1L << GLIBTOP_IPC_MSGMNI) +
|
(1L << GLIBTOP_IPC_MSGMNB) + (1L << GLIBTOP_IPC_MSGMNI) +
|
||||||
(1L << GLIBTOP_IPC_MSGTQL);
|
(1L << GLIBTOP_IPC_MSGTQL);
|
||||||
|
#else
|
||||||
|
static const unsigned long _glibtop_sysdeps_msg_limits = 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/* Init function. */
|
/* Init function. */
|
||||||
|
|
||||||
void
|
void
|
||||||
glibtop_init_msg_limits_p (glibtop *server)
|
glibtop_init_msg_limits_p (glibtop *server)
|
||||||
{
|
{
|
||||||
|
#if GLIBTOP_SOLARIS_RELEASE < 51000
|
||||||
|
|
||||||
kvm_t *kd = server->machine.kd;
|
kvm_t *kd = server->machine.kd;
|
||||||
|
|
||||||
if(kd && !kvm_nlist(kd, nlst))
|
if(kd && !kvm_nlist(kd, nlst))
|
||||||
server->sysdeps.msg_limits = _glibtop_sysdeps_msg_limits;
|
server->sysdeps.msg_limits = _glibtop_sysdeps_msg_limits;
|
||||||
else
|
else
|
||||||
server->sysdeps.msg_limits = 0;
|
server->sysdeps.msg_limits = 0;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Provides information about sysv ipc limits. */
|
/* Provides information about sysv ipc limits. */
|
||||||
@@ -55,18 +64,22 @@ glibtop_init_msg_limits_p (glibtop *server)
|
|||||||
void
|
void
|
||||||
glibtop_get_msg_limits_p (glibtop *server, glibtop_msg_limits *buf)
|
glibtop_get_msg_limits_p (glibtop *server, glibtop_msg_limits *buf)
|
||||||
{
|
{
|
||||||
|
#if GLIBTOP_SOLARIS_RELEASE < 51000
|
||||||
|
|
||||||
kvm_t *kd = server->machine.kd;
|
kvm_t *kd = server->machine.kd;
|
||||||
struct msginfo minfo;
|
glibtop_msg_limits minfo;
|
||||||
|
|
||||||
|
|
||||||
memset (buf, 0, sizeof (glibtop_msg_limits));
|
memset (buf, 0, sizeof (glibtop_msg_limits));
|
||||||
|
|
||||||
if(!(server->sysdeps.msg_limits))
|
if(!(server->sysdeps.msg_limits))
|
||||||
return;
|
return;
|
||||||
if(kvm_read(kd, nlst[0].n_value, (void *)&minfo,
|
if(kvm_read(kd, nlst[0].n_value, (void *)&minfo,
|
||||||
sizeof(struct msginfo)) != sizeof(struct msginfo))
|
sizeof(glibtop_msg_limits)) != sizeof(glibtop_msg_limits))
|
||||||
|
|
||||||
return;
|
return;
|
||||||
|
|
||||||
#if GLIBTOP_SOLARIS_RELEASE <= 570
|
#if GLIBTOP_SOLARIS_RELEASE <= 50700
|
||||||
/* These fields don't exist anymore in Solaris 8.
|
/* These fields don't exist anymore in Solaris 8.
|
||||||
* Thanks to Laszlo PETER <Laszlo.Peter@ireland.sun.com>. */
|
* Thanks to Laszlo PETER <Laszlo.Peter@ireland.sun.com>. */
|
||||||
buf->msgmap = minfo.msgmap;
|
buf->msgmap = minfo.msgmap;
|
||||||
@@ -76,6 +89,33 @@ glibtop_get_msg_limits_p (glibtop *server, glibtop_msg_limits *buf)
|
|||||||
buf->msgmnb = minfo.msgmnb;
|
buf->msgmnb = minfo.msgmnb;
|
||||||
buf->msgmni = minfo.msgmni;
|
buf->msgmni = minfo.msgmni;
|
||||||
buf->msgtql = minfo.msgtql;
|
buf->msgtql = minfo.msgtql;
|
||||||
buf->msgpool = minfo.msgmni * minfo.msgmnb >> 10;
|
#endif
|
||||||
|
#if GLIBTOP_SOLARIS_RELEASE >= 51000
|
||||||
|
rctlblk_t *rblk;
|
||||||
|
if ((rblk = malloc(rctlblk_size())) == NULL)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (getrctl("project.max-msg-qbytes", NULL, rblk, RCTL_FIRST) == -1)
|
||||||
|
return;
|
||||||
|
else
|
||||||
|
buf->msgmnb = rctlblk_get_value(rblk);
|
||||||
|
|
||||||
|
if (getrctl("project.max-msg-ids", NULL, rblk, RCTL_FIRST) == -1)
|
||||||
|
return;
|
||||||
|
else
|
||||||
|
buf->msgmni = rctlblk_get_value(rblk);
|
||||||
|
|
||||||
|
if (getrctl("project.max-msg-messages", NULL, rblk, RCTL_FIRST) == -1)
|
||||||
|
return;
|
||||||
|
else
|
||||||
|
buf->msgtql = rctlblk_get_value(rblk);
|
||||||
|
/* this is the maximum size of a system V message, which has been obsoleted as a kernel tunable value now */
|
||||||
|
/* and it should always be 65535 instead, so I list it here, if needed, can be removed */
|
||||||
|
buf->msgmax = 65535;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
buf->msgpool = buf->msgmni * buf->msgmnb >> 10;
|
||||||
buf->flags = _glibtop_sysdeps_msg_limits;
|
buf->flags = _glibtop_sysdeps_msg_limits;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@@ -69,10 +69,14 @@ glibtop_open_p (glibtop *server, const char *program_name,
|
|||||||
server->machine.gid = getgid ();
|
server->machine.gid = getgid ();
|
||||||
server->machine.egid = getegid ();
|
server->machine.egid = getegid ();
|
||||||
|
|
||||||
|
#if GLIBTOP_SOLARIS_RELEASE < 51000
|
||||||
|
|
||||||
server->machine.kd = kvm_open(NULL, NULL, NULL, O_RDONLY, NULL);
|
server->machine.kd = kvm_open(NULL, NULL, NULL, O_RDONLY, NULL);
|
||||||
if(!server->machine.kd)
|
if(!server->machine.kd)
|
||||||
glibtop_warn_io_r(server, "kvm_open()");
|
glibtop_warn_io_r(server, "kvm_open()");
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Drop priviledges; we only become root when necessary.
|
/* Drop priviledges; we only become root when necessary.
|
||||||
|
|
||||||
setreuid (ruid, euid) - set real and effective user id;
|
setreuid (ruid, euid) - set real and effective user id;
|
||||||
|
@@ -26,11 +26,13 @@
|
|||||||
#include <glibtop/sem_limits.h>
|
#include <glibtop/sem_limits.h>
|
||||||
|
|
||||||
#include <kvm.h>
|
#include <kvm.h>
|
||||||
|
#include <rctl.h>
|
||||||
#include <sys/sem.h>
|
#include <sys/sem.h>
|
||||||
|
|
||||||
static const struct nlist nlst[] = { {"seminfo"}, {NULL} };
|
static const struct nlist nlst[] = { {"glibtop_sem_limits"}, {NULL} };
|
||||||
|
#if GLIBTOP_SOLARIS_RELEASE < 51000
|
||||||
static const unsigned long _glibtop_sysdeps_sem_limits =
|
static const unsigned long _glibtop_sysdeps_sem_limits =
|
||||||
#if GLIBTOP_SOLARIS_RELEASE <= 570
|
#if GLIBTOP_SOLARIS_RELEASE <= 50700
|
||||||
(1L << GLIBTOP_IPC_SEMMAP) +
|
(1L << GLIBTOP_IPC_SEMMAP) +
|
||||||
#endif
|
#endif
|
||||||
(1L << GLIBTOP_IPC_SEMMNI) + (1L << GLIBTOP_IPC_SEMMNS) +
|
(1L << GLIBTOP_IPC_SEMMNI) + (1L << GLIBTOP_IPC_SEMMNS) +
|
||||||
@@ -38,18 +40,25 @@ static const unsigned long _glibtop_sysdeps_sem_limits =
|
|||||||
(1L << GLIBTOP_IPC_SEMOPM) + (1L << GLIBTOP_IPC_SEMUME) +
|
(1L << GLIBTOP_IPC_SEMOPM) + (1L << GLIBTOP_IPC_SEMUME) +
|
||||||
(1L << GLIBTOP_IPC_SEMUSZ) + (1L << GLIBTOP_IPC_SEMVMX) +
|
(1L << GLIBTOP_IPC_SEMUSZ) + (1L << GLIBTOP_IPC_SEMVMX) +
|
||||||
(1L << GLIBTOP_IPC_SEMAEM);
|
(1L << GLIBTOP_IPC_SEMAEM);
|
||||||
|
#else
|
||||||
|
static const unsigned long _glibtop_sysdeps_sem_limits = 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/* Init function. */
|
/* Init function. */
|
||||||
|
|
||||||
void
|
void
|
||||||
glibtop_init_sem_limits_p (glibtop *server)
|
glibtop_init_sem_limits_p (glibtop *server)
|
||||||
{
|
{
|
||||||
|
#if GLIBTOP_SOLARIS_RELEASE < 51000
|
||||||
|
|
||||||
kvm_t *kd = server->machine.kd;
|
kvm_t *kd = server->machine.kd;
|
||||||
|
|
||||||
if(kd && !kvm_nlist(kd, nlst))
|
if(kd && !kvm_nlist(kd, nlst))
|
||||||
server->sysdeps.sem_limits = _glibtop_sysdeps_sem_limits;
|
server->sysdeps.sem_limits = _glibtop_sysdeps_sem_limits;
|
||||||
else
|
else
|
||||||
server->sysdeps.sem_limits = 0;
|
server->sysdeps.sem_limits = 0;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Provides information about sysv sem limits. */
|
/* Provides information about sysv sem limits. */
|
||||||
@@ -57,18 +66,20 @@ glibtop_init_sem_limits_p (glibtop *server)
|
|||||||
void
|
void
|
||||||
glibtop_get_sem_limits_p (glibtop *server, glibtop_sem_limits *buf)
|
glibtop_get_sem_limits_p (glibtop *server, glibtop_sem_limits *buf)
|
||||||
{
|
{
|
||||||
|
#if GLIBTOP_SOLARIS_RELEASE < 51000
|
||||||
kvm_t *kd = server->machine.kd;
|
kvm_t *kd = server->machine.kd;
|
||||||
struct seminfo sinfo;
|
glibtop_sem_limits sinfo;
|
||||||
|
|
||||||
memset (buf, 0, sizeof (glibtop_sem_limits));
|
memset (buf, 0, sizeof (glibtop_sem_limits));
|
||||||
|
|
||||||
if(!(server->sysdeps.sem_limits))
|
if(!(server->sysdeps.sem_limits))
|
||||||
return;
|
return;
|
||||||
if(kvm_read(kd, nlst[0].n_value, (void *)&sinfo,
|
if(kvm_read(kd, nlst[0].n_value, (void *)&sinfo,
|
||||||
sizeof(struct seminfo)) != sizeof(struct seminfo))
|
sizeof(glibtop_sem_limits)) != sizeof(glibtop_sem_limits))
|
||||||
|
|
||||||
return;
|
return;
|
||||||
|
|
||||||
#if GLIBTOP_SOLARIS_RELEASE <= 570
|
#if GLIBTOP_SOLARIS_RELEASE <= 50700
|
||||||
/* This field don't exist anymore in Solaris 8.
|
/* This field don't exist anymore in Solaris 8.
|
||||||
* Thanks to Laszlo PETER <Laszlo.Peter@ireland.sun.com>. */
|
* Thanks to Laszlo PETER <Laszlo.Peter@ireland.sun.com>. */
|
||||||
buf->semmap = sinfo.semmap;
|
buf->semmap = sinfo.semmap;
|
||||||
@@ -82,5 +93,30 @@ glibtop_get_sem_limits_p (glibtop *server, glibtop_sem_limits *buf)
|
|||||||
buf->semusz = sinfo.semusz;
|
buf->semusz = sinfo.semusz;
|
||||||
buf->semvmx = sinfo.semvmx;
|
buf->semvmx = sinfo.semvmx;
|
||||||
buf->semaem = sinfo.semaem;
|
buf->semaem = sinfo.semaem;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if GLIBTOP_SOLARIS_RELEASE >= 51000
|
||||||
|
rctlblk_t *rblk;
|
||||||
|
if ((rblk = malloc(rctlblk_size())) == NULL)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (getrctl("process.max-sem-ops", NULL, rblk, RCTL_FIRST) == -1)
|
||||||
|
return;
|
||||||
|
else
|
||||||
|
buf->semopm = rctlblk_get_value(rblk);
|
||||||
|
|
||||||
|
if (getrctl("process.max-sem-nsems", NULL, rblk, RCTL_FIRST) == -1)
|
||||||
|
return;
|
||||||
|
else
|
||||||
|
buf->semmsl = rctlblk_get_value(rblk);
|
||||||
|
|
||||||
|
if (getrctl("project.max-sem-ids", NULL, rblk, RCTL_FIRST) == -1)
|
||||||
|
return;
|
||||||
|
else
|
||||||
|
buf->semmni = rctlblk_get_value(rblk);
|
||||||
|
/* there are only 3 fields, the remaining ones have been obsoleted in S10
|
||||||
|
and no longer have system-wide limits */
|
||||||
|
#endif
|
||||||
buf->flags = _glibtop_sysdeps_sem_limits;
|
buf->flags = _glibtop_sysdeps_sem_limits;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@@ -26,11 +26,15 @@
|
|||||||
#include <glibtop/shm_limits.h>
|
#include <glibtop/shm_limits.h>
|
||||||
|
|
||||||
#include <kvm.h>
|
#include <kvm.h>
|
||||||
|
#include <rctl.h>
|
||||||
#include <sys/shm.h>
|
#include <sys/shm.h>
|
||||||
|
|
||||||
static const struct nlist nlst[] = { {"shminfo"}, {NULL} };
|
static const struct nlist nlst[] = { {"glibtop_shm_limits"}, {NULL} };
|
||||||
|
|
||||||
#if GLIBTOP_SOLARIS_RELEASE < 590
|
#if GLIBTOP_SOLARIS_RELEASE >=51000
|
||||||
|
static const unsigned long _glibtop_sysdeps_shm_limits = 0;
|
||||||
|
#else
|
||||||
|
# if GLIBTOP_SOLARIS_RELEASE < 50900
|
||||||
static const unsigned long _glibtop_sysdeps_shm_limits =
|
static const unsigned long _glibtop_sysdeps_shm_limits =
|
||||||
(1L << GLIBTOP_IPC_SHMMAX) + (1L << GLIBTOP_IPC_SHMMIN);
|
(1L << GLIBTOP_IPC_SHMMAX) + (1L << GLIBTOP_IPC_SHMMIN);
|
||||||
|
|
||||||
@@ -39,18 +43,22 @@ static const unsigned long _glibtop_sysdeps_shm_limits =
|
|||||||
(1L << GLIBTOP_IPC_SHMMAX) + (1L << GLIBTOP_IPC_SHMMIN) +
|
(1L << GLIBTOP_IPC_SHMMAX) + (1L << GLIBTOP_IPC_SHMMIN) +
|
||||||
(1L << GLIBTOP_IPC_SHMMNI) + (1L << GLIBTOP_IPC_SHMSEG);
|
(1L << GLIBTOP_IPC_SHMMNI) + (1L << GLIBTOP_IPC_SHMSEG);
|
||||||
# endif
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Init function. */
|
/* Init function. */
|
||||||
|
|
||||||
void
|
void
|
||||||
glibtop_init_shm_limits_p (glibtop *server)
|
glibtop_init_shm_limits_p (glibtop *server)
|
||||||
{
|
{
|
||||||
|
#if GLIBTOP_SOLARIS_RELEASE < 51000
|
||||||
|
|
||||||
kvm_t * const kd = server->machine.kd;
|
kvm_t * const kd = server->machine.kd;
|
||||||
|
|
||||||
if(kd && !kvm_nlist(kd, nlst))
|
if(kd && !kvm_nlist(kd, nlst))
|
||||||
server->sysdeps.shm_limits = _glibtop_sysdeps_shm_limits;
|
server->sysdeps.shm_limits = _glibtop_sysdeps_shm_limits;
|
||||||
else
|
else
|
||||||
server->sysdeps.shm_limits = 0;
|
server->sysdeps.shm_limits = 0;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Provides information about sysv ipc limits. */
|
/* Provides information about sysv ipc limits. */
|
||||||
@@ -58,8 +66,11 @@ glibtop_init_shm_limits_p (glibtop *server)
|
|||||||
void
|
void
|
||||||
glibtop_get_shm_limits_p (glibtop *server, glibtop_shm_limits *buf)
|
glibtop_get_shm_limits_p (glibtop *server, glibtop_shm_limits *buf)
|
||||||
{
|
{
|
||||||
|
#if GLIBTOP_SOLARIS_RELEASE < 51000
|
||||||
|
|
||||||
kvm_t * const kd = server->machine.kd;
|
kvm_t * const kd = server->machine.kd;
|
||||||
struct shminfo sinfo;
|
glibtop_shm_limits sinfo;
|
||||||
|
|
||||||
|
|
||||||
memset (buf, 0, sizeof (glibtop_shm_limits));
|
memset (buf, 0, sizeof (glibtop_shm_limits));
|
||||||
|
|
||||||
@@ -67,14 +78,32 @@ glibtop_get_shm_limits_p (glibtop *server, glibtop_shm_limits *buf)
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
if(kvm_read(kd, nlst[0].n_value, (void *)&sinfo,
|
if(kvm_read(kd, nlst[0].n_value, (void *)&sinfo,
|
||||||
sizeof(struct shminfo)) != sizeof(struct shminfo))
|
sizeof(glibtop_shm_limits)) != sizeof(glibtop_shm_limits))
|
||||||
|
|
||||||
return;
|
return;
|
||||||
|
|
||||||
buf->shmmax = sinfo.shmmax;
|
buf->shmmax = sinfo.shmmax;
|
||||||
buf->shmmni = sinfo.shmmni;
|
buf->shmmni = sinfo.shmmni;
|
||||||
#if GLIBTOP_SOLARIS_RELEASE < 590
|
#if GLIBTOP_SOLARIS_RELEASE < 50900
|
||||||
buf->shmmin = sinfo.shmmin;
|
buf->shmmin = sinfo.shmmin;
|
||||||
buf->shmseg = sinfo.shmseg;
|
buf->shmseg = sinfo.shmseg;
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
#if GLIBTOP_SOLARIS_RELEASE >= 51000
|
||||||
|
rctlblk_t *rblk;
|
||||||
|
if ((rblk = malloc(rctlblk_size())) == NULL)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (getrctl("project.max-shm-memory", NULL, rblk, RCTL_FIRST) == -1)
|
||||||
|
return;
|
||||||
|
else
|
||||||
|
buf->shmmax = rctlblk_get_value(rblk);
|
||||||
|
|
||||||
|
if (getrctl("project.max-shm-ids", NULL, rblk, RCTL_FIRST) == -1)
|
||||||
|
return;
|
||||||
|
else
|
||||||
|
buf->shmmni = rctlblk_get_value(rblk);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
buf->flags = _glibtop_sysdeps_shm_limits;
|
buf->flags = _glibtop_sysdeps_shm_limits;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user