printk("arg,cmd: %ld %d\n", arg, cmd);
时间: 2024-04-04 15:35:14 浏览: 22
这是一个 Linux 内核中的打印函数,用于在内核日志中输出一条调试信息。其中,`arg` 和 `cmd` 分别是前面提到的 `BEEP_ioctl` 函数的参数,用于输出参数的值以及命令代码。
在这个代码中,`printk` 函数的格式化字符串为 `"arg,cmd: %ld %d\n"`,其中 `%ld` 和 `%d` 分别是格式化字符串中的占位符,用于输出 `arg` 和 `cmd` 参数的值。`%ld` 表示输出一个长整型数值,`%d` 表示输出一个有符号整型数值。`\n` 表示输出一个换行符,用于在打印信息后换行显示。因此,这个打印语句的作用是在内核日志中输出 `arg` 和 `cmd` 的值,用于调试和排查问题。
相关问题
static long int BEEP_ioctl(struct file *filp,unsigned int cmd, unsigned long arg) { //ioctl函数接口 if (arg > sizeof(beeps)/sizeof(unsigned long)) { return -EINVAL; } printk("arg,cmd: %ld %d\n", arg, cmd); switch(cmd) { case IOCTL_GPIO_OFF:// 设置指定引脚的输出电平为0,由电路图可知,输出0时为灭 gpio_set_value(beeps[arg].gpio, 0); break; case IOCTL_GPIO_ON: gpio_set_value(beeps[arg].gpio, 1); break; default: return -EINVAL; } return 0; }
这是一个名为 BEEP_ioctl 的函数,用于实现 ioctl 的操作。该函数的参数包括 filp、cmd 和 arg,分别表示文件指针、ioctl 命令和参数。该函数返回 0,表示操作成功。
在该函数中,首先对参数 arg 进行了检查,如果 arg 大于 beeps 数组的大小,则返回错误值 -EINVAL。接着,根据命令 cmd 的不同,分别将指定引脚的输出电平设置为 0 或 1,从而控制蜂鸣器的开关状态。其中,IOCTL_GPIO_OFF 表示关闭蜂鸣器,IOCTL_GPIO_ON 表示打开蜂鸣器。如果 cmd 不是这两个命令中的任何一个,则同样返回错误值 -EINVAL。
#include <linux/kernel.h> #include <linux/sched.h> #include <linux/module.h> #include <linux/init.h> #include <linux/moduleparam.h> static pid_t pid=1; module_param(pid, int, 0644); static int module1_init(void) { struct task_struct *p; struct list_head *pp; struct task_struct *psibling; //当前进程的PID p = pid_task(find_vpid(pid),PIDTYPE_PID); printk("me: %d %ld %s \n",p->pid,p->state,p->comm); //父进程 if(p->parent == NULL){ printk("No Parent\n"); } else{ printk("Parent:%d %ld %s \n",p->parent->pid,p->parent->state,p->parent->comm); } //兄弟进程 list_for_each(pp,&p->parent->children) { psibling = list_entry(pp,struct task_struct,sibling); printk("Brother %d %ld %s \n",psibling->pid,psibling->state,psibling->comm); } //子进程 list_for_each(pp,&p->children) { psibling = list_entry(pp,struct task_struct,sibling); printk("Children %d %ld %s \n",psibling->pid,psibling->state,psibling->comm); } return 0; } static void module1_exit(void) { printk(KERN_ALERT"goodbye!\n"); } module_init(module1_init); module_exit(module1_exit); MODULE_LICENSE("GPL");
这是一个 Linux 内核模块,可以获取指定进程的父进程、兄弟进程、子进程的信息,并打印输出。具体实现是通过调用 Linux 内核中的进程任务结构体 `task_struct` 中的成员变量来获取这些信息的。
其中,`module_param` 宏用于接收命令行参数,`module_init` 和 `module_exit` 宏分别用于指定模块的初始化函数和退出函数。`pid_task` 函数用于获取指定 PID 对应的进程任务结构体指针,而 `list_for_each` 宏则用于遍历双向链表。
需要注意的是,该模块需要在 Linux 内核源码目录下进行编译并加载,而且只能在特定的内核版本中运行。同时,也需要在加载时指定要查询的进程的 PID,例如:
```
insmod module1.ko pid=1234
```
这里的 `1234` 就是要查询的进程的 PID。
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![rar](https://img-home.csdnimg.cn/images/20210720083606.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![mp4](https://img-home.csdnimg.cn/images/20210720083504.png)