Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xindoo
redis
提交
d7826823
R
redis
项目概览
xindoo
/
redis
通知
2
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
redis
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
d7826823
编写于
2月 23, 2017
作者:
S
Salvatore Sanfilippo
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix BITPOS unaligned memory access.
上级
06263485
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
14 addition
and
7 deletion
+14
-7
src/bitops.c
src/bitops.c
+14
-7
未找到文件。
src/bitops.c
浏览文件 @
d7826823
...
...
@@ -104,6 +104,7 @@ long redisBitpos(void *s, unsigned long count, int bit) {
unsigned
long
skipval
,
word
=
0
,
one
;
long
pos
=
0
;
/* Position of bit, to return to the caller. */
unsigned
long
j
;
int
found
;
/* Process whole words first, seeking for first word that is not
* all ones or all zeros respectively if we are lookig for zeros
...
...
@@ -117,21 +118,27 @@ long redisBitpos(void *s, unsigned long count, int bit) {
/* Skip initial bits not aligned to sizeof(unsigned long) byte by byte. */
skipval
=
bit
?
0
:
UCHAR_MAX
;
c
=
(
unsigned
char
*
)
s
;
found
=
0
;
while
((
unsigned
long
)
c
&
(
sizeof
(
*
l
)
-
1
)
&&
count
)
{
if
(
*
c
!=
skipval
)
break
;
if
(
*
c
!=
skipval
)
{
found
=
1
;
break
;
}
c
++
;
count
--
;
pos
+=
8
;
}
/* Skip bits with full word step. */
skipval
=
bit
?
0
:
ULONG_MAX
;
l
=
(
unsigned
long
*
)
c
;
while
(
count
>=
sizeof
(
*
l
))
{
if
(
*
l
!=
skipval
)
break
;
l
++
;
count
-=
sizeof
(
*
l
);
pos
+=
sizeof
(
*
l
)
*
8
;
if
(
!
found
)
{
skipval
=
bit
?
0
:
ULONG_MAX
;
while
(
count
>=
sizeof
(
*
l
))
{
if
(
*
l
!=
skipval
)
break
;
l
++
;
count
-=
sizeof
(
*
l
);
pos
+=
sizeof
(
*
l
)
*
8
;
}
}
/* Load bytes into "word" considering the first byte as the most significant
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录