X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=TODO;h=e15d4b92072957520bf06099373a4eb517dad196;hp=f53328623c5b385ff1b02da98b5da0bb3041770a;hb=3a419b98485e347413f723f46ceb38dcf2c94688;hpb=d139b24a808beb0dd39d1a80023c111241c0a009 diff --git a/TODO b/TODO index f53328623..e15d4b920 100644 --- a/TODO +++ b/TODO @@ -1,6 +1,3 @@ -Fedora 18: -* chrony/ntp target? - Bugfixes: * 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 @@ -12,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. @@ -25,22 +20,96 @@ Bugfixes: * 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/ +* crash happens when running a service as forking and then changing it to simple and reloading. + + Jul 09 18:20:57 mop systemd[1]: usbmuxd.service operation timed out. Terminating. + Jul 09 18:20:57 mop systemd[1]: Unit usbmuxd.service entered failed state. + Jul 09 18:22:24 mop systemd[1]: PID 21814 read from file /var/run/usbmuxd.pid does not exist. + Jul 09 18:22:24 mop systemd[1]: Unit usbmuxd.service entered failed state. + Jul 09 18:22:33 mop systemd[1]: Reloading. + Jul 09 18:22:37 mop systemd[1]: Assertion 's->type == SERVICE_FORKING' failed at src/core/service.c:3007, function service_sigchld_eve...Aborting. + Jul 09 18:22:37 mop systemd[1]: Caught , dumped core as pid 21865. + Jul 09 18:22:37 mop systemd[1]: Freezing execution. + Jul 09 18:22:37 mop [21866]: Process 21865 (systemd) dumped core. + Features: -* change $NOTIFY_SOCKET to use an abstract namespace socket, so that chroot() is compatible with this - https://bugzilla.redhat.com/show_bug.cgi?id=833105 +* replace BindTo= by BindsTo=, but keep old name for compat -* readahead: merge the three tools into one binary +* switch-root: sockets need relabelling -* systemctl: when stopping a service which has triggres and warning about it actually check the TriggeredBy= deps fields +* switch-root: handle journald restart -* send SIGPWR to upower on resume so that it can send out its dbus signal for compat +* segfault in journalctl during /var migration -* vtconsole: don't override kernel cmdline utf8 override setting +* systemd-analyze post-boot is broken for initrd -* journal: hook up with EFI firmware log, new kmsg logic +* man: clarify that time-sync.target is not only sysv compat but also useful otherwise. Same for similar targets + +* journalctl should complain if run with uid != 0 and no persistant logs exist + +* .device aliases need to be implemented with the "following" logic, probably. + +* 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. + +* 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 + +* Document: + - PID 1 D-Bus API + - Journal C API manual pages + - scheduled shutdown API + +* 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 -* falconindy: allow unescaped pathes for mount units, like "systmectl status /.mount"? +* efi: honour timezone efi variables for default timezone selection + +* efi: automatically mount EFI partition to /boot if no such entry exists in /etc/fstab and /boot is empty + gummiboot exports the EFI system partion (ESP) device: + /sys/firmware/efi/vars/LoaderDeviceIdentifier-4a67b082-0a4c-41cf-b6c7-440b29bb8c4f/data + Acpi(PNP0A03,0)/Pci(1F|2)/?/HD(Part1,Sig1FCBC57F-4BFC-4C2B-91A3-9C84FBCD9AF1) + '/' is the separator for the device path list + HD(Part1,Sig1FCBC57F-4BFC-4C2B-91A3-9C84FBCD9AF1) contains the GPT UUID of the ESP + +* read the bootloader performance data (raw TSC) in systemd-analyze + /sys/firmware/efi/vars/LoaderTicksExec-4a67b082-0a4c-41cf-b6c7-440b29bb8c4f/data + 19066159288 + /sys/firmware/efi/vars/LoaderTicksInit-4a67b082-0a4c-41cf-b6c7-440b29bb8c4f/data + 17442940316 + /sys/firmware/efi/vars/LoaderTicksStartMenu-4a67b082-0a4c-41cf-b6c7-440b29bb8c4f/data + (only set if the menu was active) + +* 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? @@ -58,8 +127,6 @@ Features: * 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) @@ -95,8 +162,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 @@ -142,13 +207,8 @@ 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" - (store-persistent, store-volatile?) - * introduce mix of BindTo and Requisite * journalctl: show multiline log messages sanely, expand tabs, and show all valid utf8 messages @@ -157,10 +217,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 @@ -187,8 +243,6 @@ Features: * journal: write man pages for API -* journal: OR matches are borked - * journal: extend hash tables as we go * journal: API for looking for retrieving "all values of this field" @@ -225,8 +279,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 @@ -304,7 +356,6 @@ Features: - resource control in systemd - inhibiting - testing with Harald's awesome test kit - - the Documentation= * allow port=0 in .socket units @@ -403,3 +454,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