使用netlink机制跟指定进程通信
netlink通信
我们知道,使用netlink可以完成用户跟内核态双向通信,实际使用时,我们需要对netlink进行封装统一的接口,在和指定进程进行通信时,只需要调用指定接口就可以轻松完成用户态到内核态的netlink通信编码。此外,我们上层用户态进程除了需要和内核进行通信外,还需要和其他用户态进程进行通信,因此需要封装统一的接口同时支持netlink用户态到用户态的通信以及用户态到内核态的通信。
编码目标
1、支持使用netlink完成用户态到内核态的通信
2、支持使用netlink完成用户态到用户态的通信
3、使用netlink通信时代码简单
编码实现
1、内核态代码
该文件位于内核模块:kernel/linux-4.1/net/wireless/
/******************************************************************************************************
* function:内核态代码,1、封装内核发送netlink消息统一接口;2、封装用户态发送netlink消息统一接口
* author:yahai.zhang
* time: 2021.5.20
* File Name:fh_wifimgr_netlink.c
******************************************************************************************************/
#include <linux/module.h>
#include <linux/skbuff.h>
#include <net/ip.h>
#include <net/netlink.h>
#include <linux/kernel.h>
#include <linux/proc_fs.h>
extern struct net init_net;
DEFINE_SPINLOCK(wifimgr_netlink_lock);
struct sock *wifimgr_nl_sk_netlink = NULL;
int pid_wifimgr_netlink = 0;
#define NETLINK_WIFIMGR 27
#define PROCNAME "wifimgr_netlink"
#define MAX_MSG_LEN 1024
struct proc_dir_entry *proc_entry = NULL;
char read_wifimgr_msg[MAX_MSG_LEN] = {
0};
static void get_wifimgr_mesg(struct sk_buff *sk)
{
struct sk_buff *skb = NULL;
struct nlmsghdr *nlh = NULL;
skb = skb_get(sk);
nlh = nlmsg_hdr(skb);
pid_wifimgr_netlink= nlh->nlmsg_pid; /*pid of sending process */
printk("get mesg from wifimgr, pid = %d\n", pid_wifimgr_netlink);
kfree_skb(skb);
}
static int sendnlmsg_to_wifimgr(struct sock *nl_sk, int pid, char *message, int length)
{
sk_buff_data_t old_tail;
struct sk_buff *skb;
struct nlmsghdr *nlh;
int size = NLMSG_SPACE(length);
if(pid <= 0)
{
printk("pid_wifimgr_netlink:%d\n", pid);
return -1;