37} zend_shared_segment_posix;
39static int create_segments(
size_t requested_size, zend_shared_segment_posix ***shared_segments_p,
int *shared_segments_count,
const char **error_in)
41 zend_shared_segment_posix *shared_segment;
42 char shared_segment_name[
sizeof(
"/ZendAccelerator.") + 20];
43 int shared_segment_flags = O_RDWR|O_CREAT|O_TRUNC;
44 mode_t shared_segment_mode = 0600;
46#if defined(HAVE_SHM_CREATE_LARGEPAGE)
54 size_t i, shared_segment_sizes = 0, shared_segment_lg_index = 0;
55 size_t shared_segment_sindexes[3] = {0};
56 const size_t entries =
sizeof(shared_segment_sindexes) /
sizeof(shared_segment_sindexes[0]);
58 shared_segment_sizes = getpagesizes(shared_segment_sindexes, entries);
60 if (shared_segment_sizes > 0) {
61 for (i = shared_segment_sizes - 1; i >= 0; i --) {
62 if (shared_segment_sindexes[i] != 0 &&
63 !(requested_size % shared_segment_sindexes[i])) {
64 shared_segment_lg_index = i;
71 *shared_segments_count = 1;
72 *shared_segments_p = (zend_shared_segment_posix **) calloc(1,
sizeof(zend_shared_segment_posix) +
sizeof(
void *));
73 if (!*shared_segments_p) {
77 shared_segment = (zend_shared_segment_posix *)((
char *)(*shared_segments_p) +
sizeof(
void *));
78 (*shared_segments_p)[0] = shared_segment;
80 snprintf(shared_segment_name,
sizeof(shared_segment_name),
"/ZendAccelerator.%d", getpid());
81#if defined(HAVE_SHM_CREATE_LARGEPAGE)
82 if (shared_segment_lg_index > 0) {
83 shared_segment->shm_fd = shm_create_largepage(shared_segment_name, shared_segment_flags, shared_segment_lg_index, SHM_LARGEPAGE_ALLOC_DEFAULT, shared_segment_mode);
84 if (shared_segment->shm_fd != -1) {
85 goto truncate_segment;
90 shared_segment->shm_fd = shm_open(shared_segment_name, shared_segment_flags, shared_segment_mode);
91 if (shared_segment->shm_fd == -1) {
92 *error_in =
"shm_open";
96#if defined(HAVE_SHM_CREATE_LARGEPAGE)
99 if (
ftruncate(shared_segment->shm_fd, requested_size) != 0) {
100 *error_in =
"ftruncate";
101 shm_unlink(shared_segment_name);
105 shared_segment->common.p = mmap(0, requested_size,
PROT_READ |
PROT_WRITE, MAP_SHARED, shared_segment->shm_fd, 0);
108 shm_unlink(shared_segment_name);
111 shm_unlink(shared_segment_name);
113 shared_segment->common.pos = 0;
114 shared_segment->common.size = requested_size;
119static int detach_segment(zend_shared_segment_posix *shared_segment)
121 munmap(shared_segment->common.p, shared_segment->common.size);
122 close(shared_segment->shm_fd);
126static size_t segment_type_size(
void)
128 return sizeof(zend_shared_segment_posix);
ftruncate($stream, int $size)
struct _zend_shared_segment zend_shared_segment
int(* detach_segment_t)(zend_shared_segment *shared_segment)
int(* create_segments_t)(size_t requested_size, zend_shared_segment ***shared_segments, int *shared_segment_count, const char **error_in)