root / lab4 / .minix-src / include / minix / syslib.h @ 14
History | View | Annotate | Download (12.3 KB)
1 | 13 | up20180614 | /* Prototypes for system library functions. */
|
---|---|---|---|
2 | |||
3 | #ifndef _SYSLIB_H
|
||
4 | #define _SYSLIB_H
|
||
5 | |||
6 | #include <sys/types.h> |
||
7 | #include <sys/sigtypes.h> |
||
8 | |||
9 | #include <minix/ipc.h> |
||
10 | #include <minix/u64.h> |
||
11 | #include <minix/devio.h> |
||
12 | |||
13 | #include <minix/safecopies.h> |
||
14 | #include <minix/sef.h> |
||
15 | #include <machine/mcontext.h> |
||
16 | |||
17 | /* Forward declaration */
|
||
18 | struct rs_pci;
|
||
19 | struct rusage;
|
||
20 | struct sockcred;
|
||
21 | struct reg86;
|
||
22 | |||
23 | #define SYSTASK SYSTEM
|
||
24 | |||
25 | /*==========================================================================*
|
||
26 | * Minix system library. *
|
||
27 | *==========================================================================*/
|
||
28 | int _taskcall(endpoint_t who, int syscallnr, message *msgptr); |
||
29 | int _kernel_call(int syscallnr, message *msgptr); |
||
30 | |||
31 | int sys_abort(int how); |
||
32 | int sys_enable_iop(endpoint_t proc_ep);
|
||
33 | int sys_int86(struct reg86 *reg86p); |
||
34 | int sys_exec(endpoint_t proc_ep, vir_bytes stack_ptr, vir_bytes progname,
|
||
35 | vir_bytes pc, vir_bytes ps_str); |
||
36 | int sys_fork(endpoint_t parent, endpoint_t child, endpoint_t *,
|
||
37 | u32_t vm, vir_bytes *); |
||
38 | int sys_clear(endpoint_t proc_ep);
|
||
39 | int sys_exit(void); |
||
40 | int sys_trace(int req, endpoint_t proc_ep, long addr, long *data_p); |
||
41 | |||
42 | int sys_schedule(endpoint_t proc_ep, int priority, int quantum, int cpu, |
||
43 | int niced);
|
||
44 | int sys_schedctl(unsigned flags, endpoint_t proc_ep, int priority, int |
||
45 | quantum, int cpu);
|
||
46 | |||
47 | /* Shorthands for sys_runctl() system call. */
|
||
48 | #define sys_stop(proc_ep) sys_runctl(proc_ep, RC_STOP, 0) |
||
49 | #define sys_delay_stop(proc_ep) sys_runctl(proc_ep, RC_STOP, RC_DELAY)
|
||
50 | #define sys_resume(proc_ep) sys_runctl(proc_ep, RC_RESUME, 0) |
||
51 | int sys_runctl(endpoint_t proc_ep, int action, int flags); |
||
52 | |||
53 | int sys_update(endpoint_t src_ep, endpoint_t dst_ep, int flags); |
||
54 | int sys_statectl(int request, void* address, int length); |
||
55 | int sys_privctl(endpoint_t proc_ep, int req, void *p); |
||
56 | int sys_privquery_mem(endpoint_t proc_ep, phys_bytes physstart,
|
||
57 | phys_bytes physlen); |
||
58 | int sys_setgrant(cp_grant_t *grants, int ngrants); |
||
59 | |||
60 | int sys_vm_setbuf(phys_bytes base, phys_bytes size, phys_bytes high);
|
||
61 | int sys_vm_map(endpoint_t proc_ep, int do_map, phys_bytes base, |
||
62 | phys_bytes size, phys_bytes offset); |
||
63 | int sys_vmctl(endpoint_t who, int param, u32_t value); |
||
64 | int sys_vmctl_get_pdbr(endpoint_t who, u32_t *pdbr);
|
||
65 | int sys_vmctl_get_memreq(endpoint_t *who, vir_bytes *mem, vir_bytes
|
||
66 | *len, int *wrflag, endpoint_t *who_s, vir_bytes *mem_s, endpoint_t *);
|
||
67 | int sys_vmctl_enable_paging(void * data); |
||
68 | |||
69 | int sys_readbios(phys_bytes address, void *buf, size_t size); |
||
70 | int sys_settime(int now, clockid_t clk_id, time_t sec, long nsec); |
||
71 | int sys_stime(time_t boottime);
|
||
72 | int sys_vmctl_get_mapping(int index, phys_bytes *addr, phys_bytes *len, |
||
73 | int *flags);
|
||
74 | int sys_vmctl_reply_mapping(int index, vir_bytes addr); |
||
75 | int sys_vmctl_set_addrspace(endpoint_t who, phys_bytes ptroot, void |
||
76 | *ptroot_v); |
||
77 | |||
78 | |||
79 | /* Shorthands for sys_sdevio() system call. */
|
||
80 | #define sys_insb(port, proc_ep, buffer, count) \
|
||
81 | sys_sdevio(DIO_INPUT_BYTE, port, proc_ep, buffer, count, 0)
|
||
82 | #define sys_insw(port, proc_ep, buffer, count) \
|
||
83 | sys_sdevio(DIO_INPUT_WORD, port, proc_ep, buffer, count, 0)
|
||
84 | #define sys_outsb(port, proc_ep, buffer, count) \
|
||
85 | sys_sdevio(DIO_OUTPUT_BYTE, port, proc_ep, buffer, count, 0)
|
||
86 | #define sys_outsw(port, proc_ep, buffer, count) \
|
||
87 | sys_sdevio(DIO_OUTPUT_WORD, port, proc_ep, buffer, count, 0)
|
||
88 | #define sys_safe_insb(port, ept, grant, offset, count) \
|
||
89 | sys_sdevio(DIO_SAFE_INPUT_BYTE, port, ept, (void*)grant, count, offset)
|
||
90 | #define sys_safe_outsb(port, ept, grant, offset, count) \
|
||
91 | sys_sdevio(DIO_SAFE_OUTPUT_BYTE, port, ept, (void*)grant, count, offset)
|
||
92 | #define sys_safe_insw(port, ept, grant, offset, count) \
|
||
93 | sys_sdevio(DIO_SAFE_INPUT_WORD, port, ept, (void*)grant, count, offset)
|
||
94 | #define sys_safe_outsw(port, ept, grant, offset, count) \
|
||
95 | sys_sdevio(DIO_SAFE_OUTPUT_WORD, port, ept, (void*)grant, count, offset)
|
||
96 | int sys_sdevio(int req, long port, endpoint_t proc_ep, void *buffer, int |
||
97 | count, vir_bytes offset); |
||
98 | void *alloc_contig(size_t len, int flags, phys_bytes *phys); |
||
99 | int free_contig(void *addr, size_t len); |
||
100 | |||
101 | #define AC_ALIGN4K 0x01 |
||
102 | #define AC_LOWER16M 0x02 |
||
103 | #define AC_ALIGN64K 0x04 |
||
104 | #define AC_LOWER1M 0x08 |
||
105 | |||
106 | /* Clock functionality: get system times, (un)schedule an alarm call, or
|
||
107 | * retrieve/set a process-virtual timer.
|
||
108 | */
|
||
109 | int sys_times(endpoint_t proc_ep, clock_t *user_time, clock_t *sys_time,
|
||
110 | clock_t *uptime, time_t *boottime); |
||
111 | |||
112 | #define sys_setalarm(exp, abs) sys_setalarm2(exp, abs, NULL, NULL) |
||
113 | int sys_setalarm2(clock_t exp_time, int abs_time, clock_t *time_left, |
||
114 | clock_t *uptime); |
||
115 | |||
116 | int sys_vtimer(endpoint_t proc_nr, int which, clock_t *newval, clock_t |
||
117 | *oldval); |
||
118 | |||
119 | /* Shorthands for sys_irqctl() system call. */
|
||
120 | #define sys_irqdisable(hook_id) \
|
||
121 | sys_irqctl(IRQ_DISABLE, 0, 0, hook_id) |
||
122 | #define sys_irqenable(hook_id) \
|
||
123 | sys_irqctl(IRQ_ENABLE, 0, 0, hook_id) |
||
124 | #define sys_irqsetpolicy(irq_vec, policy, hook_id) \
|
||
125 | sys_irqctl(IRQ_SETPOLICY, irq_vec, policy, hook_id) |
||
126 | #define sys_irqrmpolicy(hook_id) \
|
||
127 | sys_irqctl(IRQ_RMPOLICY, 0, 0, hook_id) |
||
128 | int sys_irqctl(int request, int irq_vec, int policy, int *irq_hook_id); |
||
129 | |||
130 | /* Shorthands for sys_vircopy() and sys_physcopy() system calls. */
|
||
131 | #define sys_datacopy(p1, v1, p2, v2, len) sys_vircopy(p1, v1, p2, v2, len, 0) |
||
132 | #define sys_datacopy_try(p1, v1, p2, v2, len) sys_vircopy(p1, v1, p2, v2, len, CP_FLAG_TRY)
|
||
133 | int sys_vircopy(endpoint_t src_proc, vir_bytes src_v,
|
||
134 | endpoint_t dst_proc, vir_bytes dst_vir, phys_bytes bytes, int flags);
|
||
135 | |||
136 | #define sys_abscopy(src_phys, dst_phys, bytes) \
|
||
137 | sys_physcopy(NONE, src_phys, NONE, dst_phys, bytes, 0)
|
||
138 | int sys_physcopy(endpoint_t src_proc, vir_bytes src_vir,
|
||
139 | endpoint_t dst_proc, vir_bytes dst_vir, phys_bytes bytes, int flags);
|
||
140 | |||
141 | |||
142 | /* Grant-based copy functions. */
|
||
143 | int sys_safecopyfrom(endpoint_t source, cp_grant_id_t grant, vir_bytes
|
||
144 | grant_offset, vir_bytes my_address, size_t bytes); |
||
145 | int sys_safecopyto(endpoint_t dest, cp_grant_id_t grant, vir_bytes
|
||
146 | grant_offset, vir_bytes my_address, size_t bytes); |
||
147 | int sys_vsafecopy(struct vscp_vec *copyvec, int elements); |
||
148 | |||
149 | int sys_safememset(endpoint_t source, cp_grant_id_t grant, vir_bytes
|
||
150 | grant_offset, int pattern, size_t bytes);
|
||
151 | |||
152 | int sys_memset(endpoint_t who, unsigned long pattern, |
||
153 | phys_bytes base, phys_bytes bytes); |
||
154 | |||
155 | int sys_vumap(endpoint_t endpt, struct vumap_vir *vvec, |
||
156 | int vcount, size_t offset, int access, struct vumap_phys *pvec, |
||
157 | int *pcount);
|
||
158 | int sys_umap(endpoint_t proc_ep, int seg, vir_bytes vir_addr, vir_bytes |
||
159 | bytes, phys_bytes *phys_addr); |
||
160 | int sys_umap_data_fb(endpoint_t proc_ep, vir_bytes vir_addr, vir_bytes
|
||
161 | bytes, phys_bytes *phys_addr); |
||
162 | int sys_umap_remote(endpoint_t proc_ep, endpoint_t grantee, int seg, |
||
163 | vir_bytes vir_addr, vir_bytes bytes, phys_bytes *phys_addr); |
||
164 | |||
165 | /* Shorthands for sys_diagctl() system call. */
|
||
166 | #define sys_diagctl_diag(buf,len) \
|
||
167 | sys_diagctl(DIAGCTL_CODE_DIAG, buf, len) |
||
168 | #define sys_diagctl_stacktrace(ep) \
|
||
169 | sys_diagctl(DIAGCTL_CODE_STACKTRACE, NULL, ep)
|
||
170 | #define sys_diagctl_register() \
|
||
171 | sys_diagctl(DIAGCTL_CODE_REGISTER, NULL, 0) |
||
172 | #define sys_diagctl_unregister() \
|
||
173 | sys_diagctl(DIAGCTL_CODE_UNREGISTER, NULL, 0) |
||
174 | int sys_diagctl(int ctl, char *arg1, int arg2); |
||
175 | |||
176 | /* Shorthands for sys_getinfo() system call. */
|
||
177 | #define sys_getkinfo(dst) sys_getinfo(GET_KINFO, dst, 0,0,0) |
||
178 | #define sys_getloadinfo(dst) sys_getinfo(GET_LOADINFO, dst, 0,0,0) |
||
179 | #define sys_getmachine(dst) sys_getinfo(GET_MACHINE, dst, 0,0,0) |
||
180 | #define sys_getcpuinfo(dst) sys_getinfo(GET_CPUINFO, dst, 0,0,0) |
||
181 | #define sys_getproctab(dst) sys_getinfo(GET_PROCTAB, dst, 0,0,0) |
||
182 | #define sys_getprivtab(dst) sys_getinfo(GET_PRIVTAB, dst, 0,0,0) |
||
183 | #define sys_getproc(dst,nr) sys_getinfo(GET_PROC, dst, 0,0, nr) |
||
184 | #define sys_getrandomness(dst) sys_getinfo(GET_RANDOMNESS, dst, 0,0,0) |
||
185 | #define sys_getrandom_bin(d,b) sys_getinfo(GET_RANDOMNESS_BIN, d, 0,0,b) |
||
186 | #define sys_getimage(dst) sys_getinfo(GET_IMAGE, dst, 0,0,0) |
||
187 | #define sys_getirqhooks(dst) sys_getinfo(GET_IRQHOOKS, dst, 0,0,0) |
||
188 | #define sys_getirqactids(dst) sys_getinfo(GET_IRQACTIDS, dst, 0,0,0) |
||
189 | #define sys_getmonparams(v,vl) sys_getinfo(GET_MONPARAMS, v,vl, 0,0) |
||
190 | #define sys_getschedinfo(v1,v2) sys_getinfo(GET_SCHEDINFO, v1,0, v2,0) |
||
191 | #define sys_getpriv(dst, nr) sys_getinfo(GET_PRIV, dst, 0,0, nr) |
||
192 | #define sys_getidletsc(dst) sys_getinfo(GET_IDLETSC, dst, 0,0,0) |
||
193 | #define sys_getregs(dst,nr) sys_getinfo(GET_REGS, dst, 0,0, nr) |
||
194 | #define sys_getcputicks(dst,nr) sys_getinfo(GET_CPUTICKS, dst, 0,0, nr) |
||
195 | int sys_getinfo(int request, void *val_ptr, int val_len, void *val_ptr2, |
||
196 | int val_len2);
|
||
197 | int sys_whoami(endpoint_t *ep, char *name, int namelen, int |
||
198 | *priv_flags, int* init_flags);
|
||
199 | |||
200 | /* Signal control. */
|
||
201 | int sys_kill(endpoint_t proc_ep, int sig); |
||
202 | int sys_sigsend(endpoint_t proc_ep, struct sigmsg *sig_ctxt); |
||
203 | int sys_sigreturn(endpoint_t proc_ep, struct sigmsg *sig_ctxt); |
||
204 | int sys_getksig(endpoint_t *proc_ep, sigset_t *k_sig_map);
|
||
205 | int sys_endksig(endpoint_t proc_ep);
|
||
206 | |||
207 | /* NOTE: two different approaches were used to distinguish the device I/O
|
||
208 | * types 'byte', 'word', 'long': the latter uses #define and results in a
|
||
209 | * smaller implementation, but looses the static type checking.
|
||
210 | */
|
||
211 | int sys_voutb(pvb_pair_t *pvb_pairs, int nr_ports); |
||
212 | int sys_voutw(pvw_pair_t *pvw_pairs, int nr_ports); |
||
213 | int sys_voutl(pvl_pair_t *pvl_pairs, int nr_ports); |
||
214 | int sys_vinb(pvb_pair_t *pvb_pairs, int nr_ports); |
||
215 | int sys_vinw(pvw_pair_t *pvw_pairs, int nr_ports); |
||
216 | int sys_vinl(pvl_pair_t *pvl_pairs, int nr_ports); |
||
217 | |||
218 | /* Shorthands for sys_out() system call. */
|
||
219 | #define sys_outb(p,v) sys_out((p), (u32_t) (v), _DIO_BYTE)
|
||
220 | #define sys_outw(p,v) sys_out((p), (u32_t) (v), _DIO_WORD)
|
||
221 | #define sys_outl(p,v) sys_out((p), (u32_t) (v), _DIO_LONG)
|
||
222 | int sys_out(int port, u32_t value, int type); |
||
223 | |||
224 | /* Shorthands for sys_in() system call. */
|
||
225 | #define sys_inb(p,v) sys_in((p), (v), _DIO_BYTE)
|
||
226 | #define sys_inw(p,v) sys_in((p), (v), _DIO_WORD)
|
||
227 | #define sys_inl(p,v) sys_in((p), (v), _DIO_LONG)
|
||
228 | int sys_in(int port, u32_t *value, int type); |
||
229 | |||
230 | /* arm pinmux */
|
||
231 | int sys_padconf(u32_t padconf, u32_t mask, u32_t value);
|
||
232 | |||
233 | /* pci.c */
|
||
234 | void pci_init(void); |
||
235 | int pci_first_dev(int *devindp, u16_t *vidp, u16_t *didp); |
||
236 | int pci_next_dev(int *devindp, u16_t *vidp, u16_t *didp); |
||
237 | int pci_find_dev(u8_t bus, u8_t dev, u8_t func, int *devindp); |
||
238 | void pci_reserve(int devind); |
||
239 | int pci_reserve_ok(int devind); |
||
240 | void pci_ids(int devind, u16_t *vidp, u16_t *didp); |
||
241 | void pci_rescan_bus(u8_t busnr);
|
||
242 | u8_t pci_attr_r8(int devind, int port); |
||
243 | u16_t pci_attr_r16(int devind, int port); |
||
244 | u32_t pci_attr_r32(int devind, int port); |
||
245 | void pci_attr_w8(int devind, int port, u8_t value); |
||
246 | void pci_attr_w16(int devind, int port, u16_t value); |
||
247 | void pci_attr_w32(int devind, int port, u32_t value); |
||
248 | char *pci_dev_name(u16_t vid, u16_t did);
|
||
249 | char *pci_slot_name(int devind); |
||
250 | int pci_set_acl(struct rs_pci *rs_pci); |
||
251 | int pci_del_acl(endpoint_t proc_ep);
|
||
252 | int pci_get_bar(int devind, int port, u32_t *base, u32_t *size, int |
||
253 | *ioflag); |
||
254 | |||
255 | /* Profiling. */
|
||
256 | int sys_sprof(int action, int size, int freq, int type, endpoint_t |
||
257 | endpt, vir_bytes ctl_ptr, vir_bytes mem_ptr); |
||
258 | |||
259 | /* machine context */
|
||
260 | int sys_getmcontext(endpoint_t proc, vir_bytes mcp);
|
||
261 | int sys_setmcontext(endpoint_t proc, vir_bytes mcp);
|
||
262 | |||
263 | /* input */
|
||
264 | int tty_input_inject(int type, int code, int val); |
||
265 | |||
266 | /* Miscellaneous calls from servers and drivers. */
|
||
267 | pid_t srv_fork(uid_t reuid, gid_t regid); |
||
268 | int srv_kill(pid_t pid, int sig); |
||
269 | int getprocnr(pid_t pid, endpoint_t *proc_ep);
|
||
270 | int mapdriver(const char *label, devmajor_t major, const int *domains, |
||
271 | int nr_domains);
|
||
272 | pid_t getepinfo(endpoint_t proc_ep, uid_t *uidp, gid_t *gidp); |
||
273 | pid_t getnpid(endpoint_t proc_ep); |
||
274 | uid_t getnuid(endpoint_t proc_ep); |
||
275 | gid_t getngid(endpoint_t proc_ep); |
||
276 | int getsockcred(endpoint_t proc_ep, struct sockcred * sockcred, gid_t * groups, |
||
277 | int ngroups);
|
||
278 | int socketpath(endpoint_t endpt, const char *path, size_t size, int what, |
||
279 | dev_t *dev, ino_t *ino); |
||
280 | #define SPATH_CHECK 0 /* check user permissions on socket path */ |
||
281 | #define SPATH_CREATE 1 /* create socket file at given path */ |
||
282 | int copyfd(endpoint_t endpt, int fd, int what); |
||
283 | #define COPYFD_FROM 0 /* copy file descriptor from remote process */ |
||
284 | #define COPYFD_TO 1 /* copy file descriptor to remote process */ |
||
285 | #define COPYFD_CLOSE 2 /* close file descriptor in remote process */ |
||
286 | #define COPYFD_CLOEXEC 0x8000 /* with COPYFD_TO: set close-on-exec flag */ |
||
287 | #define COPYFD_FLAGS 0xF000 /* flags mask */ |
||
288 | int closenb(int fd); |
||
289 | |||
290 | /*
|
||
291 | * These are also the event numbers used in PROC_EVENT messages, but in order
|
||
292 | * to allow for subscriptions to multiple events, they form a bit mask.
|
||
293 | */
|
||
294 | #define PROC_EVENT_EXIT 0x01 /* process has exited */ |
||
295 | #define PROC_EVENT_SIGNAL 0x02 /* process has caught signal */ |
||
296 | int proceventmask(unsigned int mask); |
||
297 | |||
298 | #endif /* _SYSLIB_H */ |