1. 程式人生 > >printk資訊列印到指定檔案 終端 網路

printk資訊列印到指定檔案 終端 網路

有的時候除錯核心程式,經常要將資訊列印到其他地方如指定檔案或終端還有網路,  網路的話dreanice版主寫過個netconsole我這裡就不說了...

列印到檔案:

  1. #include <linux/kernel.h>
  2. #include <linux/module.h>
  3. #include <linux/init.h>
  4. #include <linux/fs.h>
  5. #include <linux/string.h>
  6. #include <linux/mm.h>
  7. #include <linux/syscalls.h>
  8. #include <asm/unistd.h>
  9. #include <asm/uaccess.h>
  10. #define MY_FILE "/root/LogFile"
  11. char buf[128];
  12. struct file *file = NULL;
  13. static int __init init(void)
  14. {
  15.         mm_segment_t old_fs;
  16.         printk("Hello, I'm the module that intends to write messages to file.\n");
  17.         if(file == NULL)
  18.                 file = filp_open(MY_FILE, O_RDWR | O_APPEND | O_CREAT, 0644);
  19.         if (IS_ERR(file)) {
  20.                 printk("error occured while opening file %s, exiting...\n", MY_FILE);
  21.                 return 0;
  22.         }
  23.         sprintf(buf,"%s", "The Messages.");
  24.         old_fs = get_fs();
  25.         set_fs(KERNEL_DS);
  26.         file->f_op->write(file, (char *)buf, sizeof(buf), &file->f_pos);
  27.         set_fs(old_fs);
  28.         return 0;
  29. }
  30. static void __exit fini(void)
  31. {
  32.         if(file != NULL)
  33.                 filp_close(file, NULL);
  34. }
  35. module_init(init);
  36. module_exit(fini);
  37. MODULE_LICENSE("GPL");
複製程式碼


列印到終端:

  1. #include <linux/kernel.h>
  2. #include <linux/module.h>
  3. #include <linux/init.h>
  4. #include <linux/sched.h>
  5. #include <linux/tty.h>
  6. MODULE_LICENSE("GPL");
  7. MODULE_AUTHOR("mq110");
  8. static void print_string(char *str)
  9. {
  10.     struct tty_struct *my_tty;
  11.     my_tty = current->signal->tty;
  12.     if (my_tty != NULL)
  13.     {
  14.         my_tty->driver->write(my_tty,str,strlen(str));
  15.         my_tty->driver->write(my_tty,"\015\013",2);
  16.     }
  17. }
  18. static int __init print_string_init(void)
  19. {
  20.     print_string("Hello world!");
  21.     return 0;
  22. }
  23. static void __exit print_string_exit(void)
  24. {
  25.     print_string("Goodbye world!");
  26. }
  27. module_init(print_string_init);
  28. module_exit(print_string_exit);
複製程式碼


3.

修改一下/etc/syslog.conf 檔案
#kern.*       /dev/console

你列印的東西可能是某個級別的資訊。比如說debug,這用printk 可以控制 。
那麼就寫程
kern.debug /var/log/kern_debug.log

-------------------------
printk(KERN_ALERT "Hello, world\n"); 
對應
/etc/syslog.conf 中的
kern.alert                      /kernel.txt

實驗成功,修改後要執行
server syslogd restart 重啟日誌服務。
此方法等於用日誌服務幫你做這個事情。該資訊用
dmesg 命令也可以看到。

程式碼在Centos5.3   2.6.18上測試過了