chiark / gitweb /
autogen.sh: diet and sync with udev and kmod
[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 * move to LGPL2+
25
26 * logind: selinux is borked...
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 * Make libselinux, libattr, libcap, libdl dependencies only of the tools which actually need them.
37
38 * as Tom Gundersen pointed out there's a always a dep loop if people use crypto file systems with random keys
39
40 * unset container= in PID1?
41
42 * 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.
43
44 * if we can not get user quota for tmpfs, mount a separate tmpfs instance
45   for every user in /run/user/$USER with a configured maximum size
46
47 * default to actual 32bit PIDs, via /proc/sys/kernel/pid_max
48
49 * add an option to make mounts private/shareable and so on, enable this for root by default
50
51 * internal restart counter for units (focus on auto-respawn)
52
53 * finer-grained auto-respawn settings (rate-limit)
54
55 * be able to specify a forced restart of service A where service B depends on, in case B
56   needs to be auto-respawned?
57
58 * Something is wrong with symlink handling of "autovt@.service" in "systemctl list-unit-files"
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 * hide PAM/TCPWrap options in fragment parser when compile time disabled
74
75 * when we automatically restart a service, ensure we retsart its rdeps, too.
76
77 * allow Type=simple with PIDFile=
78   https://bugzilla.redhat.com/show_bug.cgi?id=723942
79
80 * move PAM code into its own binary
81
82 * warn if the user stops a service but not its associated socket
83
84 * logind: spawn user@..service on login
85
86 * logind: non-local X11 server handling
87
88 * implement Register= switch in .socket units to enable registration
89   in Avahi, RPC and other socket registration services.
90
91 * make sure people don't leave processes around after ExecStartPre=
92
93 * make sure systemd-ask-password-wall does not shutdown systemd-ask-password-console too early
94
95 * readahead: use BTRFS_IOC_DEFRAG_RANGE instead of BTRFS_IOC_DEFRAG ioctl, with START_IO
96
97 * readahead: check whether a btrfs volume includes ssd by checking mount flag "ssd"
98
99 * support sd_notify() style notification when reload begins (RELOADING=1), reload is finished (READY=1)
100
101 * support sd_notify() style notification when shutting down, to make auto-exit bus services work (STOPPING=1)
102
103 * verify that the AF_UNIX sockets of a service in the fs still exist
104   when we start a service in order to avoid confusion when a user
105   assumes starting a service is enough to make it accessible
106
107 * Make it possible to set the keymap independently from the font on
108   the kernel cmdline. Right now setting one resets also the other.
109
110 * move nss-myhostname into systemd
111
112 * and a dbus call to generate target from current state
113
114 * drop /.readahead on bigger upgrades with yum
115
116 * add inode nr check to readahead to suppress preloading changed files
117
118 * add support for /bin/mount -s
119
120 * GC unreferenced jobs (such as .device jobs)
121
122 * cgroup_notify_empty(): recursively check groups up the tree, too
123
124 * when failing to start a service due to ratelimiting, try again later, if restart=always is set
125
126 * write blog stories about:
127   - enabling dbus services
128   - status update
129   - how to make changes to sysctl and sysfs attributes
130   - remote access
131   - cgroup best pratices to avoid stepping on each others toes
132   - how to pass throw-away units to systemd, or dynamically change properties of existing units
133   - how to integrate cgconfig and suchlike with systemd
134   - security properties
135   - xinetd conversion
136   - details of instantiated @.service setups
137
138 * allow port=0 in .socket units
139
140 * move readahead files into /var, look for them with .path units
141
142 * teach dbus to activate all services it finds in /etc/systemd/services/org-*.service
143
144 * support systemd.mask= on the kernel command line.
145
146 * when key file cannot be found, read it from kbd in cryptsetup
147
148 * reuse mkdtemp namespace dirs in /tmp?
149
150 * recreate systemd's D-Bus private socket file on SIGUSR2
151
152 * Support --test based on current system state
153
154 * investigate whether the gnome pty helper should be moved into systemd, to provide cgroup support.
155
156 * maybe introduce ExecRestartPre=
157
158 * configurable jitter for timer events
159
160 * timer events with system resume
161
162 * timer events on calendar time
163
164 * Support ProcessNeededForShutdown=true to allow stuff like mdmon to
165   be killed very late after the rootfs is read only? If implement pass
166   this to shutdown binary via command line argument.
167
168 * dot output for --test showing the 'initial transaction'
169
170 * calendar time support in timer, iCalendar semantics for the timer stuff (RFC2445)
171     http://git.kernel.org/?p=linux/kernel/git/torvalds/linux-2.6.git;a=commit;h=99ee5315dac6211e972fa3f23bcc9a0343ff58c4
172
173 * implicitly import "defaults" settings file into all types
174 * exec settings override
175 * writable cgroups dbus properties for live changes
176
177 * read config fragments for all units from /lib/systemd/system/foobar.service.d/ to override/extend specific settings
178
179 * port over to LISTEN_FDS/LISTEN_PID:
180    - rpcbind (/var/run/rpcbind.sock!) HAVEPATCH
181    - cups     HAVEPATCH
182    - postfix, saslauthd
183    - apache/samba
184    - libvirtd (/var/run/libvirt/libvirt-sock-ro)
185    - bluetoothd (/var/run/sdp! @/org/bluez/audio!)
186    - distccd
187
188 * auditd service files
189
190 * fingerprint.target, wireless.target, gps.target, netdevice.target
191
192 * io priority during initialization
193
194 * if a service fails too often, make the service enter failed mode, and the socket, too.
195
196 * new deps "Triggers" and "TriggeredBy"
197
198 * systemctl list-jobs - show dependencies
199
200 * add systemctl switch to dump transaction without executing it
201
202 * suspend, resume support?
203
204 * drop cap bounding set in readahead and other services
205
206 External:
207
208 * dbus:
209    - get process transport into dbus for systemctl -P/-H (PENDING)
210    - dbus --user
211    - natively watch for dbus-*.service symlinks (PENDING)
212    - allow specification of socket mode/umask when allocating DBusServer
213    - allow disabling of fd passing when connecting a AF_UNIX connection
214    - allow disabling of UID passing for AUTH EXTERNAL
215
216 * systemd --user
217     PR_SET_CHILD_REAPER patch: https://lkml.org/lkml/2011/7/28/426
218
219 * fix alsa mixer restore to not print error when no config is stored
220
221 * udisks should not use udisks-part-id, instead use blkid. also not probe /dev/loopxxx
222
223 * snd-seq should go, https://bugzilla.redhat.com/show_bug.cgi?id=676095
224
225 * gnome-shell python script/glxinfo/is-accelerated must die
226
227 * make cryptsetup lower --iter-time
228
229 * patch kernel for xattr support in /dev, /proc/, /sys and /sys/fs/cgroup?
230
231 * NTP: the kernel's 11-minutes-mode syncs the system time to the RTC, but only
232   in an ~30 minutes window. It does not adjust larger differences. Find a way
233   to tell the kernel, to always do a full time sync when the RTC is in UTC and
234   we are in 11-minutes-mode. When we trust the system time to NTP we also want
235   the RTC to sync up.
236
237 * patch kernel for cpu feature modalias for autoloading aes/kvm/...
238     (patches in linux-next, on the way to the next kernel)
239
240 * kernel: add /proc/sys file exposing CAP_LAST_CAP? sysconf?
241     merged: http://git.kernel.org/?p=linux/kernel/git/torvalds/linux.git;a=commit;h=73efc0394e148d0e15583e13712637831f926720
242
243 * kernel: add device_type = "fb", "fbcon" to class "graphics"
244
245 Regularly:
246
247 * look for close() vs. close_nointr() vs. close_nointr_nofail()
248
249 * check for strerror(r) instead of strerror(-r)
250
251 * Use PR_SET_PROCTITLE_AREA if it becomes available in the kernel
252
253 * %m in printf() instead of strerror();
254
255 * pahole
256
257 * set_put(), hashmap_put() return values check. i.e. == 0 doesn't free()!