My Project
Loading...
Searching...
No Matches
Macros | Enumerations | Functions
mod_raw.h File Reference

Go to the source code of this file.

Macros

#define DYNL_KERNEL_HANDLE   ((void*) 0x1)
 

Enumerations

enum  lib_types {
  LT_NONE , LT_NOTFOUND , LT_SINGULAR , LT_ELF ,
  LT_HPUX , LT_MACH_O , LT_BUILTIN , LT_DLL
}
 

Functions

void * dynl_open_binary_warn (const char *binary_name, const char *msg=NULL)
 
void * dynl_sym_warn (void *handle, const char *proc, const char *msg=NULL)
 
int dynl_check_opened (char *filename)
 
void * dynl_open (char *filename)
 
void * dynl_sym (void *handle, const char *symbol)
 
int dynl_close (void *handle)
 
const char * dynl_error ()
 

Macro Definition Documentation

◆ DYNL_KERNEL_HANDLE

#define DYNL_KERNEL_HANDLE   ((void*) 0x1)

Definition at line 32 of file mod_raw.h.

Enumeration Type Documentation

◆ lib_types

enum lib_types
Enumerator
LT_NONE 
LT_NOTFOUND 
LT_SINGULAR 
LT_ELF 
LT_HPUX 
LT_MACH_O 
LT_BUILTIN 
LT_DLL 

Definition at line 16 of file mod_raw.h.

lib_types
Definition: mod_raw.h:16
@ LT_MACH_O
Definition: mod_raw.h:16
@ LT_HPUX
Definition: mod_raw.h:16
@ LT_DLL
Definition: mod_raw.h:16
@ LT_SINGULAR
Definition: mod_raw.h:16
@ LT_BUILTIN
Definition: mod_raw.h:16
@ LT_ELF
Definition: mod_raw.h:16
@ LT_NONE
Definition: mod_raw.h:16
@ LT_NOTFOUND
Definition: mod_raw.h:16

Function Documentation

◆ dynl_check_opened()

int dynl_check_opened ( char *  filename)

Definition at line 135 of file mod_raw.cc.

138{
139 return dlopen(filename,RTLD_NOW|RTLD_NOLOAD) != NULL;
140}
#define NULL
Definition: omList.c:12

◆ dynl_close()

int dynl_close ( void *  handle)

Definition at line 170 of file mod_raw.cc.

171{
172 return(dlclose (handle));
173}

◆ dynl_error()

const char * dynl_error ( )

Definition at line 175 of file mod_raw.cc.

176{
177 return(dlerror());
178}

◆ dynl_open()

void * dynl_open ( char *  filename)

Definition at line 142 of file mod_raw.cc.

145{
146 return dlopen(filename, RTLD_NOW|RTLD_GLOBAL);
147#if 0
148// glibc 2.2:
149 if ((filename==NULL) || (dlopen(filename,RTLD_NOW|RTLD_NOLOAD)==NULL))
150 return(dlopen(filename, RTLD_NOW|RTLD_GLOBAL));
151 else
152 Werror("module %s already loaded",filename);
153 return NULL;
154// alternative
155// return(dlopen(filename, RTLD_NOW|RTLD_GLOBAL));
156#endif
157}
void Werror(const char *fmt,...)
Definition: reporter.cc:189

◆ dynl_open_binary_warn()

void * dynl_open_binary_warn ( const char *  binary_name,
const char *  msg = NULL 
)

Definition at line 45 of file mod_raw.cc.

46{
47 void* handle = NULL;
48 char* binary_name_so=NULL;
50
51 // try P_PROCS_DIR (%P)
52 char* proc_path = feGetResource('P');
53 if (proc_path != NULL)
54 {
55 char *p;
56 char *q;
57 p=proc_path;
58 int binary_name_so_length = 3 + strlen(DL_TAIL) + strlen(binary_name) + strlen(DIR_SEPP) + strlen(proc_path);
59 binary_name_so = (char *)omAlloc0( binary_name_so_length * sizeof(char) );
60 while((p!=NULL)&&(*p!='\0'))
61 {
62 q=strchr(p,fePathSep);
63 if (q!=NULL) *q='\0';
64 strcpy(binary_name_so,p);
65 if (q!=NULL) *q=fePathSep;
66 strcat(binary_name_so,DIR_SEPP);
67 strcat(binary_name_so,binary_name);
68 strcat(binary_name_so,DL_TAIL);
69 if(!access(binary_name_so, R_OK)) { found=TRUE; break; }
70 if (q!=NULL) p=q+1; else p=NULL;
71 }
72 if (found) handle = dynl_open(binary_name_so);
73 }
74
75 if (handle == NULL && ! warn_handle)
76 {
77 Warn("Could not find dynamic library: %s%s (path %s)",
78 binary_name, DL_TAIL,proc_path);
79 if (found) Warn("Error message from system: %s", dynl_error());
80 if (msg != NULL) Warn("%s", msg);
81 WarnS("See the INSTALL section in the Singular manual for details.");
83 }
84 omfree((ADDRESS)binary_name_so );
85
86 return handle;
87}
int BOOLEAN
Definition: auxiliary.h:87
#define TRUE
Definition: auxiliary.h:100
#define FALSE
Definition: auxiliary.h:96
void * ADDRESS
Definition: auxiliary.h:119
int p
Definition: cfModGcd.cc:4078
#define Warn
Definition: emacs.cc:77
#define WarnS
Definition: emacs.cc:78
bool found
Definition: facFactorize.cc:55
char * feGetResource(const char id, int warn)
Definition: feResource.cc:148
const char fePathSep
Definition: feResource.h:58
#define DIR_SEPP
Definition: feResource.h:7
STATIC_VAR BOOLEAN warn_handle
Definition: mod_raw.cc:38
#define DL_TAIL
Definition: mod_raw.cc:41
const char * dynl_error()
Definition: mod_raw.cc:175
void * dynl_open(char *filename)
Definition: mod_raw.cc:142
#define omfree(addr)
Definition: omAllocDecl.h:237
#define omAlloc0(size)
Definition: omAllocDecl.h:211

◆ dynl_sym()

void * dynl_sym ( void *  handle,
const char *  symbol 
)

Definition at line 159 of file mod_raw.cc.

160{
161 if (handle == DYNL_KERNEL_HANDLE)
162 {
163 if (kernel_handle == NULL)
165 handle = kernel_handle;
166 }
167 return(dlsym(handle, symbol));
168}
STATIC_VAR void * kernel_handle
Definition: mod_raw.cc:134
#define DYNL_KERNEL_HANDLE
Definition: mod_raw.h:32

◆ dynl_sym_warn()

void * dynl_sym_warn ( void *  handle,
const char *  proc,
const char *  msg = NULL 
)

Definition at line 89 of file mod_raw.cc.

90{
91 void *proc_ptr = NULL;
92 if (handle != NULL)
93 {
94 proc_ptr = dynl_sym(handle, proc);
95 if (proc_ptr == NULL && ! warn_proc)
96 {
97 WarnS("Could load a procedure from a dynamic library");
98 Warn("Error message from system: %s", dynl_error());
99 if (msg != NULL) Warn("%s", msg);
100 WarnS("See the INSTALL section in the Singular manual for details.");
101 warn_proc = TRUE;
102 }
103 }
104 return proc_ptr;
105}
unsigned char * proc[NUM_PROC]
Definition: checklibs.c:16
void * dynl_sym(void *handle, const char *symbol)
Definition: mod_raw.cc:159
STATIC_VAR BOOLEAN warn_proc
Definition: mod_raw.cc:39