]> git.saurik.com Git - apple/xnu.git/blobdiff - bsd/sys/vm.h
xnu-6153.61.1.tar.gz
[apple/xnu.git] / bsd / sys / vm.h
index 56f8e55830daa52b6363848e64b698049875d439..f23c43c8851741860ff1fb67d078bd1e5b21fe5a 100644 (file)
@@ -1,15 +1,20 @@
 /*
- * Copyright (c) 2000-2005 Apple Computer, Inc. All rights reserved.
+ * Copyright (c) 2000-2006 Apple Computer, Inc. All rights reserved.
+ *
+ * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
  *
- * @APPLE_LICENSE_HEADER_START@
- * 
  * This file contains Original Code and/or Modifications of Original Code
  * as defined in and that are subject to the Apple Public Source License
  * Version 2.0 (the 'License'). You may not use this file except in
- * compliance with the License. Please obtain a copy of the License at
- * http://www.opensource.apple.com/apsl/ and read it before using this
- * file.
- * 
+ * compliance with the License. The rights granted to you under the License
+ * may not be used to create, or enable the creation or redistribution of,
+ * unlawful or unlicensed copies of an Apple operating system, or to
+ * circumvent, violate, or enable the circumvention or violation of, any
+ * terms of an Apple operating system software license agreement.
+ *
+ * Please obtain a copy of the License at
+ * http://www.opensource.apple.com/apsl/ and read it before using this file.
+ *
  * The Original Code and all software distributed under the License are
  * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
@@ -17,8 +22,8 @@
  * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
  * Please see the License for the specific language governing rights and
  * limitations under the License.
- * 
- * @APPLE_LICENSE_HEADER_END@
+ *
+ * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
  */
 /* Copyright (c) 1995 NeXT Computer, Inc. All Rights Reserved */
 /*
@@ -57,7 +62,7 @@
  */
 /* HISTORY
  *  05-Jun-95  Mac Gillon (mgillon) at NeXT
- *     4.4 code uses this file to import MACH API
+ *      4.4 code uses this file to import MACH API
  */
 
 #ifndef _SYS_VM_H
@@ -69,7 +74,7 @@
 #ifdef BSD_KERNEL_PRIVATE
 
 /* Machine specific config stuff */
-#if    defined(KERNEL) && !defined(MACH_USER_API)      
+#if     defined(KERNEL) && !defined(MACH_USER_API)
 #include <sys/vmmeter.h>
 #include <sys/queue.h>
 #include <mach/vm_param.h>
  * Several fields are temporary (text, data stuff).
  */
 struct vmspace {
-       int     vm_refcnt;      /* number of references */
-       caddr_t vm_shm;         /* SYS5 shared memory private data XXX */
+       int     vm_refcnt;      /* number of references */
+       caddr_t vm_shm;         /* SYS5 shared memory private data XXX */
 /* we copy from vm_startcopy to the end of the structure on fork */
 #define vm_startcopy vm_rssize
-       segsz_t vm_rssize;      /* current resident set size in pages */
-       segsz_t vm_swrss;       /* resident set size before last swap */
-       segsz_t vm_tsize;       /* text size (pages) XXX */
-       segsz_t vm_dsize;       /* data size (pages) XXX */
-       segsz_t vm_ssize;       /* stack size (pages) */
-       caddr_t vm_taddr;       /* user virtual address of text XXX */
-       caddr_t vm_daddr;       /* user virtual address of data XXX */
-       caddr_t vm_maxsaddr;    /* user VA at max stack growth */
+       segsz_t vm_rssize;      /* current resident set size in pages */
+       segsz_t vm_swrss;       /* resident set size before last swap */
+       segsz_t vm_tsize;       /* text size (pages) XXX */
+       segsz_t vm_dsize;       /* data size (pages) XXX */
+       segsz_t vm_ssize;       /* stack size (pages) */
+       caddr_t vm_taddr;       /* user virtual address of text XXX */
+       caddr_t vm_daddr;       /* user virtual address of data XXX */
+       caddr_t vm_maxsaddr;    /* user VA at max stack growth */
 };
 
 #ifdef KERNEL
-// LP64todo - should this move?
-/* LP64 version of vmspace.  all pointers 
+/* LP64 version of vmspace.  all pointers
  * grow when we're dealing with a 64-bit process.
  * WARNING - keep in sync with vmspace
  */
 
-#if __DARWIN_ALIGN_NATURAL
-#pragma options align=natural
-#endif
-
+struct user32_vmspace {
+       int             vm_refcnt;      /* number of references */
+       uint32_t        vm_shm;                 /* SYS5 shared memory private data XXX */
+       segsz_t         vm_rssize;              /* current resident set size in pages */
+       segsz_t         vm_swrss;               /* resident set size before last swap */
+       segsz_t         vm_tsize;               /* text size (pages) XXX */
+       segsz_t         vm_dsize;               /* data size (pages) XXX */
+       segsz_t         vm_ssize;               /* stack size (pages) */
+       uint32_t        vm_taddr;       /* user virtual address of text XXX */
+       uint32_t        vm_daddr;       /* user virtual address of data XXX */
+       uint32_t vm_maxsaddr;   /* user VA at max stack growth */
+};
 struct user_vmspace {
-       int             vm_refcnt;      /* number of references */
-       user_addr_t     vm_shm;                 /* SYS5 shared memory private data XXX */
-       segsz_t         vm_rssize;              /* current resident set size in pages */
-       segsz_t         vm_swrss;               /* resident set size before last swap */
-       segsz_t         vm_tsize;               /* text size (pages) XXX */
-       segsz_t         vm_dsize;               /* data size (pages) XXX */
-       segsz_t         vm_ssize;               /* stack size (pages) */
-       user_addr_t     vm_taddr;       /* user virtual address of text XXX */
-       user_addr_t     vm_daddr;       /* user virtual address of data XXX */
-       user_addr_t vm_maxsaddr;        /* user VA at max stack growth */
+       int             vm_refcnt;      /* number of references */
+       user_addr_t     vm_shm __attribute((aligned(8)));                       /* SYS5 shared memory private data XXX */
+       segsz_t         vm_rssize;              /* current resident set size in pages */
+       segsz_t         vm_swrss;               /* resident set size before last swap */
+       segsz_t         vm_tsize;               /* text size (pages) XXX */
+       segsz_t         vm_dsize;               /* data size (pages) XXX */
+       segsz_t         vm_ssize;               /* stack size (pages) */
+       user_addr_t     vm_taddr __attribute((aligned(8)));       /* user virtual address of text XXX */
+       user_addr_t     vm_daddr;       /* user virtual address of data XXX */
+       user_addr_t vm_maxsaddr;        /* user VA at max stack growth */
 };
 
-#if __DARWIN_ALIGN_NATURAL
-#pragma options align=reset
-#endif
-
 #endif /* KERNEL */
 
 #include <kern/thread.h>
 
 #else /* BSD_KERNEL_PRIVATE */
+
+#include <sys/_types/_caddr_t.h> /* caddr_t */
+#include <sys/_types/_int32_t.h> /* int32_t */
+
 /* just to keep kinfo_proc happy */
 /* NOTE: Pointer fields are size variant for LP64 */
 struct vmspace {
-       int32_t dummy;
-       caddr_t dummy2;
-       int32_t dummy3[5];
-       caddr_t dummy4[3];
+       int32_t dummy;
+       caddr_t dummy2;
+       int32_t dummy3[5];
+       caddr_t dummy4[3];
 };
 
 #endif /* BSD_KERNEL_PRIVATE */