mirror of
https://github.com/fluencelabs/redis
synced 2025-04-02 07:41:04 +00:00
BITCOUNT: fix segmentation fault.
remove unsafe and unnecessary cast. until now, this cast may lead segmentation fault when end > UINT_MAX setbit foo 0 1 bitcount 0 4294967295 => ok bitcount 0 4294967296 => cause segmentation fault. Note by @antirez: the commit was modified a bit to also change the string length type to long, since it's guaranteed to be at max 512 MB in size, so we can work with the same type across all the code path. A regression test was also added.
This commit is contained in:
parent
24bc807b5c
commit
749aac72ad
@ -327,10 +327,9 @@ void bitopCommand(redisClient *c) {
|
|||||||
/* BITCOUNT key [start end] */
|
/* BITCOUNT key [start end] */
|
||||||
void bitcountCommand(redisClient *c) {
|
void bitcountCommand(redisClient *c) {
|
||||||
robj *o;
|
robj *o;
|
||||||
long start, end;
|
long start, end, strlen;
|
||||||
unsigned char *p;
|
unsigned char *p;
|
||||||
char llbuf[32];
|
char llbuf[32];
|
||||||
size_t strlen;
|
|
||||||
|
|
||||||
/* Lookup, check for type, and return 0 for non existing keys. */
|
/* Lookup, check for type, and return 0 for non existing keys. */
|
||||||
if ((o = lookupKeyReadOrReply(c,c->argv[1],shared.czero)) == NULL ||
|
if ((o = lookupKeyReadOrReply(c,c->argv[1],shared.czero)) == NULL ||
|
||||||
@ -357,7 +356,7 @@ void bitcountCommand(redisClient *c) {
|
|||||||
if (end < 0) end = strlen+end;
|
if (end < 0) end = strlen+end;
|
||||||
if (start < 0) start = 0;
|
if (start < 0) start = 0;
|
||||||
if (end < 0) end = 0;
|
if (end < 0) end = 0;
|
||||||
if ((unsigned)end >= strlen) end = strlen-1;
|
if (end >= strlen) end = strlen-1;
|
||||||
} else if (c->argc == 2) {
|
} else if (c->argc == 2) {
|
||||||
/* The whole string. */
|
/* The whole string. */
|
||||||
start = 0;
|
start = 0;
|
||||||
|
@ -73,6 +73,12 @@ start_server {tags {"bitops"}} {
|
|||||||
set e
|
set e
|
||||||
} {ERR*syntax*}
|
} {ERR*syntax*}
|
||||||
|
|
||||||
|
test {BITCOUNT regression test for github issue #582} {
|
||||||
|
r del str
|
||||||
|
r setbit foo 0 1
|
||||||
|
r bitcount foo 0 4294967296
|
||||||
|
} {1}
|
||||||
|
|
||||||
test {BITOP NOT (empty string)} {
|
test {BITOP NOT (empty string)} {
|
||||||
r set s ""
|
r set s ""
|
||||||
r bitop not dest s
|
r bitop not dest s
|
||||||
|
Loading…
x
Reference in New Issue
Block a user