커널모드 소켓 프로그래밍 실행시 Warning: kfree_skb on hard I
글쓴이: young93 / 작성시간: 금, 2003/02/07 - 2:42오후
디바이스 드라이버 모듈을 작성하고 있습니다.
커널 모드에서 sock_create()로 UDP 소켓을 열고
sock_sendmsg(), sock_recvmsg()를 이용하여
패킷을 주고 받는 프로그램을 짰는데,
패킷 수신시 이런 경고 메시지가 뜨네요
Warning: kfree_skb on hard IRQ c0098e50
뭐가 문제가 있어서 그런 걸까요.
에러가 아니고 경고니까 그냥 무시해도 상관이 없을까요?
조언 부탁드립니다.
아래는 소스입니다.
int recv_udpmsg(int sid, unsigned int *ip, unsigned short *port,
char *data, int len)
{
int err = 0;
struct socket *sock;
struct sockaddr_in addr;
struct iovec iov;
struct msghdr udpmsg;
mm_segment_t oldfs;
sock = s_sock[sid];
udpmsg.msg_name = (void *)&
udpmsg.msg_namelen = sizeof(addr);
udpmsg.msg_iov = &
udpmsg.msg_iovlen = 1;
udpmsg.msg_control = NULL;
udpmsg.msg_controllen = 0;
udpmsg.msg_flags = MSG_DONTWAIT;
udpmsg.msg_iov->iov_len = (__kernel_size_t)len;
udpmsg.msg_iov->iov_base = data;
oldfs = get_fs();
set_fs(KERNEL_DS);
err = sock_recvmsg(sock, &udpmsg, len, MSG_DONTWAIT);
if (err < 0) {
if (err != -11) printk("sock_recvmsg() err %d\n", err);
return -1;
}
set_fs(oldfs);
*ip = addr.sin_addr.s_addr;
*port = addr.sin_port;
return err;
}
int open_udpsock(int sid, unsigned short port)
{
int err;
struct socket *sock;
struct sockaddr_in addr;
err = sock_create(AF_INET, SOCK_DGRAM, IPPROTO_UDP, &sock);
if (err < 0) {
printk("sock_create() err %d\n", err);
return -1;
}
sock->sk->reuse = 1;
memset(&addr, 0, sizeof(addr));
addr.sin_port = htons(port);
err = sock->ops->bind(sock, (struct sockaddr *)&addr, sizeof(addr));
if (err < 0) {
printk("bind() err %d\n", err);
goto release;
}
s_sock[sid] = sock;
return 0;
release:
sock_release(sock);
sock = NULL;
return -1;
}
Forums:


혹시....
ISR에서 이 코드가 실행되고 있는 게 아닐까요..??
제가 이걸 해 구체적으로 해 보지 않아서는 잘 모르겠지만요, free하는 루틴에 문제가 있는 것 같습니다... kernel에서 메모리 allocation시 kmalloc/kfree는 특정 옵션을 줄때만 ISR에서 실행가능한 것으로 알고있습니다... 근데 free하는 루틴에서 ISR에서 실행불가능한 코드를 갖고 있는 게 아닐까 생각이 되는군요.
밑에 socket release하는 루틴이 좀 의심스럽습니다...
Consider the ravens: for they neither sow nor reap; which neither have storehouse nor barn; and God feedeth them: how much more are ye better than the fowls?
Luke 12:24
댓글 달기