X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fcompiler%2Fx86%2Fparms.lisp;h=67655cd8afd8c81a819c46a9effb087406c2750e;hb=e119a2f79cf36039a39996f5490934b4d927529a;hp=ac5c6669c42ee0e9c3b8acef4f06ae0a00ac59d4;hpb=01da8de70d00fe984d3e8be2a56baa3633126644;p=sbcl.git diff --git a/src/compiler/x86/parms.lisp b/src/compiler/x86/parms.lisp index ac5c666..67655cd 100644 --- a/src/compiler/x86/parms.lisp +++ b/src/compiler/x86/parms.lisp @@ -152,6 +152,19 @@ ;;; FYI, this can be looked at with the "pmap" program, and if you ;;; set the top-down mmap allocation option in the kernel (not yet ;;; the default), all bets are totally off! +;;; * For FreeBSD, the requirement of user and kernel space are +;;; getting larger, and users tend to extend them. +;;; If MAXDSIZ is extended from 512MB to 1GB, we can't use up to +;;; around 0x50000000. +;;; And if KVA_PAGES is extended from 1GB to 1.5GB, we can't use +;;; down to around 0xA0000000. +;;; So we use 0x58000000--0x98000000 for dynamic space. +;;; * OpenBSD address space changes for W^X as well as malloc +;;; randomization made the old addresses unsafe. The only range +;;; that is really safe is between the end of the text segment (it +;;; starts at #x3C000000) and #x7C000000. However if the -Z linker +;;; option is used then the safe range is (probably) #x00001000 to +;;; #x48048000, with the text and data segments at #x08048000. #!+win32 (progn @@ -204,26 +217,26 @@ (def!constant static-space-start #x01100000) (def!constant static-space-end #x011ff000) - (def!constant dynamic-space-start #x60000000) - (def!constant dynamic-space-end #xA0000000) + (def!constant dynamic-space-start #x58000000) + (def!constant dynamic-space-end #x98000000) (def!constant linkage-table-space-start #x01200000) (def!constant linkage-table-space-end #x012ff000)) #!+openbsd (progn - (def!constant read-only-space-start #x10000000) - (def!constant read-only-space-end #x100ff000) + (def!constant read-only-space-start #x7b000000) + (def!constant read-only-space-end #x7b0ff000) - (def!constant static-space-start #x10100000) - (def!constant static-space-end #x101ff000) + (def!constant static-space-start #x7b100000) + (def!constant static-space-end #x7b1ff000) - (def!constant dynamic-space-start #x80000000) - (def!constant dynamic-space-end #xA0000000) + (def!constant dynamic-space-start #x4c000000) + (def!constant dynamic-space-end #x7b0ff000) ;; In CMUCL: 0xB0000000->0xB1000000 - (def!constant linkage-table-space-start #x10200000) - (def!constant linkage-table-space-end #x102ff000)) + (def!constant linkage-table-space-start #x7b200000) + (def!constant linkage-table-space-end #x7b2ff000)) #!+netbsd (progn @@ -338,6 +351,9 @@ ;; For GC-AND-SAVE *restart-lisp-function* + ;; For the UNWIND-TO-FRAME-AND-CALL VOP + *unwind-to-frame-function* + ;; Needed for callbacks to work across saving cores. see ;; ALIEN-CALLBACK-ASSEMBLER-WRAPPER in c-call.lisp for gory ;; details.