pullout some dlinfo code from proc_modules to be reused
This commit is contained in:
parent
19e7aa64a5
commit
5213a822f6
|
@ -483,6 +483,37 @@ static int sigar_pgrab(sigar_t *sigar, sigar_pid_t pid,
|
||||||
return SIGAR_OK;
|
return SIGAR_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int sigar_dlinfo_get(sigar_t *sigar, const char *func,
|
||||||
|
void **handle, Link_map **map)
|
||||||
|
{
|
||||||
|
Dl_info dli;
|
||||||
|
|
||||||
|
if (!dladdr((void *)((uintptr_t)sigar_dlinfo_get), &dli)) {
|
||||||
|
sigar_log_printf(sigar, SIGAR_LOG_ERROR,
|
||||||
|
"[%s] dladdr(%s) = %s",
|
||||||
|
func, SIGAR_FUNC, dlerror());
|
||||||
|
return ESRCH;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!(*handle = dlopen(dli.dli_fname, RTLD_LAZY))) {
|
||||||
|
sigar_log_printf(sigar, SIGAR_LOG_ERROR,
|
||||||
|
"[%s] dlopen(%s) = %s",
|
||||||
|
func, dli.dli_fname, dlerror());
|
||||||
|
return ESRCH;
|
||||||
|
}
|
||||||
|
|
||||||
|
dlinfo(*handle, RTLD_DI_LINKMAP, map);
|
||||||
|
|
||||||
|
if (!map) {
|
||||||
|
sigar_log_printf(sigar, SIGAR_LOG_ERROR,
|
||||||
|
"[%s] dlinfo = %s",
|
||||||
|
func, dlerror());
|
||||||
|
return ESRCH;
|
||||||
|
}
|
||||||
|
|
||||||
|
return SIGAR_OK;
|
||||||
|
}
|
||||||
|
|
||||||
int sigar_proc_list_get(sigar_t *sigar,
|
int sigar_proc_list_get(sigar_t *sigar,
|
||||||
sigar_proc_list_t *proclist)
|
sigar_proc_list_t *proclist)
|
||||||
{
|
{
|
||||||
|
@ -897,26 +928,15 @@ static int sigar_pgrab_modules(sigar_t *sigar, sigar_pid_t pid,
|
||||||
|
|
||||||
static int sigar_dlinfo_modules(sigar_t *sigar, sigar_proc_modules_t *procmods)
|
static int sigar_dlinfo_modules(sigar_t *sigar, sigar_proc_modules_t *procmods)
|
||||||
{
|
{
|
||||||
|
int status;
|
||||||
void *handle;
|
void *handle;
|
||||||
Dl_info dli;
|
|
||||||
Link_map *map;
|
Link_map *map;
|
||||||
|
|
||||||
if (!dladdr((void *)((uintptr_t)sigar_dlinfo_modules), &dli)) {
|
status = sigar_dlinfo_get(sigar, SIGAR_FUNC, &handle, &map);
|
||||||
sigar_log_printf(sigar, SIGAR_LOG_ERROR,
|
if (status != SIGAR_OK) {
|
||||||
"[%s] dladdr(%s) = %s",
|
return status;
|
||||||
SIGAR_FUNC, SIGAR_FUNC, dlerror());
|
|
||||||
return ESRCH;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(handle = dlopen(dli.dli_fname, RTLD_LAZY))) {
|
|
||||||
sigar_log_printf(sigar, SIGAR_LOG_ERROR,
|
|
||||||
"[%s] dlopen(%s) = %s",
|
|
||||||
SIGAR_FUNC, dli.dli_fname, dlerror());
|
|
||||||
return ESRCH;
|
|
||||||
}
|
|
||||||
|
|
||||||
dlinfo(handle, RTLD_DI_LINKMAP, &map);
|
|
||||||
|
|
||||||
do {
|
do {
|
||||||
int status =
|
int status =
|
||||||
procmods->module_getter(procmods->data,
|
procmods->module_getter(procmods->data,
|
||||||
|
|
Loading…
Reference in New Issue