Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
天中雨水
rt-thread
提交
1571ef5a
R
rt-thread
项目概览
天中雨水
/
rt-thread
该项目与 Fork 源项目分叉
Fork自
RT-Thread / rt-thread
通知
2
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
rt-thread
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
1571ef5a
编写于
9月 04, 2018
作者:
Lawlieta
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[net][sal] Fix close/shutdown memory leak issue.
上级
39f3f93e
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
28 addition
and
12 deletion
+28
-12
components/net/sal_socket/src/sal_socket.c
components/net/sal_socket/src/sal_socket.c
+28
-12
未找到文件。
components/net/sal_socket/src/sal_socket.c
浏览文件 @
1571ef5a
...
...
@@ -30,11 +30,13 @@
#include <sal.h>
#define DBG_ENABLE
#define DBG_SECTION_NAME "SAL_SOC"
#define DBG_LEVEL DBG_INFO
#define DBG_SECTION_NAME
"SAL_SOC"
#define DBG_LEVEL
DBG_INFO
#define DBG_COLOR
#include <rtdbg.h>
#define SOCKET_TABLE_STEP_LEN 4
/* the socket table used to dynamic allocate sockets */
struct
sal_socket_table
{
...
...
@@ -52,19 +54,29 @@ static rt_bool_t init_ok = RT_FALSE;
/**
* SAL (Socket Abstraction Layer) initialize.
*
* @return result
*
>= 0: initialize success
* @return result
0: initialize success
*
-1: initialize failed
*/
int
sal_init
(
void
)
{
int
cn
;
if
(
init_ok
)
{
LOG_D
(
"Socket Abstraction Layer is already initialized."
);
return
0
;
}
/* clean sal socket table */
rt_memset
(
&
socket_table
,
0
,
sizeof
(
socket_table
));
/* init sal socket table */
cn
=
SOCKET_TABLE_STEP_LEN
<
SAL_SOCKETS_NUM
?
SOCKET_TABLE_STEP_LEN
:
SAL_SOCKETS_NUM
;
socket_table
.
max_socket
=
cn
;
socket_table
.
sockets
=
rt_calloc
(
1
,
cn
*
sizeof
(
struct
sal_socket
*
));
if
(
socket_table
.
sockets
==
RT_NULL
)
{
LOG_E
(
"No memory for socket table.
\n
"
);
return
-
1
;
}
/* create sal socket lock */
rt_mutex_init
(
&
sal_core_lock
,
"sal_lock"
,
RT_IPC_FLAG_FIFO
);
...
...
@@ -80,7 +92,7 @@ INIT_COMPONENT_EXPORT(sal_init);
*
* @param pf protocol family object
*
* @return
>=0 : protocol family object index
* @return
0 : protocol family object register success
* -1 : the global array of available protocol families is full
*/
int
sal_proto_family_register
(
const
struct
proto_family
*
pf
)
...
...
@@ -331,8 +343,8 @@ static int socket_alloc(struct sal_socket_table *st, int f_socket)
int
cnt
,
index
;
struct
sal_socket
**
sockets
;
/* increase the number of
FD
with 4 step length */
cnt
=
st
->
max_socket
+
4
;
/* increase the number of
socket
with 4 step length */
cnt
=
st
->
max_socket
+
SOCKET_TABLE_STEP_LEN
;
cnt
=
cnt
>
SAL_SOCKETS_NUM
?
SAL_SOCKETS_NUM
:
cnt
;
sockets
=
rt_realloc
(
st
->
sockets
,
cnt
*
sizeof
(
struct
sal_socket
*
));
...
...
@@ -352,7 +364,7 @@ static int socket_alloc(struct sal_socket_table *st, int f_socket)
/* allocate 'struct sal_socket' */
if
(
idx
<
(
int
)
st
->
max_socket
&&
st
->
sockets
[
idx
]
==
RT_NULL
)
{
st
->
sockets
[
idx
]
=
rt_
malloc
(
sizeof
(
struct
sal_socket
));
st
->
sockets
[
idx
]
=
rt_
calloc
(
1
,
sizeof
(
struct
sal_socket
));
if
(
st
->
sockets
[
idx
]
==
RT_NULL
)
{
idx
=
st
->
max_socket
;
...
...
@@ -476,7 +488,9 @@ int sal_shutdown(int socket, int how)
if
(
sock
->
ops
->
shutdown
((
int
)
sock
->
user_data
,
how
)
==
0
)
{
rt_memset
(
sock
,
0x00
,
sizeof
(
struct
sal_socket
));
rt_free
(
sock
);
sock
=
RT_NULL
;
return
0
;
}
...
...
@@ -683,7 +697,9 @@ int sal_closesocket(int socket)
if
(
sock
->
ops
->
closesocket
((
int
)
sock
->
user_data
)
==
0
)
{
rt_memset
(
sock
,
0x00
,
sizeof
(
struct
sal_socket
));
rt_free
(
sock
);
sock
=
RT_NULL
;
return
0
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录