chiark / gitweb /
journald: don't choke on journal files with no cutoff date
[elogind.git] / TODO
diff --git a/TODO b/TODO
index b8369c364cb4ee7d3b592bbde0f0e55c776012f2..9d09916b28752d7a396c6a9d993c0107de9235fe 100644 (file)
--- a/TODO
+++ b/TODO
@@ -20,30 +20,57 @@ 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 <ABRT>, 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:
 
-* journald: _BOOT_ID triggers too many collisions.
+* nspawn: if /var/log/journal/<container machine id> exists in both
+  the container and the host mount one to the other so that the
+  containers logs are stored and visible on the host.
 
-* journald: we currently rotate only after MaxUse+MaxFilesize has been reached.
+* syscall filter: add knowledge about compat syscalls
 
-* reexec journald across initrd transition
+* syscall filter: don't enforce no new privs?
 
-* nspawn: bind mount /var/log/journal from the host
+* syscall filter: option to return EPERM rather than SIGSYS?
 
-* 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.
+* logind: wakelock/opportunistic suspend support
 
-* document that journal data is primarily ASCII, UTF-8 where necessary and binary only where nothing else makes sense.
+* switch-root: sockets need relabelling
 
-* Document:
-        - PID 1 D-Bus API
-        - Update Syslog Interface docs
-        - Journal C API manual pages
+* segfault in journalctl during /var migration
+
+* systemd-analyze post-boot is broken for initrd
+
+* 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 persistent 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.
+
+* 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.
 
-* wiki: document logind's PreparingForShutdown, PreparingForSleep
+* journald: we currently rotate only after MaxUse+MaxFilesize has been reached.
+
+* nspawn: bind mount /var/log/journal from the host
 
-* support debian's console-setup logic
+* Document:
+        - PID 1 D-Bus API
 
 * introduce Type=pid-file
 
@@ -57,12 +84,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
@@ -79,8 +119,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
@@ -167,9 +205,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
@@ -202,12 +237,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