sk_buff 의 내용을 좀 보려다가 문제가 생겼습니다.
얼마전부터 가끔씩 Oops가 발생해서, 좀 자세히 들여다 보고 있었는데요,
/net/core/dev.c에 있는 netif_rx(struct sk_buff *skb)라는 function을 보고
있는 중이었고요..
Function의 중간쯤에서 skb->h.uh->source 를 찍어보려고 시도 했는데,
Oops가 발생해 버리네요.
첨가한 code는 그냥
printk("KERNEL-DEBUG : udp source = %d \n", (unsigned short)skb->h.uh->source)이고요
넣은 위치는 아래와 같고요..
__get_cpu_var(netdev_rx_stat).total++;
if (queue->input_pkt_queue.qlen <= netdev_max_backlog) {
if (queue->input_pkt_queue.qlen) {
enqueue:
dev_hold(skb->dev);
__skb_queue_tail(&queue->input_pkt_queue, skb);
local_irq_restore(flags);
if (netif_rx_debug == 1111)
printk("KERNEL --- udp source = %d \n", (unsigned short)skb->h.uh->source);
netif_rx_debug++;
return NET_RX_SUCCESS;
}
netif_rx_schedule(&queue->backlog_dev);
goto enqueue;
}
packet이 들어올때마다 계속 찍는 걸 방지하려고
그냥 임의로 counter가 1111을 세고나면 한번 찍도록 해봤는데요.
100% Oops가 발생하거든요.
뭐가 잘못된건지 잘 안보여서 이렇게 질문 드립니다.
조언 부탁드리고 싶어서요,,미리 감사드립니다. ^^
첨부 | 파일 크기 |
---|---|
code.txt | 556바이트 |
첨부 file을 올렸습니다.
써놓고 보니 위의 글 중 code부분이 보기 안 좋아서요..
첨부로 같은 내용을 올렸습니다.. ^^
netif_rx() 함수는
netif_rx() 함수는 네트워크 칩에서 읽은 패킷을 상위 스택에 올려주는 데이타링크 계층 수신 함수 입니다.
아직 IP 및 UDP 스택을 거치지 않았기 때문에 당연히 UDP 헤더 정보가 없습니다.
적절한 UDP 계층 함수에 해당 코드를 넣어주시면 되겠네요.
------------------------------------------
http://onestep.tistory.com
Just do it!
댓글 달기