TODO revision add30678a1bf284ecd79438d219c45ca7a1c9f51
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
* udev-kernel.socket + udev.control.socket seems not
to work, udevd is started but no fd is passed
F15:
* swap units that are activated by one name but shown in the kernel under another are semi-broken
F15 External:
* NFS, networkmanager ordering issue (PENDING)
* NM should pull in network.target (PENDING)
* bluetooth should be possible to disable (PENDING)
* make anaconda write timeout=0 for encrypted devices
* fix broken Sockets=syslog-ng.socket packaging
Features:
* fix CUPS .path unit for globbing
* move PAM code into its own binary
* logind: ensure ACLs are updated on login and logout
* warn if the user stops a service but not its associated socket
* ensure we always set the facility when logging to kmsg
* service: pid file reading after reload doesn't work, since we don't reset the pid variable
* logind: spawn user@..service on login
* logind: non-local X11 server handling
* logind: use sysfs path in device hash table instead of sysname, as soon as fb driver is fixed
* implement Register= switch in .socket units to enable registration
in Avahi, RPC and other socket registration services.
* make sure people don't leave processes around after ExecStartPre=
* make sure systemd-ask-password-wall does not shutdown systemd-ask-password-console too early
* kernel: add /proc/sys file exposing CAP_LAST_CAP?
* kernel: add device_type = "fb", "fbcon" to class "graphics"
* understand https://bugzilla.redhat.com/show_bug.cgi?id=672194
* readahead: use BTRFS_IOC_DEFRAG_RANGE instead of BTRFS_IOC_DEFRAG ioctl, with START_IO
* readahead: check whether a btrfs volume includes ssd by checking mount flag "ssd"
* support sd_notify() style notification when reload is finished (RELOADED=1)
* support sf_notify() style notification when shutting down, to make auto-exit bus services work
* verify that the AF_UNIX sockets of a service in the fs still exist
when we start a service in order to avoid confusion when a user
assumes starting a service is enough to make it accessible
* Make it possible to set the keymap independently from the font on
the kernel cmdline. Right now setting one resets also the other.
* move nss-myhostname into systemd
* figure out a standard place to configure timezone name, inform myllynen@redhat.com
* add dbus call to convert snapshot into target, and a dbus call to generate target from current state
* detect LXC with $container=lxc
* drop /.readahead on bigger upgrades with yum
* add inode stat() check to readahead to suppress preloading changed files
* allow list of paths in config_parse_condition_path()
* show enablement status in systemctl status
* add support for /bin/mount -s
* GC unreferenced jobs (such as .device jobs)
* add JoinControllers= to system.conf to mount certain cgroup
controllers together in order to guarantee atomic creation/addition
of cgroups
* avoid DefaultStandardOutput=syslog to have any effect on StandardInput=socket services
* cgroup_notify_empty(): recursively check groups up the tree, too
* fix alsa mixer restore to not print error when no config is stored
* when failing to start a service due to ratelimiting, try again later, if restart=always is set
* write blog stories about:
- enabling dbus services
- status update
- how to make changes to sysctl and sysfs attributes
- remote access
* allow port=0 in .socket units
* rename systemd-logger to systemd-stdio-syslog-bridge
* take BSD file lock on tty devices when using them?
* avoid any flag files, or readahead files in /, we need to support r/o /
or / on tmpfs like Android setups.
* move readahead files into /var, look for them with .path units
* teach dbus to activate all services it finds in /etc/systemd/services/org-*.service
* get process transport into dbus for systemctl -P/-H
* document default dependencies
* support systemd.whitelist=/systemd.blacklist= on the kernel command
line.
symlinks during an RPM package upgrade (filesystem.rpm or systemd.rpm).
(lua code to create symlinks right away for new installations is in filesytem.rpm now)
We soon want to get rid of var-run.mount var-lock.mount units:
if mountpoint /run ; then
umount /var/run || :
else
fi
ln -s /run /var/run
echo "R /var/.run.save" > /etc/tmpfiles.d/remove-run-save.conf
* when key file cannot be found, read it from kbd in cryptsetup
* add switch to systemctl to show enabled but not running services. Or
another switch that shows service that have been running since
booting but aren't running anymore.
* reuse mkdtemp namespace dirs in /tmp?
* recreate systemd's D-Bus private socket file on SIGUSR2
* be more specific what failed:
...
Unmounting file systems.
Not all file systems unmounted, 1 left.
Disabling swaps.
Detaching loop devices.
Detaching DM devices.
Cannot finalize remaining file systems and devices, trying to kill remaining processes.
Unmounting file systems.
Not all file systems unmounted, 1 left.
Cannot finalize remaining file systems and devices, giving up.
...
* check for compiled-in, but not active selinux, and don't print any warnings
about policy loading. Probably check for available selinux in /proc/filesystems,
and check for active selinux with getcon_raw() == "kernel"
* Support --test based on current system state
* show failure error string in "systemctl status"
* make sure timeouts are applied to Type=oneshot services.
* investigate whether the gnome pty helper should be moved into systemd, to provide cgroup support.
* need a way to apply mount options of api vfs from systemd unit files
(or some other modern source?) instead of fstab?
* maybe introduce ExecRestartPre=
* figure out what happened to bluez patch
* Patch systemd-fsck to use -C and pass console fd to it
* configurable jitter for timer events
* Support ProcessNeededForShutdown=true to allow stuff like mdmon to
be killed very late after the rootfs is read only? If implement pass
this to shutdown binary via command line argument.
* dot output for --test showing the 'initial transaction'
* calendar time support in timer, iCalendar semantics for the timer stuff (RFC2445)
* systemd --user
- get PR_SET_ANCHOR merged: http://lkml.org/lkml/2010/2/2/165
* implicitly import "defaults" settings file into all types
* port over to LISTEN_FDS/LISTEN_PID:
- uuidd HAVEPATCH
- rpcbind (/var/run/rpcbind.sock!) HAVEPATCH
- cups HAVEPATCH
- postfix, saslauthd
- libvirtd (/var/run/libvirt/libvirt-sock-ro)
- bluetoothd (/var/run/sdp! @/org/bluez/audio!)
- distccd
* set_put(), hashmap_put() return values check. i.e. == 0 doesn't free()!
* io priority during initialization
* if a service fails too often, make the service enter failed mode, and the socket, too.
* systemctl list-jobs - show dependencies
* auditd service files
* add systemctl switch to dump transaction without executing it
* suspend, resume support?
* readahead: btrfs/LVM SSD detection
* allow runtime changing of log level and target
* drop cap bounding set in readahead and other services
External:
* udisks should not use udisks-part-id, instead use blkid. also not probe /dev/loopxxx
* snd-seq should go, https://bugzilla.redhat.com/show_bug.cgi?id=676095
* gnome-shell python script/glxinfo/is-accelerated must die
* make cryptsetup lower --iter-time
* patch kernel for xattr support in /dev, /proc/, /sys and /sys/fs/cgroup?
* patch kernel for cpu feature modalias for autoloading aes/kvm/...
(Rafael J. Wysocki's sysdev rework is on the way. After that CPUs can be exported a proper bus.)
* procps, psmisc, sysvinit-tools, hostname → util-linux-ng
https://bugzilla.redhat.com/show_bug.cgi?id=612789 -- umount /cgroup on halt
https://bugzilla.redhat.com/show_bug.cgi?id=612712 -- pam_systemd
https://bugs.freedesktop.org/show_bug.cgi?id=29193 -- accountsservice
https://bugs.freedesktop.org/show_bug.cgi?id=29194 -- ConsoleKit
https://bugzilla.redhat.com/show_bug.cgi?id=617330 -- pcsc-lite
Regularly:
* look for close() vs. close_nointr() vs. close_nointr_nofail()
* check for strerror(r) instead of strerror(-r)
* Use PR_SET_PROCTITLE_AREA if it becomes available in the kernel
* %m in printf() instead of strerror();
* pahole
* CFLAGS="-Wl,--gc-sections -Wl,--print-gc-sections -ffunction-sections -fdata-sections"