User stackpointers moved to the vcpd structs
[akaros.git] / kern / include / ros / procdata.h
1 /* Copyright (c) 2009 The Regents of the University of California
2  * See LICENSE for details.  */
3
4 #ifndef ROS_PROCDATA_H
5 #define ROS_PROCDATA_H
6
7 #include <ros/memlayout.h>
8 #include <ros/ring_syscall.h>
9 #include <ros/arch/arch.h>
10 #include <ros/common.h>
11 #include <ros/procinfo.h>
12 #include <ros/notification.h>
13
14 typedef struct procdata {
15         syscall_sring_t                 syscallring;
16         char                                    pad1[SYSCALLRINGSIZE - sizeof(syscall_sring_t)];
17         sysevent_sring_t                syseventring;
18         char                                    pad2[SYSEVENTRINGSIZE - sizeof(sysevent_sring_t)];
19 #ifdef __i386__
20         segdesc_t                               *ldt; // TODO: bug with this. (TLSV)
21 #endif
22         /* glibc relies on stuff above this point.  if you change it, you need to
23          * rebuild glibc. */
24         struct notif_method             notif_methods[MAX_NR_NOTIF];
25         /* Long range, would like these to be mapped in lazily, as the vcores are
26          * requested.  Sharing MAX_NUM_CPUS is a bit weird too. */
27         struct preempt_data             vcore_preempt_data[MAX_NUM_CPUS];
28 } procdata_t;
29
30 #define PROCDATA_NUM_PAGES  ((sizeof(procdata_t)-1)/PGSIZE + 1)
31
32 // this is how user programs access the procdata page
33 #ifndef ROS_KERNEL
34 # define __procdata (*(procdata_t*)UDATA)
35 #endif
36
37 #endif // !ROS_PROCDATA_H