Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Unity
提交
380103ab
T
Third Party Unity
项目概览
OpenHarmony
/
Third Party Unity
1 年多 前同步成功
通知
36
Star
144
Fork
2
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
Third Party Unity
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
380103ab
编写于
9月 30, 2019
作者:
M
Mark VanderVoord
提交者:
GitHub
9月 30, 2019
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #448 from alecoding/malloc_alignment
Fix malloc alignment (Thanks @alecoding )
上级
46263fc1
7df6cca7
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
30 addition
and
7 deletion
+30
-7
extras/fixture/src/unity_fixture.c
extras/fixture/src/unity_fixture.c
+30
-7
未找到文件。
extras/fixture/src/unity_fixture.c
浏览文件 @
380103ab
...
...
@@ -188,13 +188,26 @@ typedef struct GuardBytes
}
Guard
;
#define UNITY_MALLOC_ALIGNMENT (UNITY_POINTER_WIDTH / 8)
static
const
char
end
[]
=
"END"
;
static
size_t
unity_size_round_up
(
size_t
size
)
{
size_t
rounded_size
;
rounded_size
=
((
size
+
UNITY_MALLOC_ALIGNMENT
-
1
)
/
UNITY_MALLOC_ALIGNMENT
)
*
UNITY_MALLOC_ALIGNMENT
;
return
rounded_size
;
}
void
*
unity_malloc
(
size_t
size
)
{
char
*
mem
;
Guard
*
guard
;
size_t
total_size
=
size
+
sizeof
(
Guard
)
+
sizeof
(
end
);
size_t
total_size
;
total_size
=
sizeof
(
Guard
)
+
unity_size_round_up
(
size
+
sizeof
(
end
));
if
(
malloc_fail_countdown
!=
MALLOC_DONT_FAIL
)
{
...
...
@@ -243,9 +256,15 @@ static void release_memory(void* mem)
malloc_count
--
;
#ifdef UNITY_EXCLUDE_STDLIB_MALLOC
if
(
mem
==
unity_heap
+
heap_index
-
guard
->
size
-
sizeof
(
end
))
{
heap_index
-=
(
guard
->
size
+
sizeof
(
Guard
)
+
sizeof
(
end
));
size_t
block_size
;
block_size
=
unity_size_round_up
(
guard
->
size
+
sizeof
(
end
));
if
(
mem
==
unity_heap
+
heap_index
-
block_size
)
{
heap_index
-=
(
sizeof
(
Guard
)
+
block_size
);
}
}
#else
UNITY_FIXTURE_FREE
(
guard
);
...
...
@@ -300,12 +319,16 @@ void* unity_realloc(void* oldMem, size_t size)
if
(
guard
->
size
>=
size
)
return
oldMem
;
#ifdef UNITY_EXCLUDE_STDLIB_MALLOC
/* Optimization if memory is expandable */
if
(
oldMem
==
unity_heap
+
heap_index
-
guard
->
size
-
sizeof
(
end
)
&&
heap_index
+
size
-
guard
->
size
<=
UNITY_INTERNAL_HEAP_SIZE_BYTES
)
{
size_t
old_total_size
=
unity_size_round_up
(
guard
->
size
+
sizeof
(
end
));
if
((
oldMem
==
unity_heap
+
heap_index
-
old_total_size
)
&&
((
heap_index
-
old_total_size
+
unity_size_round_up
(
size
+
sizeof
(
end
)))
<=
UNITY_INTERNAL_HEAP_SIZE_BYTES
))
{
release_memory
(
oldMem
);
/* Not thread-safe, like unity_heap generally */
return
unity_malloc
(
size
);
/* No memcpy since data is in place */
}
}
#endif
newMem
=
unity_malloc
(
size
);
if
(
newMem
==
NULL
)
return
NULL
;
/* Do not release old memory */
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录