File: page_size_fixes.patch

package info (click to toggle)
php5 5.3.3-7%2Bsqueeze19
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 122,836 kB
  • ctags: 55,742
  • sloc: ansic: 633,963; php: 19,620; sh: 11,344; xml: 5,816; cpp: 2,400; yacc: 1,745; exp: 1,514; makefile: 1,019; pascal: 623; awk: 537; sql: 22
file content (104 lines) | stat: -rw-r--r-- 2,996 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
Description: Don't assume value of PAGE_SIZE if sys/mman.h does not
 define it. Instead, use sysconf() at runtime if available.
Origin: vendor
Bug: http://bugs.php.net/bug.php?id=50982
Last-Update: 2010-02-17

--- a/Zend/zend_stream.c
+++ b/Zend/zend_stream.c
@@ -27,10 +27,15 @@
 
 #include <sys/types.h>
 #include <sys/stat.h>
-#if HAVE_SYS_MMAN_H
-# include <sys/mman.h>
-# ifndef PAGE_SIZE
-#  define PAGE_SIZE 4096
+#if HAVE_UNISTD_H
+# include <unistd.h>
+#endif
+#if !HAVE_UNISTD_H || (!defined(_SC_PAGESIZE) && !defined(_SC_PAGE_SIZE))
+# if HAVE_SYS_MMAN_H
+#  include <sys/mman.h>
+#  ifndef PAGE_SIZE
+#   define PAGE_SIZE 4096
+#  endif
 # endif
 #endif
 
@@ -215,9 +220,21 @@ ZEND_API int zend_stream_fixup(zend_file
 
 	if (old_type == ZEND_HANDLE_FP && !file_handle->handle.stream.isatty && size) {
 #if HAVE_MMAP
+		long page_size = 0;
+
+# if HAVE_UNISTD_H
+#  ifdef _SC_PAGESIZE
+		page_size = sysconf(_SC_PAGESIZE);
+#  else
+		page_size = sysconf(_SC_PAGE_SIZE);
+#  endif
+# else
+		page_size = PAGE_SIZE;
+# endif
+
 		if (file_handle->handle.fp &&
 		    size != 0 &&
-		    ((size - 1) % PAGE_SIZE) <= PAGE_SIZE - ZEND_MMAP_AHEAD) {
+		    ((size - 1) % page_size) <= page_size - ZEND_MMAP_AHEAD) {
 			/*  *buf[size] is zeroed automatically by the kernel */
 			*buf = mmap(0, size + ZEND_MMAP_AHEAD, PROT_READ, MAP_PRIVATE, fileno(file_handle->handle.fp), 0);
 			if (*buf != MAP_FAILED) {
--- a/main/main.c
+++ b/main/main.c
@@ -91,15 +91,17 @@
 #include "SAPI.h"
 #include "rfc1867.h"
 
-#if HAVE_SYS_MMAN_H
-# include <sys/mman.h>
-# ifndef PAGE_SIZE
+#if !HAVE_UNISTD_H || (!defined(_SC_PAGESIZE) && !defined(_SC_PAGE_SIZE))
+# if HAVE_SYS_MMAN_H
+#  include <sys/mman.h>
+#  ifndef PAGE_SIZE
+#   define PAGE_SIZE 4096
+#  endif
+# endif
+# ifdef PHP_WIN32
 #  define PAGE_SIZE 4096
 # endif
 #endif
-#ifdef PHP_WIN32
-# define PAGE_SIZE 4096
-#endif
 /* }}} */
 
 PHPAPI int (*php_register_internal_extensions_func)(TSRMLS_D) = php_register_internal_extensions;
@@ -1192,6 +1194,17 @@ PHPAPI int php_stream_open_for_zend_ex(c
 	char *p;
 	size_t len, mapped_len;
 	php_stream *stream = php_stream_open_wrapper((char *)filename, "rb", mode, &handle->opened_path);
+	long page_size = 0;
+
+#if HAVE_UNISTD_H
+# ifdef _SC_PAGESIZE
+	page_size = sysconf(_SC_PAGESIZE);
+# else
+	page_size = sysconf(_SC_PAGE_SIZE);
+# endif
+#else
+	page_size = PAGE_SIZE;
+#endif
 
 	if (stream) {
 		handle->filename = (char*)filename;
@@ -1204,7 +1217,7 @@ PHPAPI int php_stream_open_for_zend_ex(c
 		memset(&handle->handle.stream.mmap, 0, sizeof(handle->handle.stream.mmap));
 		len = php_zend_stream_fsizer(stream TSRMLS_CC);
 		if (len != 0
-		&& ((len - 1) % PAGE_SIZE) <= PAGE_SIZE - ZEND_MMAP_AHEAD
+		&& ((len - 1) % page_size) <= page_size - ZEND_MMAP_AHEAD
 		&& php_stream_mmap_possible(stream)
 		&& (p = php_stream_mmap_range(stream, 0, len, PHP_STREAM_MAP_MODE_SHARED_READONLY, &mapped_len)) != NULL) {
 			handle->handle.stream.closer   = php_zend_stream_mmap_closer;