Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
dotNET Platform
runtime
提交
96d7d903
R
runtime
项目概览
dotNET Platform
/
runtime
11 个月 前同步成功
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
runtime
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
未验证
提交
96d7d903
编写于
3月 02, 2022
作者:
E
Egor Bogatov
提交者:
GitHub
3月 01, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix div-by-zero introduced in
https://github.com/dotnet/runtime/pull/65926
(#66035)
上级
a7a4ed95
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
6 addition
and
3 deletion
+6
-3
src/coreclr/vm/eehash.inl
src/coreclr/vm/eehash.inl
+2
-2
src/coreclr/vm/util.hpp
src/coreclr/vm/util.hpp
+4
-1
未找到文件。
src/coreclr/vm/eehash.inl
浏览文件 @
96d7d903
...
...
@@ -198,7 +198,7 @@ BOOL EEHashTableBase<KeyType, Helper, bDefaultCopyIsDeep>::Init(DWORD dwNumBucke
m_pVolatileBucketTable->m_pBuckets++;
m_pVolatileBucketTable->m_dwNumBuckets = dwNumBuckets;
#ifdef TARGET_64BIT
m_pVolatileBucketTable->m_dwNumBucketsMul = GetFastModMultiplier(dwNumBuckets);
m_pVolatileBucketTable->m_dwNumBucketsMul =
dwNumBuckets == 0 ? 0 :
GetFastModMultiplier(dwNumBuckets);
#endif
m_Heap = pHeap;
...
...
@@ -786,7 +786,7 @@ BOOL EEHashTableBase<KeyType, Helper, bDefaultCopyIsDeep>::GrowHashTable()
pNewBucketTable->m_pBuckets = pNewBuckets;
pNewBucketTable->m_dwNumBuckets = dwNewNumBuckets;
#ifdef TARGET_64BIT
pNewBucketTable->m_dwNumBucketsMul = GetFastModMultiplier(dwNewNumBuckets);
pNewBucketTable->m_dwNumBucketsMul =
dwNewNumBuckets == 0 ? 0 :
GetFastModMultiplier(dwNewNumBuckets);
#endif
// Add old table to the to free list. Note that the SyncClean thing will only
...
...
src/coreclr/vm/util.hpp
浏览文件 @
96d7d903
...
...
@@ -1017,7 +1017,10 @@ inline UINT64 GetFastModMultiplier(UINT32 divisor)
inline
UINT32
FastMod
(
UINT32
value
,
UINT32
divisor
,
UINT64
multiplier
)
{
return
(
UINT32
)(((((
multiplier
*
value
)
>>
32
)
+
1
)
*
divisor
)
>>
32
);
_ASSERTE
(
divisor
<=
INT_MAX
);
UINT32
highbits
=
(
UINT32
)(((((
multiplier
*
value
)
>>
32
)
+
1
)
*
divisor
)
>>
32
);
_ASSERTE
(
highbits
==
value
%
divisor
);
return
highbits
;
}
#endif
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录