Skip to content

Commit f2954bf

Browse files
committed
Merge branch 'PHP-8.4'
* PHP-8.4: Fix NULL arithmetic in System V shared memory emulation
2 parents fa1af48 + 5c066e0 commit f2954bf

File tree

1 file changed

+13
-11
lines changed

1 file changed

+13
-11
lines changed

TSRM/tsrm_win32.c

Lines changed: 13 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -402,19 +402,21 @@ static shm_pair *shm_get(key_t key, void *addr)
402402
shm_pair *ptr;
403403
shm_pair *newptr;
404404

405-
for (ptr = TWG(shm); ptr < (TWG(shm) + TWG(shm_size)); ptr++) {
406-
if (!ptr->descriptor) {
407-
continue;
408-
}
409-
if (!addr && ptr->descriptor->shm_perm.key == key) {
410-
break;
411-
} else if (ptr->addr == addr) {
412-
break;
405+
if (TWG(shm) != NULL) {
406+
for (ptr = TWG(shm); ptr < (TWG(shm) + TWG(shm_size)); ptr++) {
407+
if (!ptr->descriptor) {
408+
continue;
409+
}
410+
if (!addr && ptr->descriptor->shm_perm.key == key) {
411+
break;
412+
} else if (ptr->addr == addr) {
413+
break;
414+
}
413415
}
414-
}
415416

416-
if (ptr < (TWG(shm) + TWG(shm_size))) {
417-
return ptr;
417+
if (ptr < (TWG(shm) + TWG(shm_size))) {
418+
return ptr;
419+
}
418420
}
419421

420422
newptr = (shm_pair*)realloc((void*)TWG(shm), (TWG(shm_size)+1)*sizeof(shm_pair));

0 commit comments

Comments
 (0)