X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fcode%2Fforeign.lisp;h=be46641abca9b94464611a23c67bd02e6fa0bf06;hb=829ced3e78a23ba153ba4db64e6ea6984c2313b6;hp=cd838675613687198af7227565cda9821a3aadfa;hpb=b43d36ddab647b955432acc51a6d2aec3a128482;p=sbcl.git diff --git a/src/code/foreign.lisp b/src/code/foreign.lisp index cd83867..be46641 100644 --- a/src/code/foreign.lisp +++ b/src/code/foreign.lisp @@ -53,7 +53,10 @@ Dynamic symbols are entered into the linkage-table if they aren't there already. On non-linkage-table ports signals an error if the symbol isn't found." (declare (ignorable datap)) - (let ((static (find-foreign-symbol-in-table name *static-foreign-symbols*))) + #!+sb-dynamic-core + (values (ensure-foreign-symbol-linkage name datap) t) + #!-sb-dynamic-core + (let ((static (find-foreign-symbol-in-table name *static-foreign-symbols*))) (if static (values static nil) #!+os-provides-dlopen @@ -80,8 +83,7 @@ if the symbol isn't found." #!+linkage-table (multiple-value-bind (addr sharedp) (foreign-symbol-address symbol datap) - #+sb-xc-host - (aver (not sharedp)) + #+sb-xc-host #!-sb-dynamic-core (aver (not sharedp)) () ;; If the address is from linkage-table and refers to data ;; we need to do a bit of juggling. It is not the address of the ;; variable, but the address where the real address is stored. @@ -103,7 +105,7 @@ if the symbol isn't found." ;;; Cleanups before saving a core #-sb-xc-host (defun foreign-deinit () - #!+(and os-provides-dlopen (or (not linkage-table) win32)) + #!+(and os-provides-dlopen (not linkage-table)) (when (dynamic-foreign-symbols-p) (warn "~@