- 论坛徽章:
- 0
|
我的程序如下:
#define __KERNEL__
#define MODULE
#include <linux/module.h>
#include <linux/netdevice.h>
#include <linux/kernel.h>
#include <linux/netfilter.h>
#include <linux/netfilter_ipv4.h>
#include <linux/skbuff.h>
#include <linux/config.h>
#include <net/ip.h>
#include <linux/inet.h>
static struct nf_hook_ops nfho_pre;
struct ipv6_pk_flow {
unsigned int flowid;
struct sk_buff_head *q;
} ;
unsigned int hook_pre_routing( unsigned int hooknum,
struct sk_buff **skb,
const struct net_device *in,
const struct net_device *out,
int (*okfn)(struct sk_buff *))
{
printk("Enter NF_IP_PRE_ROUTING ...\n");
if((*skb)->nh.iph->saddr == in_aton("210.27.5.64") )
{
struct ipv6_pk_flow *ipv6_queue;
ipv6_queue->flowid = 0;
skb_queue_tail(ipv6_queue->q, *skb);
return NF_ACCEPT;
}
else
return NF_ACCEPT;
}
int queue_init( )
{
struct ipv6_pk_flow *ipv6_queue;
ipv6_queue = kmalloc(sizeof(struct ipv6_pk_flow), GFP_KERNEL );
skb_queue_purge( ipv6_queue->q );
skb_queue_head_init( ipv6_queue->q);
return 0;
}
int init_module()
{
nfho_pre.hook = hook_pre_routing;
nfho_pre.hooknum = NF_IP_PRE_ROUTING;
nfho_pre.pf = PF_INET;
nfho_pre.priority = NF_IP_PRI_FIRST;
nf_register_hook( &nfho_pre );
queue_init();
return 0;
}
void cleanup_module()
{
nf_unregister_hook( &nfho_pre );
}
MODULE_LICENSE("GPL");
编译并加载该模块后,出现段错误,请指出程序的错误,谢谢! |
|