X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Fcode%2Fforeign.lisp;h=a735e7646fccdcae00bb506c6b0a0ae3c2a3bfe9;hb=625c9493a8a7b5186144d21302437cf4f4f3571c;hp=bd89cd83e8e977a0cfa38553a93a0ab36f06cebd;hpb=fe19212267bef96fedb712ebb43abc91631aea18;p=sbcl.git diff --git a/src/code/foreign.lisp b/src/code/foreign.lisp index bd89cd8..a735e76 100644 --- a/src/code/foreign.lisp +++ b/src/code/foreign.lisp @@ -16,8 +16,8 @@ (defun extern-alien-name (name) (handler-case - #!+elf (coerce name 'base-string) - #!+(or mach-o win32) (concatenate 'base-string "_" name) + #!-win32 (coerce name 'base-string) + #!+win32 (concatenate 'base-string "_" name) (error () (error "invalid external alien name: ~S" name)))) @@ -34,10 +34,7 @@ (let ((extern (extern-alien-name name))) (values (or (gethash extern table) - (gethash (concatenate 'base-string - #!+(and darwin (or x86 x86-64 ppc)) "_ldso_stub__" - #!-(and darwin (or x86 x86-64 ppc)) "ldso_stub__" - extern) table))))) + (gethash (concatenate 'base-string "ldso_stub__" extern) table))))) (defun find-foreign-symbol-address (name) "Returns the address of the foreign symbol NAME, or NIL. Does not enter the @@ -142,7 +139,10 @@ if the symbol isn't found." (symbol-address unsigned))) (dladdr (function unsigned unsigned (* (struct dl-info))) :extern "dladdr")) - (let ((err (alien-funcall dladdr addr (addr info)))) + (let ((err (without-gcing + ;; On eg. Darwin GC can could otherwise interrupt + ;; the call while dladdr is holding a lock. + (alien-funcall dladdr addr (addr info))))) (if (zerop err) nil (slot info 'symbol))))