ev_qs can request fallback to active vcores (XCC)
[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/sysevent.h>
10 #include <ros/arch/arch.h>
11 #include <ros/common.h>
12 #include <ros/procinfo.h>
13 #include <ros/event.h>
14
15 typedef struct procdata {
16         /*
17         syscall_sring_t                 syscallring;
18         char                                    pad1[SYSCALLRINGSIZE - sizeof(syscall_sring_t)];
19         */
20         syscall_sring_t                 *syscallring;
21         sysevent_sring_t                syseventring;
22         char                                    pad2[SYSEVENTRINGSIZE - sizeof(sysevent_sring_t)];
23 #ifdef __i386__
24         segdesc_t                               *ldt; // TODO: bug with this. (TLSV)
25 #endif
26         /* glibc relies on stuff above this point.  if you change it, you need to
27          * rebuild glibc. */
28         struct event_queue              *kernel_evts[MAX_NR_EVENT];
29         /* Long range, would like these to be mapped in lazily, as the vcores are
30          * requested.  Sharing MAX_NUM_CPUS is a bit weird too. */
31         struct preempt_data             vcore_preempt_data[MAX_NUM_CPUS];
32 } procdata_t;
33
34 #define PROCDATA_NUM_PAGES  ((sizeof(procdata_t)-1)/PGSIZE + 1)
35
36 /* TODO: I dislike having this not be a pointer (for kernel programming) */
37 #define __procdata (*(procdata_t*)UDATA)
38
39 #endif /* ROS_PROCDATA_H */