X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=TODO;h=16c429fb751a327892067b02528c8baf7e5cef43;hp=ecdde830af24d794de208c6abf613934a9730047;hb=7212a8a99ee863698f5feaa00abb4b99f3996a1a;hpb=0bf07cb5e4db097fcc25784b491fc4311d20fff2 diff --git a/TODO b/TODO index ecdde830a..16c429fb7 100644 --- a/TODO +++ b/TODO @@ -20,63 +20,68 @@ 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/ -Features: +* 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. + +* support *static* (/run) hibernate inhibitors. All rpm -i actions should completely prevent any + sort of hibernate action until the next reboot. If the kernel or any other base tool is replaced + by rpm, the resume path might fail, the for resume needed kernel might even be uninstalled, and + the whole situation leads directly to data loss. -* switch-root: reopen /dev/console before switching root +Features: -* switch-root: sockets need relabelling +* wiki: document new logind LockSessions() call -* switch-root: handle journald restart +* initialize the hostname from the fs label of /, if /etc/hostname does not exist? -* policy loading in initrd generates warning +* logind: different policy actions for idle, suspend, shutdown blockers: allow idle blockers by default, don't allow suspend blockers by default -* segfault in journalctl during /var migration +* install README to /etc/rc.d/init.d (if support for that is enabled) helping people who use "ls" there to figure out which services exist. -* systemd-analyze post-boot is broken for initrd +* logind: ignore inactive login screens when checking whether power key should be handled -* journal: s/permanent/persistant +* rename "userspace" to "core-os" -* man: clarify that time-sync.target is not only sysv compat but also useful otherwise. Same for similar targets +* systemctl: "Journal has been rotated since unit was started." message is misleading -* journalctl should complain if run with uid != 0 and no persistant logs exist +* syscall filter: add knowledge about compat syscalls -* .device aliases need to be implemented with the "following" logic, probably. +* syscall filter: don't enforce no new privs? -* add sd_journal_wait() to make things easier for sync programs that just want to wait for changes +* syscall filter: option to return EPERM rather than SIGSYS? -* refuse taking lower-case variable names in sd_journal_send() and friends. +* logind: wakelock/opportunistic suspend support -* when running as user instance: implicitly default to WorkingDirectory=$HOME for all services. - -* journalctl highlight reboots +* switch-root: sockets need relabelling -* Merge KillUnit()'s mode and who params into one +* segfault in journalctl during /var migration -* load-fragment: when loading a unit file via a chain of symlinks - verify that it isn't masked via any of the names traversed. +* systemd-analyze post-boot is broken for initrd -* journald: _BOOT_ID triggers too many collisions. +* man: clarify that time-sync.target is not only sysv compat but also useful otherwise. Same for similar targets -* journald: we currently rotate only after MaxUse+MaxFilesize has been reached. +* journalctl should complain if run with uid != 0 and no persistent logs exist -* reexec journald across initrd transition +* .device aliases need to be implemented with the "following" logic, probably. -* nspawn: bind mount /var/log/journal from the host +* refuse taking lower-case variable names in sd_journal_send() and friends. -* 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. +* load-fragment: when loading a unit file via a chain of symlinks + verify that it isn't masked via any of the names traversed. -* document that journal data is primarily ASCII, UTF-8 where necessary and binary only where nothing else makes sense. +* journald: we currently rotate only after MaxUse+MaxFilesize has been reached. * 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 @@ -90,12 +95,25 @@ Features: * 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 @@ -112,8 +130,6 @@ Features: * drop accountsservice's StandardOutput=syslog and Type=dbus fields -* make sure show-logs checks for utf8 validity, not ascii validity - * 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 @@ -200,9 +216,6 @@ Features: * 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 @@ -235,12 +248,6 @@ Features: * write RPM spec macros for presets -* 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" * journal: deal nicely with byte-by-byte copied files, especially regards header