chiark / gitweb /
journald: flush /run to /var as soon as it becomes available
[elogind.git] / TODO
1 Bugfixes:
2
3 * swap units that are activated by one name but shown in the kernel under another are semi-broken
4
5 * NM should pull in network.target (PENDING)
6   https://bugzilla.redhat.com/show_bug.cgi?id=692008
7
8 * make anaconda write timeout=0 for encrypted devices
9
10 * service: pid file reading after reload doesn't work, since we don't reset the pid variable
11
12 * make sure timeouts are applied to Type=oneshot services.
13
14 * Dangling symlinks of .automount unit files in .wants/ directories, set up
15   automount points even when the original .automount file did not exist
16   anymore. Only the .mount unit was still around.
17
18 * make polkit checks async
19
20 * properly handle .mount unit state tracking when two mount points are stacked one on top of another on the exact same mount point.
21
22 Features:
23
24 * logind: selinux is borked...
25
26 * logind: sends SessionNew on Lock()?
27
28 * logind: allow showing logout dialog from system
29
30 * document that %% can be used to write % in a string that is specifier extended
31
32 * check utf8 everywhere
33
34 * when an instanced service exits, remove its parent cgroup too if possible.
35
36 * as Tom Gundersen pointed out there's a always a dep loop if people use crypto file systems with random keys
37
38 * unset container= in PID1?
39
40 * 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.
41
42 * if we can not get user quota for tmpfs, mount a separate tmpfs instance
43   for every user in /run/user/$USER with a configured maximum size
44
45 * default to actual 32bit PIDs, via /proc/sys/kernel/pid_max
46
47 * add an option to make mounts private/shareable and so on, enable this for root by default
48
49 * internal restart counter for units (focus on auto-respawn)
50
51 * finer-grained auto-respawn settings (rate-limit)
52
53 * be able to specify a forced restart of service A where service B depends on, in case B
54   needs to be auto-respawned?
55
56 * Something is wrong with symlink handling of "autovt@.service" in "systemctl list-unit-files"
57
58 * introduce sd_log_open() to create a connection to the syslog bridge via sd-daemon.h
59
60 * when a bus name of a service disappears from the bus make sure to queue further activation requests
61
62 * something like ConditionExec= or ExecStartPre= without failure state
63
64 * service restart retry configuration
65
66 * tmpfiles: apply "x" on "D" too (see patch from William Douglas)
67 * tmpfiles: support generation of char/block devices, symlinks and one-line files (think sysfs)
68
69 * Introduce ControlGroupPersistant=yes to set +t on the tasks file when creating the cgroup
70
71 * don't set $HOME in services unless requested
72
73 * remove hacks in vala code and require libnotify 0.7
74
75 * hide PAM/TCPWrap options in fragment parser when compile time disabled
76
77 * when we automatically restart a service, ensure we retsart its rdeps, too.
78
79 * allow Type=simple with PIDFile=
80   https://bugzilla.redhat.com/show_bug.cgi?id=723942
81
82 * move PAM code into its own binary
83
84 * warn if the user stops a service but not its associated socket
85
86 * logind: spawn user@..service on login
87
88 * logind: non-local X11 server handling
89
90 * implement Register= switch in .socket units to enable registration
91   in Avahi, RPC and other socket registration services.
92
93 * make sure people don't leave processes around after ExecStartPre=
94
95 * make sure systemd-ask-password-wall does not shutdown systemd-ask-password-console too early
96
97 * readahead: use BTRFS_IOC_DEFRAG_RANGE instead of BTRFS_IOC_DEFRAG ioctl, with START_IO
98
99 * readahead: check whether a btrfs volume includes ssd by checking mount flag "ssd"
100
101 * support sd_notify() style notification when reload begins (RELOADING=1), reload is finished (READY=1)
102
103 * support sd_notify() style notification when shutting down, to make auto-exit bus services work (STOPPING=1)
104
105 * verify that the AF_UNIX sockets of a service in the fs still exist
106   when we start a service in order to avoid confusion when a user
107   assumes starting a service is enough to make it accessible
108
109 * Make it possible to set the keymap independently from the font on
110   the kernel cmdline. Right now setting one resets also the other.
111
112 * move nss-myhostname into systemd
113
114 * and a dbus call to generate target from current state
115
116 * detect LXC with $container=lxc
117
118 * drop /.readahead on bigger upgrades with yum
119
120 * add inode nr check to readahead to suppress preloading changed files
121
122 * add support for /bin/mount -s
123
124 * GC unreferenced jobs (such as .device jobs)
125
126 * cgroup_notify_empty(): recursively check groups up the tree, too
127
128 * when failing to start a service due to ratelimiting, try again later, if restart=always is set
129
130 * write blog stories about:
131   - enabling dbus services
132   - status update
133   - how to make changes to sysctl and sysfs attributes
134   - remote access
135   - cgroup best pratices to avoid stepping on each others toes
136   - how to pass throw-away units to systemd, or dynamically change properties of existing units
137   - how to integrate cgconfig and suchlike with systemd
138   - security properties
139   - xinetd conversion
140   - details of instantiated @.service setups
141
142 * allow port=0 in .socket units
143
144 * move readahead files into /var, look for them with .path units
145
146 * teach dbus to activate all services it finds in /etc/systemd/services/org-*.service
147
148 * support systemd.mask= on the kernel command line.
149
150 * when key file cannot be found, read it from kbd in cryptsetup
151
152 * reuse mkdtemp namespace dirs in /tmp?
153
154 * recreate systemd's D-Bus private socket file on SIGUSR2
155
156 * Support --test based on current system state
157
158 * investigate whether the gnome pty helper should be moved into systemd, to provide cgroup support.
159
160 * maybe introduce ExecRestartPre=
161
162 * configurable jitter for timer events
163
164 * timer events with system resume
165
166 * timer events on calendar time
167
168 * Support ProcessNeededForShutdown=true to allow stuff like mdmon to
169   be killed very late after the rootfs is read only? If implement pass
170   this to shutdown binary via command line argument.
171
172 * dot output for --test showing the 'initial transaction'
173
174 * calendar time support in timer, iCalendar semantics for the timer stuff (RFC2445)
175     http://git.kernel.org/?p=linux/kernel/git/torvalds/linux-2.6.git;a=commit;h=99ee5315dac6211e972fa3f23bcc9a0343ff58c4
176
177 * implicitly import "defaults" settings file into all types
178 * exec settings override
179 * writable cgroups dbus properties for live changes
180
181 * read config fragments for all units from /lib/systemd/system/foobar.service.d/ to override/extend specific settings
182
183 * port over to LISTEN_FDS/LISTEN_PID:
184    - rpcbind (/var/run/rpcbind.sock!) HAVEPATCH
185    - cups     HAVEPATCH
186    - postfix, saslauthd
187    - apache/samba
188    - libvirtd (/var/run/libvirt/libvirt-sock-ro)
189    - bluetoothd (/var/run/sdp! @/org/bluez/audio!)
190    - distccd
191
192 * auditd service files
193
194 * fingerprint.target, wireless.target, gps.target, netdevice.target
195
196 * io priority during initialization
197
198 * if a service fails too often, make the service enter failed mode, and the socket, too.
199
200 * new deps "Triggers" and "TriggeredBy"
201
202 * systemctl list-jobs - show dependencies
203
204 * add systemctl switch to dump transaction without executing it
205
206 * suspend, resume support?
207
208 * drop cap bounding set in readahead and other services
209
210 External:
211
212 * dbus:
213    - get process transport into dbus for systemctl -P/-H (PENDING)
214    - dbus --user
215    - natively watch for dbus-*.service symlinks (PENDING)
216    - allow specification of socket mode/umask when allocating DBusServer
217    - allow disabling of fd passing when connecting a AF_UNIX connection
218    - allow disabling of UID passing for AUTH EXTERNAL
219
220 * systemd --user
221     PR_SET_CHILD_REAPER patch: https://lkml.org/lkml/2011/7/28/426
222
223 * fix alsa mixer restore to not print error when no config is stored
224
225 * udisks should not use udisks-part-id, instead use blkid. also not probe /dev/loopxxx
226
227 * snd-seq should go, https://bugzilla.redhat.com/show_bug.cgi?id=676095
228
229 * gnome-shell python script/glxinfo/is-accelerated must die
230
231 * make cryptsetup lower --iter-time
232
233 * patch kernel for xattr support in /dev, /proc/, /sys and /sys/fs/cgroup?
234
235 * patch kernel for cpu feature modalias for autoloading aes/kvm/...
236     http://git.kernel.org/?p=linux/kernel/git/ak/linux-misc-2.6.git;a=shortlog;h=refs/heads/cpuid-match
237   (Rafael J. Wysocki's sysdev rework is on the way. After that CPUs can be exported a proper bus.)
238
239 * kernel: add /proc/sys file exposing CAP_LAST_CAP? sysconf?
240
241 * kernel: add device_type = "fb", "fbcon" to class "graphics"
242
243 Regularly:
244
245 * look for close() vs. close_nointr() vs. close_nointr_nofail()
246
247 * check for strerror(r) instead of strerror(-r)
248
249 * Use PR_SET_PROCTITLE_AREA if it becomes available in the kernel
250
251 * %m in printf() instead of strerror();
252
253 * pahole
254
255 * set_put(), hashmap_put() return values check. i.e. == 0 doesn't free()!