開發netfilter的一些坑 原

            第一:我自己電腦是ubuntu18,gcc是7.4,內核版本是4.1,我第一次看net filter的時候也是參照網上的例子,結果make的時候始終過不去。大致意思就是nf_register_hook在新版的內核裏面換掉了,新版內核函數變成了 nf_register_net_hook(&init_net, reg);所以的加上這樣一句

 #if LINUX_VERSION_CODE >= KERNEL_VERSION(4,13,0)
    nf_register_net_hook(&init_net, reg)
#else
    nf_register_hook(reg)
#endif

            第二:我服務器上是centos,gcc4.3,但是make的時候直接說沒有include/linux這個目錄,這個還是比較簡單的,直接下載一個對應版本的源文件放在/usr/src/include下面即可。所以直接 yum  install kernel-devel.

            第三,自從kernel4.13開始 hook函數的原型就是

int sample_nf_hookfn(void *priv,
                               struct sk_buff *skb,
                               const struct nf_hook_state *state);

而不是網上例子裏面的 

static unsigned int sample(
unsigned int hooknum,
struct sk_buff * skb,
const struct net_device *in,
const struct net_device *out,
int (*okfn) (struct sk_buff *))

,對於新的內核,需要編寫新的函數實現方式

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章