X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=fixme;h=ff00436e4a2bf0a357b44bc808c1cfcddc023581;hp=2668bbbc2fe502a11e9c0435cda2d0fe2b0f8931;hb=36adffeab07c74470bc96417b17a72b53055ee42;hpb=9eba9da4bce4778b4d5dd43e2c41756976a1582b diff --git a/fixme b/fixme index 2668bbbc2..ff00436e4 100644 --- a/fixme +++ b/fixme @@ -1,54 +1,92 @@ +* calendar time support in timer, iCalendar semantics for the timer stuff (RFC2445) -- mounts might take time, need to be executed asynchronously in a forked process? +* implicitly import "defaults" settings file into all types -- need gc for active jobs that nothing cares for +* add #ifdefs for non-sysv builds -- need gc for units that are not referenced anymore +* reinvestigate random seed, hwclock -- refreshing of units (i.e. reload config files) +* "disabled" load state? -- dbusification +* ability to kill services? i.e. in contrast to stopping them, go directly + into killing mode? -- cgroupsification +* port over to LISTEN_FDS/LISTEN_PID: -- udev hookup + - uuidd DONE + - nscd DONE + - dbus DONE + - rsyslog DONE + - rpcbind (/var/run/rpcbind.sock!) DONE + - cups DONE + - avahi-daemon (/var/run/avahi-daemon/socket) DONE + - ssh CLASSIC + - postfix, saslauthd + - apache/samba + - libvirtd (/var/run/libvirt/libvirt-sock-ro) + - bluetoothd (/var/run/sdp! @/org/bluez/audio!) + - distccd -- snapshot system +* write utmp record a la upstart for processes -- hookup with battery status, suspend/resume +* follow property change dbus spec -- add a job mode which shuts everything down but what is requested +* selinux -- implement priv dropping +* systemctl status $PID, systemctl stop $PID! -- allow to disable priv dropping for hook scripts from fragment +* place /etc/inittab with explaining blurb. -- implement timer +* In command lines, support both "$FOO" and $FOO +* /etc must always take precedence even if we follow symlinks! +* fix merging of device units +* color aus bei stdout auf !tty -- implement mount/automount +getty before prefdm -- more process attributes: cpu affinity, cpu scheduling +* /lib/init/rw -- create session/pgroup for child processes? handle input on console properly? interactive fsck? interactive luks password? +* vielleicht implizit immer auf syslog dependen? -- fs namespaces +* debian deadlock when partition auf noauto is. -- templating/instances +* fingerprint.target, wireless.target, gps.target -- verify fragment data after loading: refuse cycles on yourself, service units contradicting, more than one Start executable, ... +* set_put(), hashmap_put() return values checken. i.e. == 0 macht kein free()! -- automatically delete stale unix sockets +* crash on missing hostname -- .socket needs to be notified not only by .service state changes, but also unsuccessful start jobs +* fix merging in .swap units -- 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. +* pahole -- 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. +* io priority -- ability to kill services? i.e. in contrast to stopping them, go directly - into killing mode? +* network.target darf nm nicht unbedingt starten + +External: + +* default.target must be %ghosted... + +* in %post create all symlinks manually and use inittab data + +* default logic for serial getty, ck logging, ssh readahead + +* patch /etc/init.d/functions with: + + if [ $PPID -ne 1 && mountpoint /cgroup/systemd ] ; then echo "You suck!" ; fi + +https://bugzilla.redhat.com/show_bug.cgi?id=614245 +https://bugzilla.redhat.com/show_bug.cgi?id=612789 +https://bugzilla.redhat.com/show_bug.cgi?id=612728 +https://bugzilla.redhat.com/show_bug.cgi?id=612712 + +Regularly: + +* look for close() vs. close_nointr() vs. close_nointr_nofail() + +* check for strerror(r) instead of strerror(-r) + +* Use PR_SET_PROCTITLE_AREA if it becomes available in the kernel + +* %m in printf() instead of strerror();