ip包在linux 2.4内核中的旅程。

1.中断处理函数中:

网卡收到一帧------------------------〉引发中断-------------------cpu调用相应的中断处理函数(指向此网卡驱动中的相应的处理函数)(把此packet读到ram中)--------------------〉呼叫netif_rx函数来打上timestamp,并把此skb放入到cpu设置的队列中-----------------à标记软中断(__cpu_raise_softirq---------------------à中断完成。

 

2.当软中断被调用时(一共在三个地方调用),呼叫NET_RX_SOFTIRQ(其实就是net_rx_action()函数)来处理网络方面的软中断。-----------------net_rx_action()根据数据包的协议类型在数组ptype_base[16]里找到相应的协议,并从中知道了接收的处理函数,然后把数据包交给处理函数,这样就交给了上层处理,实际调用处理函数是通过net_rx_action()里的pt_prev->func()这一句。例如如果数据包是IP协议的话,ptype_base[ETH_P_IP]->func()(ip_rcv()),这样就把数据包交给了IP协议。根据包的类型,查找系统中注册了的相应的包处理函数,对于ipv4ip包,呼叫ip_rcv-------------NF_IP_PRE_ROUTING--------------ip_rcv_finish(进行对此包的路由操作)---------------------〉根据路由的结果,呼叫ip_local_deliver(给本机的包)/ip_forwardd(要转发的包)/ip_error()(出现错误的包)/ip_mr_input()(多播包的处理)

 

 

ip_forward:要进行转发的包,check ttl, mtu, call NF_IP_FORWARDS--------------ip_forwmard_finishcheck other ip options for forwardd!-------------------àip_send(如果需要分片,则调用ip_fragment,否则调用ip_finish_output()(call NF_IP_POST_ROUTING,然后时ip_finish_output2(填充链路层头部到skb结构中)--------------)hh->hh_output/dsr->neighbour->output

你可能感兴趣的:(linux,网络,input,action,output)