minix/servers/is
David van Moolenbroek b8b8f537bd IPC privileges fixes
Kernel:
o Remove s_ipc_sendrec, instead using s_ipc_to for all send primitives
o Centralize s_ipc_to bit manipulation,
  - disallowing assignment of bits pointing to unused priv structs;
  - preventing send-to-self by not setting bit for own priv struct;
  - preserving send mask matrix symmetry in all cases
o Add IPC send mask checks to SENDA, which were missing entirely somehow
o Slightly improve IPC stats accounting for SENDA
o Remove SYSTEM from user processes' send mask
o Half-fix the dependency between boot image order and process numbers,
  - correcting the table order of the boot processes;
  - documenting the order requirement needed for proper send masks;
  - warning at boot time if the order is violated

RS:
o Add support in /etc/drivers.conf for servers that talk to user processes,
  - disallowing IPC to user processes if no "ipc" field is present
  - adding a special "USER" label to explicitly allow IPC to user processes
o Always apply IPC masks when specified; remove -i flag from service(8)
o Use kernel send mask symmetry to delay adding IPC permissions for labels
  that do not exist yet, adding them to that label's process upon creation
o Add VM to ipc permissions list for rtl8139 and fxp in drivers.conf

Left to future fixes:
o Removal of the table order vs process numbers dependency altogether,
  possibly using per-process send list structures as used for SYSTEM calls
o Proper assignment of send masks to boot processes;
  some of the assigned (~0) masks are much wider than necessary
o Proper assignment of IPC send masks for many more servers in drivers.conf
o Removal of the debugging warning about the now legitimate case where RS's
  add_forward_ipc cannot find the IPC destination's label yet
2009-07-02 16:25:31 +00:00
..
dmp.c moved stacktrace to sysctl, as vmctl is very privileged so can't 2009-01-27 12:54:33 +00:00
dmp_ds.c . DS understands publishing and subscribing where keys are in string 2006-07-13 14:50:23 +00:00
dmp_fs.c include "../vfs/dmap.h". 2007-08-07 13:26:25 +00:00
dmp_kernel.c IPC privileges fixes 2009-07-02 16:25:31 +00:00
dmp_pm.c Basic VM and other minor improvements. 2008-11-19 12:26:10 +00:00
dmp_rs.c vfs/mount/rs/service changes: 2007-01-22 15:25:41 +00:00
glo.h endpoint-aware conversion of servers. 2006-03-03 10:20:58 +00:00
inc.h Split of architecture-dependent and -independent functions for i386, 2006-12-22 15:22:27 +00:00
is.h Renamed src/lib/utils to src/lib/sysutil --- because of new src/lib/util 2005-07-19 13:21:51 +00:00
main.c moved stacktrace to sysctl, as vmctl is very privileged so can't 2009-01-27 12:54:33 +00:00
Makefile Basic VM and other minor improvements. 2008-11-19 12:26:10 +00:00
proto.h moved stacktrace to sysctl, as vmctl is very privileged so can't 2009-01-27 12:54:33 +00:00