1 /* Function prototypes. */
6 #include <minix/safecopies.h>
10 /* Struct declarations. */
15 _PROTOTYPE( void clock_init
, (void) );
16 _PROTOTYPE( clock_t get_uptime
, (void) );
17 _PROTOTYPE( void set_timer
, (struct timer
*tp
, clock_t t
, tmr_func_t f
) );
18 _PROTOTYPE( void reset_timer
, (struct timer
*tp
) );
19 _PROTOTYPE( void ser_dump_proc
, (void) );
21 _PROTOTYPE( void cycles_accounting_init
, (void) );
23 * This functions start and stop accounting for process, kernel or idle cycles.
24 * It inherently have to account for some kernel cycles for process too,
25 * therefore it should be called asap after trapping to kernel and as late as
26 * possible before returning to userspace. These function is architecture
29 _PROTOTYPE( void cycles_accounting_stop
, (struct proc
* p
) );
30 /* this is a wrapper to make calling it from assembly easier */
31 _PROTOTYPE( void cycles_accounting_stop_idle
, (void) );
34 _PROTOTYPE( void main
, (void) );
35 _PROTOTYPE( void prepare_shutdown
, (int how
) );
36 _PROTOTYPE( void minix_shutdown
, (struct timer
*tp
) );
39 _PROTOTYPE( void minix_panic
, (char *s
, int n
) );
42 _PROTOTYPE( int do_ipc
, (int call_nr
, int src_dst
,
43 message
*m_ptr
, long bit_map
) );
44 _PROTOTYPE( int mini_notify
, (struct proc
*src
, endpoint_t dst
) );
45 _PROTOTYPE( void enqueue
, (struct proc
*rp
) );
46 _PROTOTYPE( void dequeue
, (struct proc
*rp
) );
47 _PROTOTYPE( void balance_queues
, (struct timer
*tp
) );
48 _PROTOTYPE( struct proc
* schedcheck
, (void) );
49 _PROTOTYPE( struct proc
* arch_finish_schedcheck
, (void) );
50 _PROTOTYPE( struct proc
*endpoint_lookup
, (endpoint_t ep
) );
51 #if DEBUG_ENABLE_IPC_WARNINGS
52 _PROTOTYPE( int isokendpt_f
, (char *file
, int line
, endpoint_t e
, int *p
, int f
));
53 #define isokendpt_d(e, p, f) isokendpt_f(__FILE__, __LINE__, (e), (p), (f))
55 _PROTOTYPE( int isokendpt_f
, (endpoint_t e
, int *p
, int f
) );
56 #define isokendpt_d(e, p, f) isokendpt_f((e), (p), (f))
60 _PROTOTYPE( void cstart
, (U16_t cs
, U16_t ds
, U16_t mds
,
61 U16_t parmoff
, U16_t parmsize
) );
64 _PROTOTYPE( int get_priv
, (register struct proc
*rc
, int proc_type
) );
65 _PROTOTYPE( void set_sendto_bit
, (struct proc
*rc
, int id
) );
66 _PROTOTYPE( void unset_sendto_bit
, (struct proc
*rc
, int id
) );
67 _PROTOTYPE( void send_sig
, (int proc_nr
, int sig_nr
) );
68 _PROTOTYPE( void cause_sig
, (proc_nr_t proc_nr
, int sig_nr
) );
69 _PROTOTYPE( void sig_delay_done
, (struct proc
*rp
) );
70 _PROTOTYPE( void kernel_call
, (message
*m_user
, struct proc
* caller
) );
71 _PROTOTYPE( void system_init
, (void) );
72 #define numap_local(proc_nr, vir_addr, bytes) \
73 umap_local(proc_addr(proc_nr), D, (vir_addr), (bytes))
74 _PROTOTYPE( phys_bytes umap_grant
, (struct proc
*, cp_grant_id_t
, vir_bytes
));
75 _PROTOTYPE( void clear_endpoint
, (struct proc
*rc
) );
76 _PROTOTYPE( phys_bytes umap_bios
, (vir_bytes vir_addr
, vir_bytes bytes
));
77 _PROTOTYPE( void kernel_call_resume
, (struct proc
*p
));
79 /* system/do_newmap.c */
80 _PROTOTYPE( int newmap
, (struct proc
* caller
, struct proc
*rp
,
81 struct mem_map
*map_ptr
));
83 /* system/do_vtimer.c */
84 _PROTOTYPE( void vtimer_check
, (struct proc
*rp
) );
87 _PROTOTYPE( void put_irq_handler
, (irq_hook_t
*hook
, int irq
,
88 irq_handler_t handler
) );
89 _PROTOTYPE( void rm_irq_handler
, (irq_hook_t
*hook
) );
90 _PROTOTYPE( void enable_irq
, (irq_hook_t
*hook
) );
91 _PROTOTYPE( int disable_irq
, (irq_hook_t
*hook
) );
95 #define CHECK_RUNQUEUES check_runqueues_f(__FILE__, __LINE__)
96 _PROTOTYPE( void check_runqueues_f
, (char *file
, int line
) );
98 _PROTOTYPE( char *rtsflagstr
, (int flags
) );
99 _PROTOTYPE( char *miscflagstr
, (int flags
) );
101 /* system/do_safemap.c */
102 _PROTOTYPE( int map_invoke_vm
, (struct proc
* caller
, int req_type
,
103 endpoint_t end_d
, int seg_d
, vir_bytes off_d
,
104 endpoint_t end_s
, int seg_s
, vir_bytes off_s
,
105 size_t size
, int flag
));
107 /* system/do_safecopy.c */
108 _PROTOTYPE( int verify_grant
, (endpoint_t
, endpoint_t
,
109 cp_grant_id_t
, vir_bytes
, int,
110 vir_bytes
, vir_bytes
*, endpoint_t
*));
112 /* system/do_sysctl.c */
113 _PROTOTYPE( int do_sysctl
, (struct proc
* caller
, message
*m
));
117 _PROTOTYPE( void init_profile_clock
, (u32_t
) );
118 _PROTOTYPE( void stop_profile_clock
, (void) );
121 /* functions defined in architecture-dependent files. */
122 _PROTOTYPE( void prot_init
, (void) );
123 _PROTOTYPE( phys_bytes phys_copy
, (phys_bytes source
, phys_bytes dest
,
125 _PROTOTYPE( void phys_copy_fault
, (void));
126 _PROTOTYPE( void phys_copy_fault_in_kernel
, (void));
127 #define virtual_copy(src, dst, bytes) \
128 virtual_copy_f(NULL, src, dst, bytes, 0)
129 #define virtual_copy_vmcheck(caller, src, dst, bytes) \
130 virtual_copy_f(caller, src, dst, bytes, 1)
131 _PROTOTYPE( int virtual_copy_f
, (struct proc
* caller
,
132 struct vir_addr
*src
, struct vir_addr
*dst
,
133 vir_bytes bytes
, int vmcheck
) );
134 _PROTOTYPE( int data_copy
, (endpoint_t from
, vir_bytes from_addr
,
135 endpoint_t to
, vir_bytes to_addr
, size_t bytes
));
136 _PROTOTYPE( int data_copy_vmcheck
, (struct proc
*,
137 endpoint_t from
, vir_bytes from_addr
,
138 endpoint_t to
, vir_bytes to_addr
, size_t bytes
));
139 _PROTOTYPE( void alloc_segments
, (struct proc
*rp
) );
140 _PROTOTYPE( void vm_init
, (struct proc
*first
) );
141 _PROTOTYPE( phys_bytes umap_local
, (register struct proc
*rp
, int seg
,
142 vir_bytes vir_addr
, vir_bytes bytes
));
143 _PROTOTYPE( void cp_mess
, (int src
,phys_clicks src_clicks
,
144 vir_bytes src_offset
, phys_clicks dst_clicks
, vir_bytes dst_offset
));
145 _PROTOTYPE( phys_bytes umap_remote
, (struct proc
* rp
, int seg
,
146 vir_bytes vir_addr
, vir_bytes bytes
) );
147 _PROTOTYPE( phys_bytes umap_virtual
, (struct proc
* rp
,
148 int seg
, vir_bytes vir_addr
, vir_bytes bytes
) );
149 _PROTOTYPE( phys_bytes seg2phys
, (U16_t
) );
150 _PROTOTYPE( int vm_phys_memset
, (phys_bytes source
, u8_t pattern
,
152 _PROTOTYPE( vir_bytes alloc_remote_segment
, (u32_t
*, segframe_t
*,
153 int, phys_bytes
, vir_bytes
, int));
154 _PROTOTYPE( int intr_init
, (int, int) );
155 _PROTOTYPE( int intr_disabled
, (void) );
156 _PROTOTYPE( void halt_cpu
, (void) );
157 _PROTOTYPE( void arch_init
, (void) );
158 _PROTOTYPE( void ser_putc
, (char) );
159 _PROTOTYPE( void arch_shutdown
, (int) );
160 _PROTOTYPE( void arch_monitor
, (void) );
161 _PROTOTYPE( void arch_get_aout_headers
, (int i
, struct exec
*h
) );
162 _PROTOTYPE( void restart
, (void) );
163 _PROTOTYPE( void read_tsc
, (unsigned long *high
, unsigned long *low
) );
164 _PROTOTYPE( int arch_init_profile_clock
, (u32_t freq
) );
165 _PROTOTYPE( void arch_stop_profile_clock
, (void) );
166 _PROTOTYPE( void arch_ack_profile_clock
, (void) );
167 _PROTOTYPE( void do_ser_debug
, (void) );
168 _PROTOTYPE( int arch_get_params
, (char *parm
, int max
));
169 _PROTOTYPE( int arch_set_params
, (char *parm
, int max
));
170 _PROTOTYPE( void arch_pre_exec
, (struct proc
*pr
, u32_t
, u32_t
));
171 _PROTOTYPE( int arch_umap
, (struct proc
*pr
, vir_bytes
, vir_bytes
,
173 _PROTOTYPE( int arch_do_vmctl
, (message
*m_ptr
, struct proc
*p
));
174 _PROTOTYPE( int vm_contiguous
, (struct proc
*targetproc
, u32_t vir_buf
, size_t count
));
175 _PROTOTYPE( void proc_stacktrace
, (struct proc
*proc
) );
176 _PROTOTYPE( int vm_lookup
, (struct proc
*proc
, vir_bytes
virtual, vir_bytes
*result
, u32_t
*ptent
));
177 _PROTOTYPE( int delivermsg
, (struct proc
*target
));
178 _PROTOTYPE( void arch_do_syscall
, (struct proc
*proc
) );
179 _PROTOTYPE( int arch_phys_map
, (int index
, phys_bytes
*addr
,
180 phys_bytes
*len
, int *flags
));
181 _PROTOTYPE( int arch_phys_map_reply
, (int index
, vir_bytes addr
));
182 _PROTOTYPE( int arch_enable_paging
, (void));
184 _PROTOTYPE( int copy_msg_from_user
, (struct proc
* p
, message
* user_mbuf
,
186 _PROTOTYPE( int copy_msg_to_user
, (struct proc
* p
, message
* src
,
187 message
* user_mbuf
));
188 _PROTOTYPE(void switch_address_space
, (struct proc
* p
));