官术网_书友最值得收藏!

How it works...

Now, it's time to see how all of the previous steps work. In future sections, we're going to explain better what this code really does. However, at the moment, we should just notice the following.

In step 1, notice the calls to module_init() and module_exit(), kernel-provided C macros, which are used to tell the kernel that, during the boot or shutdown of the system, it must call the functions we provided, named dummy_code_init() and dummy_code_exit(), which, in turn, just print some information messages.

Later on in this chapter, we're going to see in detail what printk() does and what the KERN_INFO macro means but, for now, we should take into account only that they are used to print a message during the boot (or shutdown). For instance, the preceding code instructs the kernel to print out the message dummy-code loaded at some time during the boot stage.

In step 2, in the Makefile, we are simply telling the kernel that if CONFIG_DUMMY_CODE has been enabled (that is CONFIG_DUMMY_CODE=y), then dummy-code.c must be compiled and inserted into the kernel binary (linked), while with the Kconfig file, we just add our new module into the kernel configuration system.

In step 3, we enable the compilation of our code by using the make menuconfig command.

In step 4, finally, we recompiled the kernel in order to add our code within it.

In step 5, during the boot, we should see the following kernel message:

...
loop: module loaded
dummy-code loaded
ahci-mvebu d00e0000.sata: AHCI 0001.0300 32 slots 1 ports 6 Gbps
...
主站蜘蛛池模板: 山西省| 邮箱| 宁河县| 格尔木市| 安龙县| 泰州市| 衡山县| 镇坪县| 内丘县| 杭锦旗| 嫩江县| 汉寿县| 河南省| 湛江市| 嵩明县| 达日县| 台南市| 临洮县| 蓬溪县| 托克逊县| 樟树市| 永安市| 依兰县| 汉沽区| 彭阳县| 乐亭县| 连州市| 长海县| 铁岭县| 修文县| 汉寿县| 大同市| 秭归县| 台北县| 岳西县| 边坝县| 炎陵县| 基隆市| 海盐县| 周口市| 九台市|