blob: f9e3b55895298283fcb874f55318937df605d470 [file] [log] [blame]
Lucas De Marchibf89f762011-12-01 18:23:47 -02001Features:
Lucas De Marchi5e690c52011-12-16 02:02:58 -02002=========
Lucas De Marchibf89f762011-12-01 18:23:47 -02003
Lucas De Marchi80e54cb2012-02-22 13:07:13 -02004* testsuite:
5 - when fake init_module() succeeds, create an entry in /sys/module
6 - when fake delete_module() succeeds, remove its entry from /sys/module
7 - add test for dependency loop _with install commands_ relying on module
8 already been loaded in order to succeed. E.g.: alsa install rules on
9 debian:
Lucas De Marchibf89f762011-12-01 18:23:47 -020010
Lucas De Marchi80e54cb2012-02-22 13:07:13 -020011 install snd /sbin/modprobe --ignore-install snd && { /sbin/modprobe --quiet snd-ioctl32 ; /sbin/modprobe --quiet snd-seq ; }
12 install snd_rawmidi /sbin/modprobe --ignore-install snd-rawmidi && { /sbin/modprobe --quiet snd-seq-midi ; : ; }
13 install snd_emu10k1 /sbin/modprobe --ignore-install snd-emu10k1 && { /sbin/modprobe --quiet snd-emu10k1-synth ; : ; }
14 install snd_pcm modprobe --ignore-install snd-pcm $CMDLINE_OPTS && { modprobe --quiet snd-pcm-oss ; : ; }
15 install snd_mixer modprobe --ignore-install snd-mixer $CMDLINE_OPTS && { modprobe --quiet snd-mixer-oss ; : ; }
16 install snd_seq modprobe --ignore-install snd-seq $CMDLINE_OPTS && { modprobe --quiet snd-seq-midi ; modprobe --quiet snd-seq-oss ; : ; }
Lucas De Marchic3325cf2011-12-02 14:49:57 -020017
Gustavo Sverzut Barbieri674f8592011-12-20 11:54:53 -020018* review API, maybe unify all of these setters:
19 - kmod_module_version_get_symbol()
20 - kmod_module_version_get_crc()
21 - kmod_module_symbol_get_symbol()
22 - kmod_module_symbol_get_crc()
23 - kmod_module_dependency_symbol_get_symbol()
24 - kmod_module_dependency_symbol_get_crc()
25 - kmod_module_versions_free_list()
26 - kmod_module_symbols_free_list()
27 - kmod_module_dependency_symbols_free_list()
28
Lucas De Marchia41b39f2012-01-20 13:04:43 -020029* Stop using system() inside the library and use fork + exec instead
30
Lucas De Marchi80e54cb2012-02-22 13:07:13 -020031* config: configs that do not need to be matched by fnmatch() could be using a
32 vector instead of a list. This way we could search in it by calling
33 bsearch().
Lucas De Marchi9207df72012-02-14 21:57:35 -020034
Lucas De Marchi80e54cb2012-02-22 13:07:13 -020035* index: drop the "open(), seek(), read()" implementation and use another one
36 with mmap(). When lookup() is called and the file is not mmaped, mmap it.
Lucas De Marchi5e690c52011-12-16 02:02:58 -020037
Lucas De Marchi3af535c2011-12-27 17:32:55 -020038Things to be added/removed in kernel (check what is really needed):
Lucas De Marchi5e690c52011-12-16 02:02:58 -020039===================================================================
40
41* list of currently loaded modules
Lucas De Marchi80e54cb2012-02-22 13:07:13 -020042 - readdir() in /sys/modules: dir without a 'initstate' file means the
43 module is builtin.
Lucas De Marchi5e690c52011-12-16 02:02:58 -020044
45* module's size should be available under /sys
Lucas De Marchi758428a2012-01-16 15:56:17 -020046 - DONE in 3.3: http://git.kernel.org/?p=linux/kernel/git/torvalds/linux.git;a=commit;h=cca3e707301862ca9b9327e6a732463982f8cd1b
Lucas De Marchi5e690c52011-12-16 02:02:58 -020047
48* kill /proc/modules ?
Lucas De Marchi758428a2012-01-16 15:56:17 -020049 - Unlikely, given other tools might depend on it
Lucas De Marchi5a96c5f2012-01-01 05:47:17 -020050
51Things that are different from module-init-tools on purpose (!TODO)
52===================================================================
53
54modprobe
55--------
56
57* 'modprobe -l' was marked as deprecated and does not exist anymore
58
59* 'modprobe -t' is gone, together with 'modprobe -l'
60
Lucas De Marchi80e54cb2012-02-22 13:07:13 -020061* there's and additional '--remove-dependencies' flags to modprobe so we
Lucas De Marchi5a96c5f2012-01-01 05:47:17 -020062 can remove modules depending on that one
63
Lucas De Marchi80e54cb2012-02-22 13:07:13 -020064* modprobe doesn't parse configuration files with names not ending in
65 '.alias' or '.conf'. modprobe used to warn about these files.
Lucas De Marchi5a96c5f2012-01-01 05:47:17 -020066
Lucas De Marchi80e54cb2012-02-22 13:07:13 -020067* modprobe doesn't parse 'config' and 'include' commands in configuration
Lucas De Marchi0ad5dd02012-01-11 00:28:12 -020068 files.
69
Lucas De Marchif5643942012-01-12 14:45:11 -020070* modprobe from m-i-t does not honour softdeps for install commands. E.g.:
71 config:
72
73 install bli "echo bli"
74 install bla "echo bla"
75 softdep bla pre: bli
76
77 With m-i-t, the output of 'modprobe --show-depends bla' will be:
78 install "echo bla"
79
80 While with kmod:
81 install "echo bli"
82 install "echo bla"
83
Lucas De Marchibc434962012-01-13 02:35:34 -020084* kmod doesn't dump the configuration as is in the config files. Instead it
85 dumps the configuration as it was parsed. Therefore, comments and file names
86 are not dumped, but on the good side we know what the exact configuration
87 kmod is using. We did this because if we only want to know the entire content
88 of configuration files, it's enough to use find(1) in modprobe.d directories
89
Lucas De Marchi5a96c5f2012-01-01 05:47:17 -020090depmod
91------
92
93* there's no 'depmod -m' option: legacy modules.*map files are gone
Lucas De Marchie85b6732012-01-12 15:28:19 -020094
95lsmod
96-----
97
98* information is parsed from /sys instead of /proc/modules