IBNOS
thread.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2014, Michael Müller
3  * Copyright (c) 2014, Sebastian Lackner
4  * All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions are met:
8  *
9  * 1. Redistributions of source code must retain the above copyright notice, this
10  * list of conditions and the following disclaimer.
11  * 2. Redistributions in binary form must reproduce the above copyright notice,
12  * this list of conditions and the following disclaimer in the documentation
13  * and/or other materials provided with the distribution.
14  *
15  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
16  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
17  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
18  * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
19  * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
20  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
21  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
22  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
24  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25  *
26  */
27 
28 #ifndef _H_THREAD_
29 #define _H_THREAD_
30 
31 
32 #ifdef __KERNEL__
33 
34  struct thread;
35 
36  #include <stdint.h>
37  #include <stdbool.h>
38 
39  #include <process/object.h>
40  #include <process/process.h>
41  #include <hardware/context.h>
42  #include <util/list.h>
43 
44  extern struct linkedList threadList;
45  extern struct thread *lastFPUthread;
46 
47  struct thread
48  {
49  struct object obj;
51  bool blocked;
52 
53  /* entry in the list of the associated process (not refcounted) */
54  struct process *process;
56  uint32_t exitcode;
57 
58  /* fpu was initialized for this thread */
60 
61  /* ring3 stack mapped in user space */
63  uint32_t user_ring3StackLength; /* in pages */
64 
65  /* thread local block in user space */
67  uint32_t user_threadLocalLength; /* in pages */
68 
69  struct taskContext task;
70  struct fpuContext fpu;
71  };
72 
73  #define DEFAULT_STACK_SIZE 0x10000
74  #define DEFAULT_TLB_SIZE 0x1000
75 
76  struct thread *threadCreate(struct process *p, struct thread *original, void *eip);
77  struct thread *threadRun(struct thread *t);
78  void threadRelease(struct thread *t);
79 
80  void threadSchedule();
81 
82  uint32_t threadWait(struct thread *t, struct object *obj, uint32_t mode);
83 
84 #endif
85 
86 #endif /* _H_THREAD_ */
struct thread * threadCreate(struct process *p, struct thread *original, void *eip)
Creates a new kernel thread object.
Definition: thread.c:80
void threadRelease(struct thread *t)
bool fpuInitialized
Definition: thread.h:59
struct linkedList threadList
Definition: thread.c:44
void threadSchedule()
Schedules threads until all process have been terminated.
Definition: thread.c:355
void * user_ring3StackBase
Definition: thread.h:62
struct thread * lastFPUthread
Definition: thread.c:45
struct object obj
Definition: thread.h:49
Definition: object.h:69
Definition: thread.h:47
void * user_threadLocalBase
Definition: thread.h:66
uint32_t user_threadLocalLength
Definition: thread.h:67
uint32_t eip
Definition: context.h:186
struct linkedList waiters
Definition: thread.h:50
uint32_t exitcode
Definition: thread.h:56
struct linkedList entry_process
Definition: thread.h:55
struct fpuContext fpu
Definition: thread.h:70
struct process * process
Definition: thread.h:54
struct thread * threadRun(struct thread *t)
struct taskContext task
Definition: thread.h:69
uint32_t threadWait(struct thread *t, struct object *obj, uint32_t mode)
Makes a kernel thread object wait for some waitable object.
Definition: thread.c:388
char mode[8]
Definition: filesystem.h:65
uint32_t user_ring3StackLength
Definition: thread.h:63
bool blocked
Definition: thread.h:51