X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fcode%2Fbsd-os.lisp;h=5567c3f7ae7577d21649b71d4445743c36e5b8c3;hb=3a10f894e7867fa2c27a3af05380abc3247f728d;hp=e36b615c8794510ab88b59fd1aff49b14b6b107e;hpb=a530bbe337109d898d5b4a001fc8f1afa3b5dc39;p=sbcl.git diff --git a/src/code/bsd-os.lisp b/src/code/bsd-os.lisp index e36b615..5567c3f 100644 --- a/src/code/bsd-os.lisp +++ b/src/code/bsd-os.lisp @@ -4,9 +4,6 @@ ;;;; Carnegie Mellon University, and has been placed in the public ;;;; domain. -(sb!int:file-comment - "$Header$") - (in-package "SB!SYS") ;;;; Check that target machine features are set up consistently with @@ -21,26 +18,28 @@ #!+FreeBSD "FreeBSD" #!+OpenBSD "OpenBSD")) +(defvar *software-version* nil) + (defun software-version () #!+sb-doc "Return a string describing version of the supporting software, or NIL if not available." - #+nil ; won't work until we support RUN-PROGRAM.. - (unless *software-version* - (setf *software-version* - (string-trim '(#\newline) - (with-output-to-string (stream) - (run-program "/usr/bin/uname" - '("-r") - :output stream))))) - nil) + (or *software-version* + (setf *software-version* + (string-trim '(#\newline) + (with-output-to-string (stream) + (sb!ext:run-program "/usr/bin/uname" `("-r") + :output stream)))))) -;;; OS-COLD-INIT-OR-REINIT initializes our operating-system interface. -;;; It sets the values of the global port variables to what they -;;; should be and calls the functions that set up the argument blocks -;;; for the server interfaces. (defun os-cold-init-or-reinit () - (setf *software-version* nil)) + (setf *software-version* nil) + (setf *default-pathname-defaults* + ;; (temporary value, so that #'PATHNAME won't blow up when + ;; we call it below:) + (make-trivial-default-pathname) + *default-pathname-defaults* + ;; (final value, constructed using #'PATHNAME:) + (pathname (sb!unix:posix-getcwd/)))) ;;; Return system time, user time and number of page faults. (defun get-system-info () @@ -49,8 +48,7 @@ (sb!unix:unix-getrusage sb!unix:rusage_self) (declare (ignore maxrss ixrss idrss isrss minflt)) (unless err? - (error "Unix system call getrusage failed: ~A." - (sb!unix:get-unix-error-msg utime))) + (simple-perror "Unix system call getrusage() failed" :errno utime)) (values utime stime majflt)))