zoukankan      html  css  js  c++  java
  • HelloWorld 模块

    helloworld.c 代码

     1 #include <linux/init.h>
     2 #include <linux/module.h>
     3 
     4 MODULE_LICENSE("Dual BSD/GPL");
     5 
     6 static int hello_init(void)
     7 {
     8 printk(KERN_ALERT "Hello world
    ");
     9 return 0;
    10 }
    11 
    12 static void hello_exit(void)
    13 {
    14 printk(KERN_ALERT "goodbye,cruel world
    ");
    15 }
    16 
    17 module_init(hello_init);
    18 module_exit(hello_exit);

    Makefile 代码

    obj-m := helloworld.o
    
    CURRENT_DIR :=$(shell pwd)
    
    KERNEL_DIR := /usr/src/linux-headers-$(shell uname -r)
    
    all:
            $(MAKE) -C $(KERNEL_DIR) M=$(CURRENT_DIR) modules
    
    clean:
            rm -rf %.o

    执行make

    ryan@Ryan-pc:/data1/Ryan/demo/helloworld$ make 
    make -C /usr/src/linux-headers-3.13.0-32-generic  M=/data1/Ryan/demo/helloworld modules
    make[1]: Entering directory `/usr/src/linux-headers-3.13.0-32-generic'
      Building modules, stage 2.
      MODPOST 1 modules
    make[1]: Leaving directory `/usr/src/linux-headers-3.13.0-32-generic'

    加载模块

    1 ryan@Ryan-pc:/data1/Ryan/demo/helloworld$ sudo insmod helloworld.ko 
    2 ryan@Ryan-pc:/data1/Ryan/demo/helloworld$ 

    dmesg查看

    1 ryan@Ryan-pc:/data1/Ryan/demo/helloworld$ dmesg
    [178401.813566] sr 0:0:0:0: [sr0] Device not ready
    [178401.813570] sr 0:0:0:0: [sr0]  
    [178401.813571] Result: hostbyte=DID_OK driverbyte=DRIVER_SENSE
    [178401.813572] sr 0:0:0:0: [sr0]  
    [178401.813573] Sense Key : Not Ready [current] 
    [178401.813575] sr 0:0:0:0: [sr0]  
    [178401.813577] Add. Sense: Medium not present - tray closed
    [178401.813579] sr 0:0:0:0: [sr0] CDB: 
    [178401.813580] Read(10): 28 00 00 00 02 2f 00 00 01 00
    [178401.813584] end_request: I/O error, dev sr0, sector 2236
    [179614.794066] helloworld: module verification failed: signature and/or  required key missing - tainting kernel
    [179614.794552] Hello world
    [180458.268623] goodbye,cruel world
    [180514.941519] Hello world
    [180549.136795] goodbye,cruel world
    [181244.193514] Hello world

    卸载模块

    1 ryan@Ryan-pc:/data1/Ryan/demo/helloworld$ sudo rmmod helloworld 
    2 ryan@Ryan-pc:/data1/Ryan/demo/helloworld$ 
     
  • 相关阅读:
    2017年5月15号课堂笔记
    2017年5月12号课堂笔记
    2017年5月8号课堂笔记
    2017年5月5号课堂笔记
    2017年4月26号课堂笔记
    不忘初心,坚持走下去
    2017年4月24号课堂笔记
    2017年4月21号课堂笔记
    2017年4月19号课堂笔记
    autoit UIA获取Listview的信息
  • 原文地址:https://www.cnblogs.com/xiaoxiaodewo/p/5621613.html
Copyright © 2011-2022 走看看