chiark / gitweb /
nspawn: better use setresuid() instead of setreuid()
[elogind.git] / TODO
1 * udev-kernel.socket + udev.control.socket seems not
2   to work, udevd is started but no fd is passed
3
4 F15:
5
6 * swap units that are activated by one name but shown in the kernel under another are semi-broken
7
8 F15 External:
9
10 * NFS, networkmanager ordering issue (PENDING)
11
12 * NM should pull in network.target (PENDING)
13   https://bugzilla.redhat.com/show_bug.cgi?id=692008
14
15 * bluetooth should be possible to disable (PENDING)
16
17 * get writev() /dev/kmsg support into the F15 kernel
18     http://git.kernel.org/?p=linux/kernel/git/torvalds/linux-2.6.git;a=commit;h=7e5b58bcbcb3d7518389c1d82fb6e926f5a9f72c
19
20 * make anaconda write timeout=0 for encrypted devices
21
22 * fix broken Sockets=syslog-ng.socket packaging
23
24 Features:
25
26 * understand https://bugzilla.redhat.com/show_bug.cgi?id=672194
27
28 * possibly set timezone offset from systemd at init instead
29   of calling hwclock
30
31 * kernel: add device_type = "fb", "fbcon" to class "graphics"
32
33 * readahead: use BTRFS_IOC_DEFRAG_RANGE instead of BTRFS_IOC_DEFRAG ioctl, with START_IO
34
35 * readahead: check whether a btrfs volume includes ssd by checking mount flag "ssd"
36
37 * hostnamed: make file updates atomic
38
39 * support sd_notify() style notificatio when reload is finished (RELOADED=1)
40
41 * verify that the AF_UNIX sockets of a service in the fs still exist
42   when we start a service in order to avoid confusion when a user
43   assumes starting a service is enough to make it accessible
44
45 * drop -lrt req for sd-daemon.[ch]
46
47 * Make it possible to set the keymap independently from the font on
48   the kernel cmdline. Right now setting one resets also the other.
49
50 * add dbus call to convert snapshot into target
51
52 * move nss-myhostname into systemd
53
54 * figure out a standard place to configure timezone name, inform myllynen@redhat.com
55
56 * add dbus call to convert snapshot into target
57
58 * move /selinux to /sys/fs/selinux
59
60 * detect LXC with $container=lxc
61
62 * add prefix match to sysctl, tmpfiles, ...
63
64 * drop /.readahead on bigger upgrades with yum
65
66 * add inode stat() check to readahead to suppress preloading changed files
67
68 * allow list of paths in config_parse_condition_path()
69
70 * introduce dbus calls for enabling/disabling a service
71
72 * support notifications for services being enabled/disabled
73
74 * GC unreferenced jobs (such as .device jobs)
75
76 * add JoinControllers= to system.conf to mount certain cgroup
77   controllers together in order to guarantee atomic creation/addition
78   of cgroups
79
80 * don't enter "exited" mode for sysv services with pid file
81
82 * avoid DefaultStandardOutput=syslog to have any effect on StandardInput=socket services
83
84 * cgroup_notify_empty(): recursively check groups up the tree, too
85
86 * fix alsa mixer restore to not print error when no config is stored
87
88 * show enablement status in systemctl status
89
90 * support SYSTEMD_PAGER taking precedence over PAGER
91
92 * fix upstart reboot compat call
93
94 * In systemctl make sure both is-enabled and is-active print a string, or neither.
95
96 * teach systemctl to enable unit files in arbitrary directories
97
98 * when failing to start a service due to ratelimiting, try again later, if restart=always is set
99
100 * write blog stories about:
101   - enabling dbus services
102   - status update
103   - /etc/sysconfig and /etc/default
104   - how to write socket activated services
105
106 * maybe add tiny dbus services similar to hostnamed for locale and wallclock/timezone?
107
108 * allow port=0 in .socket units
109
110 * rename systemd-logger to systemd-stdio-syslog-bridge
111
112 * take BSD file lock on tty devices when using them?
113
114 * avoid any flag files, or readahead files in /, we need to support r/o /
115   or / on tmpfs like Android setups.
116
117 * move readahead files into /var, look for them with .path units
118
119 * teach dbus to activate all services it finds in /etc/systemd/services/org-*.service
120
121 * get process transport into dbus for systemctl -P/-H
122
123 * document default dependencies
124
125 * support systemd.whitelist=/systemd.blacklist= on the kernel command
126   line.
127
128 * Find a way to replace /var/run, /var/lock directories with
129   symlinks during an RPM package upgrade (filesystem.rpm or systemd.rpm).
130   (lua code to create symlinks right away for new installations is in filesytem.rpm now)
131   We soon want to get rid of var-run.mount var-lock.mount units:
132     if mountpoint /run ; then
133           umount /var/run || :
134     else
135           mount --move /var/run /run || mount --bind /var/run /run
136     fi
137     mv /var/run /var/.run.save
138     ln -s /run /var/run
139     echo "R /var/.run.save" > /etc/tmpfiles.d/remove-run-save.conf
140
141 * when key file cannot be found, read it from kbd in cryptsetup
142
143 * add switch to systemctl to show enabled but not running services. Or
144   another switch that shows service that have been running since
145   booting but aren't running anymore.
146
147 * reuse mkdtemp namespace dirs in /tmp?
148
149 * recreate systemd's D-Bus private socket file on SIGUSR2
150
151 * be more specific what failed:
152     ...
153     Unmounting file systems.
154     Not all file systems unmounted, 1 left.
155     Disabling swaps.
156     Detaching loop devices.
157     Detaching DM devices.
158     Cannot finalize remaining file systems and devices, trying to kill remaining processes.
159     Unmounting file systems.
160     Not all file systems unmounted, 1 left.
161     Cannot finalize remaining file systems and devices, giving up.
162     ...
163
164 * check for compiled-in, but not active selinux, and don't print any warnings
165   about policy loading. Probably check for available selinux in /proc/filesystems,
166   and check for active selinux with getcon_raw() == "kernel"
167
168 * Support --test based on current system state
169
170 * consider services with any kind of link in /etc/systemd/system enabled
171
172 * show failure error string in "systemctl status"
173
174 * make sure timeouts are applied to Type=oneshot services.
175
176 * Implement:
177     systemctl mask <unit>
178     systemctl unmask <unit>
179   Also support --temp to make this temporary by placing mask links in /run.
180
181 * detect LXC environment
182
183 * Maybe store in unit files whether a service should be enabled by default on package installation
184   (belongs into a distro pattern though, not in an upstream package's service file)
185
186 * perhaps add "systemctl reenable" as combination of "systemctl disable" and "systemctl enable"
187
188 * need a way to apply mount options of api vfs from systemd unit files
189   (or some other modern source?) instead of fstab?
190
191 * maybe introduce ExecRestartPre=
192
193 * figure out what happened to bluez patch
194
195 * Patch systemd-fsck to use -C and pass console fd to it
196
197 * configurable jitter for timer events
198
199 * Support ProcessNeededForShutdown=true to allow stuff like mdmon to
200   be killed very late after the rootfs is read only? If implement pass
201   this to shutdown binary via command line argument.
202
203 * use pivot_root on shutdown so that we can unmount the root directory.
204    - copy binaries to, and pivot_root() to the "shutdown tmpfs"
205    - solve "mdadm --wait-clean" problem that way
206
207 * dot output for --test showing the 'initial transaction'
208
209 * calendar time support in timer, iCalendar semantics for the timer stuff (RFC2445)
210     http://git.kernel.org/?p=linux/kernel/git/torvalds/linux-2.6.git;a=commit;h=99ee5315dac6211e972fa3f23bcc9a0343ff58c4
211
212 * systemd --user
213   - get PR_SET_ANCHOR merged: http://lkml.org/lkml/2010/2/2/165
214
215 * add VT tracking:
216   - provide CK functionality
217   - start getty only when actual vt switch happens (same model as
218     socket on-demand activation). allocate the next free tty and
219     start a getty there. this way, pressing alt-f[1-12] will switch
220     through running X and getty sessions, and any unallocated
221     activated tty will start a new getty. the hardcoding of
222     getty[1-6] will entirely go away.
223   - http://git.kernel.org/?p=linux/kernel/git/torvalds/linux-2.6.git;a=commit;h=fbc92a3455577ab17615cbcb91826399061bd789
224
225 * implicitly import "defaults" settings file into all types
226
227 * port over to LISTEN_FDS/LISTEN_PID:
228    - uuidd    HAVEPATCH
229    - rpcbind (/var/run/rpcbind.sock!) HAVEPATCH
230    - cups     HAVEPATCH
231    - postfix, saslauthd
232    - apache/samba
233    - libvirtd (/var/run/libvirt/libvirt-sock-ro)
234    - bluetoothd (/var/run/sdp! @/org/bluez/audio!)
235    - distccd
236
237 * fingerprint.target, wireless.target, gps.target, netdevice.target
238
239 * set_put(), hashmap_put() return values check. i.e. == 0 doesn't free()!
240
241 * io priority during initialization
242
243 * if a service fails too often, make the service enter failed mode, and the socket, too.
244
245 * systemctl list-jobs - show dependencies
246
247 * auditd service files
248
249 * add systemctl switch to dump transaction without executing it
250
251 * suspend, resume support?
252
253 * readahead: btrfs/LVM SSD detection
254
255 * add separate man page for [Install] settings
256
257 * allow runtime changing of log level and target
258
259 * drop cap bounding set in readahead and other services
260
261 External:
262
263 * udisks should not use udisks-part-id, instead use blkid. also not probe /dev/loopxxx
264
265 * snd-seq should go, https://bugzilla.redhat.com/show_bug.cgi?id=676095
266
267 * gnome-shell python script/glxinfo/is-accelerated must die
268
269 * make cryptsetup lower --iter-time
270
271 * patch kernel for xattr support in /dev, /proc/, /sys and /sys/fs/cgroup?
272
273 * patch kernel for cpu feature modalias for autoloading aes/kvm/...
274     http://git.kernel.org/?p=linux/kernel/git/ak/linux-misc-2.6.git;a=shortlog;h=refs/heads/cpuid-match
275   (Rafael J. Wysocki's sysdev rework is on the way. After that CPUs can be exported a proper bus.)
276
277 * procps, psmisc, sysvinit-tools, hostname → util-linux-ng
278
279 https://bugzilla.redhat.com/show_bug.cgi?id=614245 -- plymouth
280 https://bugzilla.redhat.com/show_bug.cgi?id=612789 -- umount /cgroup on halt
281 https://bugzilla.redhat.com/show_bug.cgi?id=612728 -- /etc/rc.d/init.d/functions
282 https://bugzilla.redhat.com/show_bug.cgi?id=612712 -- pam_systemd
283 https://bugs.freedesktop.org/show_bug.cgi?id=29193 -- accountsservice
284 https://bugs.freedesktop.org/show_bug.cgi?id=29194 -- ConsoleKit
285 https://bugs.freedesktop.org/show_bug.cgi?id=29205 -- udisks
286 http://article.gmane.org/gmane.linux.bluez.kernel/6479 -- bluez
287 http://www.spinics.net/lists/linux-nfs/msg14371.html -- rpcbind
288 https://bugzilla.redhat.com/show_bug.cgi?id=617328 -- ntp
289 https://bugzilla.redhat.com/show_bug.cgi?id=617320 -- at
290 https://bugzilla.redhat.com/show_bug.cgi?id=617326 -- fprintd
291 https://bugzilla.redhat.com/show_bug.cgi?id=617333 -- yum
292 https://bugzilla.redhat.com/show_bug.cgi?id=617317 -- acpid
293 https://bugzilla.redhat.com/show_bug.cgi?id=617327 -- gpm
294 https://bugzilla.redhat.com/show_bug.cgi?id=617330 -- pcsc-lite
295 https://bugzilla.redhat.com/show_bug.cgi?id=617321 -- audit
296 https://bugzilla.redhat.com/show_bug.cgi?id=617316 -- abrt
297
298 Regularly:
299
300 * look for close() vs. close_nointr() vs. close_nointr_nofail()
301
302 * check for strerror(r) instead of strerror(-r)
303
304 * Use PR_SET_PROCTITLE_AREA if it becomes available in the kernel
305
306 * %m in printf() instead of strerror();
307
308 * pahole
309
310 * CFLAGS="-Wl,--gc-sections -Wl,--print-gc-sections -ffunction-sections -fdata-sections"