歡迎您光臨本站 註冊首頁

編寫模塊遍歷系統中的進程

←手機掃碼閱讀     火星人 @ 2014-03-12 , reply:0
  

 

       編寫內核模塊實現進程的遍歷。這個有點類似ps命令了。

  源程序:list.c

  /*****************************************

  *功能:利用進程鏈表遍歷當前系統中的所有進程

  *同時可以列印出進程的相關信息

  *

  * ***************************************/

  #include <linux/list.h>

  #include <linux/module.h>

  #include <linux/init.h>

  #include <linux/sched.h>

  #define METHOD 2

  static int list_init(void)

  {

  struct task_struct *task, *p;

  struct list_head *pos;

  int count;

  char *method;

  count = 0; /*下面這些初始化完全是為了消除編譯時的警告信息*/

  p = NULL;

  task = NULL;

  pos = NULL;

  method = NULL;

  task = &init_task;

  printk(KERN_ALERT"PID\tCOMM\n");

  switch(METHOD) {

  case 1:

  method="list_for_each";

  break;

  case 2:

  method="for_each_process";

  break;

  case 3:

  method="list_for_each_entry";

  break;

  }

  printk( "The method is %s\n", method );

  #if METHOD == 1

  list_for_each( pos, &task->tasks ) {

  p = list_entry( pos, struct task_struct, tasks );

  count++;

  printk( KERN_ALERT "%d\t%s\n", p->pid, p->comm );

  }

  #elif METHOD == 2

  for_each_process(task) {

  count++;

  printk( KERN_ALERT "%d\t%s\n", task->pid, task->comm );

  }

  #elif METHOD == 3

  list_for_each_entry( p, &task->tasks, tasks ) {

  count++;

  printk( KERN_ALERT "%d\t%s\n", p->pid, p->comm );

  }

  #endif

  printk("系統當前共 %d 個進程!!", count);

  return 0;

  }

  static void list_exit(void)

  {

  printk( KERN_ALERT "GOOD BYE!!\n");

  }

  module_init( list_init );

  module_exit( list_exit );

  MODULE_AUTHOR( "Along" );

  MODULE_LICENSE( "GPL" );

  我的Makefile:

  obj-m := list.o

  KERNELDIR ?= /lib/modules/$(shell uname -r)/build

  PWD := $(shell pwd)

  all:

  make -C $(KERNELDIR) M=$(PWD) modules

  clean:

  make -C $(KERNELDIR) M=$(PWD) clean

  這個程序主要用到了幾個關鍵的宏list_for_each,list_for_each_entry,for_each_process 。我們可以通過修改程序中 METHOD 的值查看不同宏運行產生的結果。



[火星人 ] 編寫模塊遍歷系統中的進程已經有441次圍觀

http://coctec.com/docs/program/show-post-71588.html