diff options
author | Sam Hartman <hartmans@debian.org> | 2023-09-11 14:10:02 -0600 |
---|---|---|
committer | Sam Hartman <hartmans@debian.org> | 2023-09-11 14:10:02 -0600 |
commit | 42408448b00a7a2150b5853dc4f63296b6827e0e (patch) | |
tree | f2d801e728b41563b77ebe89a3d560319ff37d31 /libpam/pam_dynamic.c | |
parent | b99a4f53dcf4725e4b3b861fd8a28c0156a8a147 (diff) | |
parent | e9aa2ef52a423a3a33299bf7e8715eb5bd76ea67 (diff) | |
download | pam-42408448b00a7a2150b5853dc4f63296b6827e0e.tar.gz pam-42408448b00a7a2150b5853dc4f63296b6827e0e.tar.bz2 pam-42408448b00a7a2150b5853dc4f63296b6827e0e.zip |
Update upstream source from tag 'upstream/1.5.3'
Update to upstream version '1.5.3'
with Debian dir 6b9d9dfb8a4ca02d4557097ee59960e72a6a4a29
Diffstat (limited to 'libpam/pam_dynamic.c')
-rw-r--r-- | libpam/pam_dynamic.c | 84 |
1 files changed, 1 insertions, 83 deletions
diff --git a/libpam/pam_dynamic.c b/libpam/pam_dynamic.c index c063083f..81f49b43 100644 --- a/libpam/pam_dynamic.c +++ b/libpam/pam_dynamic.c @@ -32,107 +32,25 @@ */ #include "pam_private.h" - -#ifdef PAM_SHL -# include <dl.h> -#elif defined(PAM_DYLD) -# include <mach-o/dyld.h> -#else /* PAM_SHL */ -# include <dlfcn.h> -#endif /* PAM_SHL */ - -#ifndef SHLIB_SYM_PREFIX -#define SHLIB_SYM_PREFIX "_" -#endif +#include <dlfcn.h> void *_pam_dlopen(const char *mod_path) { -#ifdef PAM_SHL - return shl_load(mod_path, BIND_IMMEDIATE, 0L); -#elif defined(PAM_DYLD) - NSObjectFileImage ofile; - void *ret = NULL; - - if (NSCreateObjectFileImageFromFile(mod_path, &ofile) != - NSObjectFileImageSuccess ) - return NULL; - - ret = NSLinkModule(ofile, mod_path, NSLINKMODULE_OPTION_PRIVATE | NSLINKMODULE_OPTION_BINDNOW); - NSDestroyObjectFileImage(ofile); - - return ret; -#else return dlopen(mod_path, RTLD_NOW); -#endif } servicefn _pam_dlsym(void *handle, const char *symbol) { -#ifdef PAM_SHL - char *_symbol = NULL; - servicefn ret; - - if( symbol == NULL ) - return NULL; - - if( shl_findsym(&handle, symbol, (short) TYPE_PROCEDURE, &ret ){ - _symbol = malloc( strlen(symbol) + sizeof(SHLIB_SYM_PREFIX) + 1 ); - if( _symbol == NULL ) - return NULL; - strcpy(_symbol, SHLIB_SYM_PREFIX); - strcat(_symbol, symbol); - if( shl_findsym(&handle, _symbol, - (short) TYPE_PROCEDURE, &ret ){ - free(_symbol); - return NULL; - } - free(_symbol); - } - - return ret; - -#elif defined(PAM_DYLD) - NSSymbol nsSymbol; - char *_symbol; - - if( symbol == NULL ) - return NULL; - _symbol = malloc( strlen(symbol) + 2 ); - if( _symbol == NULL ) - return NULL; - strcpy(_symbol, SHLIB_SYM_PREFIX); - strcat(_symbol, symbol); - - nsSymbol = NSLookupSymbolInModule(handle, _symbol); - if( nsSymbol == NULL ) - return NULL; - free(_symbol); - - return (servicefn)NSAddressOfSymbol(nsSymbol); -#else return (servicefn) dlsym(handle, symbol); -#endif } void _pam_dlclose(void *handle) { -#ifdef PAM_SHL - shl_unload(handle); -#elif defined(PAM_DYLD) - NSUnLinkModule((NSModule)handle, NSUNLINKMODULE_OPTION_NONE); -#else dlclose(handle); -#endif - - return; } const char * _pam_dlerror (void) { -#if defined(PAM_SHL) || defined(PAM_DYLD) - return "unknown"; -#else return dlerror (); -#endif } |