我编写了一个简单的内核模块,其中包含以下ksocket连接接受代码:
.....(some ksocket initiation)
while( on_service )
{
sockfd_c = kaccept(sockfd_s, (struct sockaddr *)&addr_cli, &addr_len);
kclose(sockfd_c);
}
编写一个简单的客户端来连接到这个套接字服务器。 从控制台,我发现当我连续运行客户端连接时,“free”命令会增加内存使用量。
kaccept()和kclose()的功能如下。
int kclose(ksocket_t sockfd)
{
struct socket *sk;
int ret;
sk = (struct socket *)sockfd;
ret = sk->ops->release(sk);
if (sk)
{
sock_release(sk);
}
return ret;
}
ksocket_t kaccept(ksocket_t socket, struct sockaddr *address, int *address_len)
{
struct socket *sk;
struct socket *new_sk = NULL;
int ret;
sk = (struct socket *)socket;
sxg_debug("family = %d, type = %d, protocol = %d\n",
sk->sk->sk_family, sk->type, sk->sk->sk_protocol);
//new_sk = sock_alloc();
//sock_alloc() is not exported, so i use sock_create() instead
ret = sock_create(sk->sk->sk_family, sk->type, sk->sk->sk_protocol, &new_sk);
if (ret < 0)
return NULL;
if (!new_sk)
return NULL;
new_sk->type = sk->type;
new_sk->ops = sk->ops;
ret = sk->ops->accept(sk, new_sk, 0 /*sk->file->f_flags*/);
if (ret < 0)
goto error_kaccept;
if (address)
{
ret = new_sk->ops->getname(new_sk, address, address_len, 2);
if (ret < 0)
goto error_kaccept;
}
return new_sk;
error_kaccept:
sock_release(new_sk);
return NULL;
}
有没有人知道内存泄漏的原因/方式?
答案 0 :(得分:0)
使用valgrind
查找内存泄漏
as
valgrind ./your_program
答案 1 :(得分:0)
我的内核版本是3.2,我正在尝试编写内核套接字服务器。 经过几天的战斗,我有以下发现。
我使用sock_create()来创建套接字服务器,然后通过
监听和接受连接sockfd_srv = sock_create(...)
...
while(1) {
sockfd_srv->ops->listen();
sockfd_cli = sock_create(...);
sockfd_srv->ops->accept(..., &sockfd_cli);
....(do something)
sock_release(sockfd_cli);
}
上述程序将导致内存泄漏,即使我通过sock_release()释放客户端的套接字。最后,系统会内存不足。
我改变它如下,我使用sock_create_lite()而不是sock_create()。
sockfd_srv = sock_create(...)
...
while(1) {
sockfd_srv->ops->listen();
sockfd_cli = sock_create_lite(...);
sockfd_srv->ops->accept(..., &sockfd_cli);
....(do something)
sock_release(sockfd_cli);
}
然后内存泄漏问题就消失了。