X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=fixme;h=3618d544979a8208b4927c9748e0158b83658653;hp=aa80b46ab401e8a3e522a42d2ec05bbb89e21f44;hb=6dde1f33e1249a8a6b354372dd95065f26b8c712;hpb=75787bb7136e064ee623aaee00ec76a7f024c91a diff --git a/fixme b/fixme index aa80b46ab..3618d5449 100644 --- a/fixme +++ b/fixme @@ -1,44 +1,68 @@ -- mounts might take time, need to be executed asynchronously in a forked process? +- trigger mounting; mounts might take time, need to be executed asynchronously in a forked process? - need gc for active jobs that nothing cares for -- need gc for names that are not referenced anymore +- need gc for units that are not referenced anymore -- refreshing of names (i.e. reload config files) +- refreshing of units (i.e. reload config files) -- dbusification +- further dbusification (i.e. export dependency information, per-unit-type data) - cgroupsification -- udev hookup - - snapshot system -- s/milestone/target/ +- add a job mode which shuts everything down but what is requested -- hookup with battery status, suspend/resume +- implement timer -- add a job mode which shuts everything down but what is requested +- implement automount -- write log subsystem/log output logic for daemons +- create session/pgroup for child processes? handle input on console properly? interactive fsck? interactive luks password? -- implement priv dropping +- fs namespaces -- allow to disable priv dropping for hook scripts from fragment +- templating/instances -- implement timer +- verify fragment data after loading: refuse cycles on yourself, service units contradicting, more than one Start executable, ... -- implement mount/automount +- .socket needs to be notified not only by .service state changes, but also unsuccessful start jobs -- more process attributes: chroot, cpu affinity, scheduling +- we probably cannot use glibc's syslog() for logging, since it + presumably uses the logging socket in blocking mode which might + trigger a deadlock if syslog does not process the socket anymore + (maybe because it is restarted) and the socket buffer is full. -- create session/pgroup for child processes +- in udev/mount if properties change we need to delete the old + settings and install the new settings. Deleting the old settings is + currently missing. -- fs namespaces +- ability to kill services? i.e. in contrast to stopping them, go directly + into killing mode? -- templating/instances +- restart-on-success, restart-on-failure, restart-on-abort, restart-on-name-gnone + +- port over to LISTEN_FDS/LISTEN_PID: + + - uuidd DONE + - nscd DONE + - rpcbind (/var/run/rpcbind.sock!) + - dbus + - rsyslog + - cups + - ssh CLASSIC + - postfix, saslauthd + - apache/samba + - libvirtd (/var/run/libvirt/libvirt-sock-ro) + - bluetoothd (/var/run/sdp! @/org/bluez/audio!) + - avahi-daemon (/var/run/avahi-daemon/socket) + - distccd + +- teach dbus to talk to systemd when autospawning services + +- unix sockets chown()/chgrp() -- verify fragment data after loading: refuse cycles on yourself, service names contradicting, more than one Start executable, ... +- watch dbus names for figuring out when a service has finished startup/goes down -- rate limit startups +- initialize console tty on startup