X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=TODO;h=fce3db34ea7cf9699ef720b85eb2392457a86661;hp=4742981c016c4e89ec2c6678e7da1dd5afc5d400;hb=d246fbb054974af4c78e0cf298e031291475cbc1;hpb=9246319f1fd9625a4a43883ae660ecd5ae41423a diff --git a/TODO b/TODO index 4742981c0..fce3db34e 100644 --- a/TODO +++ b/TODO @@ -1,15 +1,4 @@ -Fedora 18: -* important: udev.pc is broken in 183, fixed in master -* fix mimo VID/PID check that claims "innocent" hubs -* storage: rename udev-settle.service to systemd-udev-settle.service -* split-out systemd-libs.rpm to allow parallel install of 32 and 64 bit packages -* chrony/ntp target? - Bugfixes: -* fix building of --disable-logind, hournald and coredunp pull-in parts of sd_login - -* fix emergency mode breakage after the Type=idle change - * remove MS_SHARED from src/core/execute.c and src/test/test-ns.c. They are always combined with MS_REMOUNT, which currently does nothing in the kernel, but might which fail in the future; https://bugzilla.redhat.com/show_bug.cgi?id=813563 @@ -20,8 +9,6 @@ Bugfixes: * make anaconda write timeout=0 for encrypted devices -* make sure timeouts are applied to Type=oneshot services. - * Dangling symlinks of .automount unit files in .wants/ directories, set up automount points even when the original .automount file did not exist anymore. Only the .mount unit was still around. @@ -30,39 +17,95 @@ Bugfixes: * properly handle .mount unit state tracking when two mount points are stacked one on top of another on the exact same mount point. +* we pull src/core/manager.h into src/shared/src/shared/path-lookup.c which is the wrong direction + rename enum "ManagerRunningAs" to "SystemdRunningAs" and move it to shared/ + Features: -* logind: listen to power/suspend/lid-button events - - run poweroff if no session is active - - console session should beep when we refuse to poweroff - - graphical sessions will show a dialog, like they do already today - - use udev to tag input devices we want to subscribe to -* journalctl /dev/sda, journalctl /usr/bin/httpd, journalctl --device=b12:8 (--device=n12, --device=+usb:1-1) +* journalctl should complain if run with uid != 0 and no persistant logs exist -* also reset /proc/sys/kernel/usermodehelper/bset /proc/sys/kernel/usermodehelper/inheritable in system.conf's CapabilityBoundingSet= +* .device aliases need to be implemented with the "following" logic, probably. -* make use of /sys/power/wake_lock in inhibitors +* add sd_journal_wait() to make things easier for sync programs that just want to wait for changes + +* refuse taking lower-case variable names in sd_journal_send() and friends. + +* when running as user instance: implicitly default to WorkingDirectory=$HOME for all services. + +* journalctl highlight reboots + +* Merge KillUnit()'s mode and who params into one + +* load-fragment: when loading a unit file via a chain of symlinks + verify that it isn't masked via any of the names traversed. + +* journald: _BOOT_ID triggers too many collisions. + +* journald: we currently rotate only after MaxUse+MaxFilesize has been reached. + +* reexec journald across initrd transition + +* nspawn: bind mount /var/log/journal from the host + +* The current Storage=auto logic is borked, since people cannot mount + /var/log/journal via NFS since the mount point has to exist and we + already take that as signal to store our stuff there. + +* document that journal data is primarily ASCII, UTF-8 where necessary and binary only where nothing else makes sense. + +* Document: + - PID 1 D-Bus API + - Journal C API manual pages + - scheduled shutdown API + +* wiki: document logind's PreparingForShutdown, PreparingForSleep + +* support debian's console-setup logic + +* introduce Type=pid-file + +* systemctl list-unit-files appears to be broken for symlinked units in /usr/lib + +* maybe allow services with ExecStop= set, but no ExecStart=? + +* efi: implement /forcefsck as uefi variables thus not requiring file system altering to trigger a file system check + +* efi: honour language efi variables for default language selection + +* efi: honour timezone efi variables for default timezone selection -* introduce "systemctl help" which invokes man for the man pages listed in Documentation= +* new dependency type to "group" services in a target + +* change Requires=basic.target to RequisiteOverride=basic.target + +* exclude processes marked with argv[0][0]=@ from the normal service killing too + +* support rd.luks.allow-discards= kernel cmdline params in cryptsetup generator + +* systemctl: when stopping a service which has triggres and warning about it actually check the TriggeredBy= deps fields + +* journal: hook up with EFI firmware log, new kmsg logic + +* handle C-A-Del in logind, like the power/suspend buttons? + +* nspawn: make use of device cgroup contrller by default + +* journalctl /dev/sda, journalctl --device=b12:8 (--device=n12, --device=+usb:1-1) + +* make use of /sys/power/wake_lock in inhibitors * drop accountsservice's StandardOutput=syslog and Type=dbus fields * make sure show-logs checks for utf8 validity, not ascii validity -* add CapbilityBoundingSet to system.conf to set system-wide caps bounds, and same for TimerSlackNS - * when breaking cycles drop sysv services first, then services from /run, then from /etc, then from /usr * readahead: when bumping /sys readahead variable save mtime and compare later to detect changes -* Document boot options such as forcefsck - * (attempt to) make Debianites happy: - implement .d/ auto includes for unit files - add syntax to reset ExecStart= lists (and similar) -* properly detect mimo devices, the current VID/PID check is too broad - * manipulate CPU governor during boot, set it to performance * steal SBF management from the kernel @@ -94,8 +137,6 @@ Features: * don't delete /tmp/systemd-namespace-* before a process is gone down -* don't delete /run/users/lennart if lennart is still logged in even if aging is used - * vconsole: implement setterm -store -foreground xxx --background zzz * ExecOnFailure=/usr/bin/foo @@ -114,8 +155,6 @@ Features: * Auke: merge Auke's bootchart -* journald: allow forwarding of log data to specific TTY instead of console - * udev: move to LGPL * udev systemd unify: @@ -143,8 +182,6 @@ Features: * when a service has the same env var set twice we actually store it twice and return that in systemctl show -p... We should only show the last setting -* add man page documenting all kernel cmdline options, including stuff like fsck.mode= - * support container_ttys= * journald: make configurable "store-on-var", "store-on-run", "dont-store", "auto" @@ -158,10 +195,6 @@ Features: * journal: store euid in journal if it differs from uid -* support chrony in addition to ntpd in timedated - -* document crypttab(5) - * There's currently no way to cancel fsck (used to be possible via C-c or c on the console) * journal: sanely deal with entries which are larger than the individual file size, but where the componets would fit @@ -178,8 +211,6 @@ Features: * figure out whether we should leave dbus around during shutdown -* add interface to allow immediate rotation of the journal, and even flushing. - * dbus: in fedora, make the machine a symlink to /etc/machine-id * journald: reuse XZ context @@ -214,14 +245,10 @@ Features: * systemctl status: show coredumps -* systemctl status: show whether journal was rotated since service started - * save coredump in Windows/Mozilla minidump format * support crash reporting operation modes (https://live.gnome.org/GnomeOS/Design/Whiteboards/ProblemReporting) -* journal: allow per-entry control on /var vs. /run (think incognito browser mode) - * clean up session cgroups that remain after logout (think sshd), but eventually run empty * support "systemctl stop foobar@.service" to stop all units matching a certain template @@ -232,8 +259,6 @@ Features: * when an instanced service exits, remove its parent cgroup too if possible. -* automatically escape unit names passed on the service (i.e. think "systemctl start serial-getty.service@serial/by-path/jshdfjsdfhkjh" being automatically escaped as necessary. - * if we can not get user quota for tmpfs, mount a separate tmpfs instance for every user in /run/user/$USER with a configured maximum size @@ -311,7 +336,6 @@ Features: - resource control in systemd - inhibiting - testing with Harald's awesome test kit - - the Documentation= * allow port=0 in .socket units @@ -410,3 +434,11 @@ Regularly: * pahole * set_put(), hashmap_put() return values check. i.e. == 0 doesn't free()! + +Scheduled for removal (or fixing): + +* xxxOverridable dependencies + +* journald.conf: ImportKernel= + +* prefdm.service