diff options
-rw-r--r-- | meta-oe/recipes-devtools/php/php/70_mod_php5.conf | 12 | ||||
-rw-r--r-- | meta-oe/recipes-devtools/php/php/configure.patch | 11 | ||||
-rw-r--r-- | meta-oe/recipes-devtools/php/php/pthread-check-threads-m4.patch | 30 | ||||
-rw-r--r-- | meta-oe/recipes-devtools/php/php_5.5.15.bb | 142 |
4 files changed, 163 insertions, 32 deletions
diff --git a/meta-oe/recipes-devtools/php/php/70_mod_php5.conf b/meta-oe/recipes-devtools/php/php/70_mod_php5.conf new file mode 100644 index 000000000..1de6fb11a --- /dev/null +++ b/meta-oe/recipes-devtools/php/php/70_mod_php5.conf | |||
@@ -0,0 +1,12 @@ | |||
1 | # vim: ft=apache sw=4 ts=4 | ||
2 | <IfDefine PHP5> | ||
3 | # Load the module first | ||
4 | <IfModule !sapi_apache2.c> | ||
5 | LoadModule php5_module lib/apache2/modules/libphp5.so | ||
6 | </IfModule> | ||
7 | |||
8 | # Set it to handle the files | ||
9 | AddHandler php5-script .php .phtml .php3 .php4 .php5 | ||
10 | AddType application/x-httpd-php-source .phps | ||
11 | DirectoryIndex index.html index.html.var index.php index.phtml | ||
12 | </IfDefine> | ||
diff --git a/meta-oe/recipes-devtools/php/php/configure.patch b/meta-oe/recipes-devtools/php/php/configure.patch new file mode 100644 index 000000000..c5334c706 --- /dev/null +++ b/meta-oe/recipes-devtools/php/php/configure.patch | |||
@@ -0,0 +1,11 @@ | |||
1 | --- php-5.1.6/configure.old 2006-09-12 07:54:14.000000000 -0700 | ||
2 | +++ php-5.1.6/configure 2006-09-12 07:54:37.000000000 -0700 | ||
3 | @@ -14715,8 +14715,6 @@ | ||
4 | |||
5 | |||
6 | |||
7 | - unset ac_cv_func_dlopen | ||
8 | - unset ac_cv_func___dlopen | ||
9 | unset found | ||
10 | |||
11 | echo $ac_n "checking for dlopen""... $ac_c" 1>&6 | ||
diff --git a/meta-oe/recipes-devtools/php/php/pthread-check-threads-m4.patch b/meta-oe/recipes-devtools/php/php/pthread-check-threads-m4.patch new file mode 100644 index 000000000..0c564cd88 --- /dev/null +++ b/meta-oe/recipes-devtools/php/php/pthread-check-threads-m4.patch | |||
@@ -0,0 +1,30 @@ | |||
1 | From d8067ceacbf54e79c9c6b68675332c09eaa0b55d Mon Sep 17 00:00:00 2001 | ||
2 | From: Jackie Huang <jackie.huang@windriver.com> | ||
3 | Date: Mon, 8 Apr 2013 14:29:51 +0800 | ||
4 | Subject: [PATCH] pthread-check | ||
5 | |||
6 | Enable pthreads support when cross-compiling | ||
7 | |||
8 | Upstream-Status: Inapproprate [config] | ||
9 | |||
10 | Signed-off-by: Jackie Huang <jackie.huang@windriver.com> | ||
11 | --- | ||
12 | TSRM/threads.m4 | 2 +- | ||
13 | 1 files changed, 1 insertions(+), 1 deletions(-) | ||
14 | |||
15 | diff --git a/TSRM/threads.m4 b/TSRM/threads.m4 | ||
16 | index 38494ce..15d9454 100644 | ||
17 | --- a/TSRM/threads.m4 | ||
18 | +++ b/TSRM/threads.m4 | ||
19 | @@ -86,7 +86,7 @@ int main() { | ||
20 | pthreads_working=no | ||
21 | ], [ | ||
22 | dnl For cross compiling running this test is of no use. NetWare supports pthreads | ||
23 | - pthreads_working=no | ||
24 | + pthreads_working=yes | ||
25 | case $host_alias in | ||
26 | *netware*) | ||
27 | pthreads_working=yes | ||
28 | -- | ||
29 | 1.7.4.1 | ||
30 | |||
diff --git a/meta-oe/recipes-devtools/php/php_5.5.15.bb b/meta-oe/recipes-devtools/php/php_5.5.15.bb index ff81aee82..1e53a326c 100644 --- a/meta-oe/recipes-devtools/php/php_5.5.15.bb +++ b/meta-oe/recipes-devtools/php/php_5.5.15.bb | |||
@@ -1,4 +1,4 @@ | |||
1 | DESCRIPTION = "A server-side, HTML-embedded scripting language. This package provides the CGI." | 1 | SUMMARY = "A server-side, HTML-embedded scripting language" |
2 | HOMEPAGE = "http://www.php.net" | 2 | HOMEPAGE = "http://www.php.net" |
3 | SECTION = "console/network" | 3 | SECTION = "console/network" |
4 | 4 | ||
@@ -6,13 +6,9 @@ LICENSE = "PHP-3.0" | |||
6 | LIC_FILES_CHKSUM = "file://LICENSE;md5=52dd90569008fee5bcdbb22d945b1108" | 6 | LIC_FILES_CHKSUM = "file://LICENSE;md5=52dd90569008fee5bcdbb22d945b1108" |
7 | 7 | ||
8 | BBCLASSEXTEND = "native" | 8 | BBCLASSEXTEND = "native" |
9 | DEPENDS = "zlib libxml2 virtual/libiconv php-native lemon-native \ | 9 | DEPENDS = "zlib bzip2 libxml2 virtual/libiconv php-native lemon-native \ |
10 | libc-client openssl libmcrypt" | 10 | uw-imap openssl libmcrypt" |
11 | DEPENDS_virtclass-native = "zlib-native libxml2-native" | 11 | DEPENDS_class-native = "zlib-native libxml2-native" |
12 | |||
13 | # The new PHP downloads server groups PHP releases by major version so find | ||
14 | # the major version of the PHP recipe. | ||
15 | PHP_MAJVER = "${@d.getVar('PV',1).split('.')[0]}" | ||
16 | 12 | ||
17 | SRC_URI = "http://php.net/distributions/php-${PV}.tar.bz2 \ | 13 | SRC_URI = "http://php.net/distributions/php-${PV}.tar.bz2 \ |
18 | file://acinclude-xml2-config.patch \ | 14 | file://acinclude-xml2-config.patch \ |
@@ -28,6 +24,9 @@ SRC_URI_append_class-target += " \ | |||
28 | file://php_exec_native.patch \ | 24 | file://php_exec_native.patch \ |
29 | file://php-fpm.conf \ | 25 | file://php-fpm.conf \ |
30 | file://php-fpm-apache.conf \ | 26 | file://php-fpm-apache.conf \ |
27 | file://configure.patch \ | ||
28 | file://pthread-check-threads-m4.patch \ | ||
29 | file://70_mod_php5.conf \ | ||
31 | " | 30 | " |
32 | 31 | ||
33 | SRC_URI[md5sum] = "5cb5f2ed9099299f8a4c952d59d93812" | 32 | SRC_URI[md5sum] = "5cb5f2ed9099299f8a4c952d59d93812" |
@@ -37,22 +36,38 @@ S = "${WORKDIR}/php-${PV}" | |||
37 | 36 | ||
38 | inherit autotools pkgconfig pythonnative gettext | 37 | inherit autotools pkgconfig pythonnative gettext |
39 | 38 | ||
39 | # phpize is not scanned for absolute paths by default (but php-config is). | ||
40 | # | ||
41 | SSTATE_SCAN_FILES += "phpize" | ||
40 | SSTATE_SCAN_FILES += "build-defs.h" | 42 | SSTATE_SCAN_FILES += "build-defs.h" |
41 | 43 | ||
44 | PHP_LIBDIR = "${libdir}/php5" | ||
45 | |||
42 | # Common EXTRA_OECONF | 46 | # Common EXTRA_OECONF |
43 | COMMON_EXTRA_OECONF = "--enable-sockets --enable-pcntl --enable-shared --disable-opcache" | 47 | COMMON_EXTRA_OECONF = "--enable-sockets \ |
48 | --enable-pcntl \ | ||
49 | --enable-shared \ | ||
50 | --disable-opcache \ | ||
51 | --disable-rpath \ | ||
52 | --with-pic \ | ||
53 | --libdir=${PHP_LIBDIR} \ | ||
54 | " | ||
44 | EXTRA_OECONF = "--enable-mbstring \ | 55 | EXTRA_OECONF = "--enable-mbstring \ |
45 | --enable-wddx \ | 56 | --enable-wddx \ |
46 | --enable-fpm \ | 57 | --enable-fpm \ |
58 | --enable-zip \ | ||
47 | --with-imap=${STAGING_DIR_HOST} \ | 59 | --with-imap=${STAGING_DIR_HOST} \ |
48 | --with-gettext=${STAGING_LIBDIR}/.. \ | 60 | --with-gettext=${STAGING_LIBDIR}/.. \ |
49 | --with-imap-ssl=${STAGING_DIR_HOST} \ | 61 | --with-imap-ssl=${STAGING_DIR_HOST} \ |
50 | --with-zlib=${STAGING_LIBDIR}/.. \ | 62 | --with-zlib=${STAGING_LIBDIR}/.. \ |
51 | --with-iconv=${STAGING_LIBDIR}/.. \ | 63 | --with-iconv=${STAGING_LIBDIR}/.. \ |
52 | --with-mcrypt=${STAGING_DIR_TARGET}${exec_prefix} \ | 64 | --with-mcrypt=${STAGING_DIR_TARGET}${exec_prefix} \ |
65 | --with-bz2=${STAGING_DIR_TARGET}${exec_prefix} \ | ||
66 | --with-config-file-path=${sysconfdir}/php/apache2-php5 \ | ||
67 | ${@base_conditional('SITEINFO_ENDIANNESS', 'le', 'ac_cv_c_bigendian_php=no', 'ac_cv_c_bigendian_php=yes', d)} \ | ||
53 | ${COMMON_EXTRA_OECONF} \ | 68 | ${COMMON_EXTRA_OECONF} \ |
54 | " | 69 | " |
55 | EXTRA_OECONF_virtclass-native = " \ | 70 | EXTRA_OECONF_class-native = " \ |
56 | --with-zlib=${STAGING_LIBDIR_NATIVE}/.. \ | 71 | --with-zlib=${STAGING_LIBDIR_NATIVE}/.. \ |
57 | --without-iconv \ | 72 | --without-iconv \ |
58 | ${COMMON_EXTRA_OECONF} \ | 73 | ${COMMON_EXTRA_OECONF} \ |
@@ -64,26 +79,54 @@ PACKAGECONFIG_class-native = "" | |||
64 | PACKAGECONFIG[mysql] = "--with-mysql=${STAGING_DIR_TARGET}${prefix} \ | 79 | PACKAGECONFIG[mysql] = "--with-mysql=${STAGING_DIR_TARGET}${prefix} \ |
65 | --with-mysqli=${STAGING_BINDIR_CROSS}/mysql_config \ | 80 | --with-mysqli=${STAGING_BINDIR_CROSS}/mysql_config \ |
66 | --with-pdo-mysql=${STAGING_BINDIR_CROSS}/mysql_config \ | 81 | --with-pdo-mysql=${STAGING_BINDIR_CROSS}/mysql_config \ |
67 | , \ | 82 | ,--without-mysql --without-mysqli --without-pdo-mysql \ |
68 | ,mysql5" | 83 | ,mysql5" |
69 | 84 | ||
70 | PACKAGECONFIG[sqlite3] = "--with-sqlite3=${STAGING_LIBDIR}/.. \ | 85 | PACKAGECONFIG[sqlite3] = "--with-sqlite3=${STAGING_LIBDIR}/.. \ |
71 | --with-pdo-sqlite=${STAGING_LIBDIR}/.. \ | 86 | --with-pdo-sqlite=${STAGING_LIBDIR}/.. \ |
72 | , \ | 87 | , \ |
73 | ,sqlite3" | 88 | ,sqlite3" |
89 | PACKAGECONFIG[pgsql] = "--with-pgsql=${STAGING_DIR_TARGET}${exec_prefix},--without-pgsql,postgresql" | ||
90 | PACKAGECONFIG[soap] = "--enable-libxml --enable-soap, --disable-soap, libxml2" | ||
91 | PACKAGECONFIG[apache2] = "--with-apxs2=${STAGING_BINDIR_CROSS}/apxs,,apache2-native apache2" | ||
92 | |||
74 | 93 | ||
75 | export PHP_NATIVE_DIR = "${STAGING_BINDIR_NATIVE}" | 94 | export PHP_NATIVE_DIR = "${STAGING_BINDIR_NATIVE}" |
76 | export PHP_PEAR_PHP_BIN = "${STAGING_BINDIR_NATIVE}/php" | 95 | export PHP_PEAR_PHP_BIN = "${STAGING_BINDIR_NATIVE}/php" |
77 | CFLAGS += " -D_GNU_SOURCE" | 96 | CFLAGS += " -D_GNU_SOURCE -g -DPTYS_ARE_GETPT -DPTYS_ARE_SEARCHED -I${STAGING_INCDIR}/apache2" |
78 | 97 | ||
79 | EXTRA_OEMAKE = "INSTALL_ROOT=${D}" | 98 | EXTRA_OEMAKE = "INSTALL_ROOT=${D}" |
80 | 99 | ||
81 | acpaths = "" | 100 | acpaths = "" |
82 | 101 | ||
102 | do_configure_prepend () { | ||
103 | rm -f ${S}/build/libtool.m4 ${S}/ltmain.sh ${S}/aclocal.m4 | ||
104 | find ${S} -name config.m4 | xargs -n1 sed -i 's!APXS_HTTPD=.*!APXS_HTTPD=${STAGING_BINDIR_NATIVE}/httpd!' | ||
105 | } | ||
106 | |||
107 | do_configure_append() { | ||
108 | # No, libtool, we really don't want rpath set... | ||
109 | sed -i 's|^hardcode_libdir_flag_spec=.*|hardcode_libdir_flag_spec=""|g' ${HOST_SYS}-libtool | ||
110 | sed -i 's|^runpath_var=LD_RUN_PATH|runpath_var=DIE_RPATH_DIE|g' ${HOST_SYS}-libtool | ||
111 | } | ||
112 | |||
83 | do_install_append_class-native() { | 113 | do_install_append_class-native() { |
84 | rm -rf ${D}/${libdir}/php/.registry | 114 | rm -rf ${D}/${PHP_LIBDIR}/php/.registry |
85 | rm -rf ${D}/${libdir}/php/.channels | 115 | rm -rf ${D}/${PHP_LIBDIR}/php/.channels |
86 | rm -rf ${D}/${libdir}/php/.[a-z]* | 116 | rm -rf ${D}/${PHP_LIBDIR}/php/.[a-z]* |
117 | } | ||
118 | |||
119 | do_install_prepend() { | ||
120 | cat aclocal-copy/libtool.m4 aclocal-copy/lt~obsolete.m4 aclocal-copy/ltoptions.m4 \ | ||
121 | aclocal-copy/ltsugar.m4 aclocal-copy/ltversion.m4 > ${S}/build/libtool.m4 | ||
122 | } | ||
123 | |||
124 | do_install_prepend_class-target() { | ||
125 | if ${@bb.utils.contains('PACKAGECONFIG', 'apache2', 'true', 'false', d)}; then | ||
126 | # Install dummy config file so apxs doesn't fail | ||
127 | install -d ${D}${sysconfdir}/apache2 | ||
128 | printf "\nLoadModule dummy_module modules/mod_dummy.so\n" > ${D}${sysconfdir}/apache2/httpd.conf | ||
129 | fi | ||
87 | } | 130 | } |
88 | 131 | ||
89 | # fixme | 132 | # fixme |
@@ -112,19 +155,47 @@ do_install_append_class-target() { | |||
112 | rmdir ${TMP} | 155 | rmdir ${TMP} |
113 | TMP=`dirname ${TMP}`; | 156 | TMP=`dirname ${TMP}`; |
114 | done | 157 | done |
158 | |||
159 | if ${@bb.utils.contains('PACKAGECONFIG', 'apache2', 'true', 'false', d)}; then | ||
160 | install -d ${D}${libdir}/apache2/modules | ||
161 | install -d ${D}${sysconfdir}/apache2/modules.d | ||
162 | install -d ${D}${sysconfdir}/php/apache2-php5 | ||
163 | install -m 755 libs/libphp5.so ${D}${libdir}/apache2/modules | ||
164 | install -m 644 ${WORKDIR}/70_mod_php5.conf ${D}${sysconfdir}/apache2/modules.d | ||
165 | sed -i s,lib/,${libdir}/, ${D}${sysconfdir}/apache2/modules.d/70_mod_php5.conf | ||
166 | cat ${S}/php.ini-production | \ | ||
167 | sed -e 's,extension_dir = \"\./\",extension_dir = \"/usr/lib/extensions\",' \ | ||
168 | > ${D}${sysconfdir}/php/apache2-php5/php.ini | ||
169 | rm -f ${D}${sysconfdir}/apache2/httpd.conf* | ||
170 | fi | ||
115 | } | 171 | } |
116 | 172 | ||
117 | PACKAGES = "${PN}-dbg ${PN}-cli ${PN}-cgi ${PN}-fpm ${PN}-fpm-apache2 ${PN}-pear ${PN}-dev ${PN}-staticdev ${PN}-doc ${PN}" | 173 | SYSROOT_PREPROCESS_FUNCS += "php_sysroot_preprocess" |
174 | |||
175 | php_sysroot_preprocess () { | ||
176 | install -d ${SYSROOT_DESTDIR}${bindir_crossscripts}/ | ||
177 | install -m 755 ${D}${bindir}/phpize ${SYSROOT_DESTDIR}${bindir_crossscripts}/ | ||
178 | install -m 755 ${D}${bindir}/php-config ${SYSROOT_DESTDIR}${bindir_crossscripts}/ | ||
179 | |||
180 | sed -i 's!eval echo /!eval echo ${STAGING_DIR_HOST}/!' ${SYSROOT_DESTDIR}${bindir_crossscripts}/phpize | ||
181 | sed -i 's!^include_dir=.*!include_dir=${STAGING_INCDIR}/php!' ${SYSROOT_DESTDIR}${bindir_crossscripts}/php-config | ||
182 | } | ||
183 | |||
184 | MODPHP_PACKAGE = "${@bb.utils.contains('PACKAGECONFIG', 'apache2', '${PN}-modphp', '', d)}" | ||
185 | |||
186 | PACKAGES = "${PN}-dbg ${PN}-cli ${PN}-cgi ${PN}-fpm ${PN}-fpm-apache2 ${PN}-pear ${MODPHP_PACKAGE} ${PN}-dev ${PN}-staticdev ${PN}-doc ${PN}" | ||
118 | 187 | ||
119 | RDEPENDS_${PN}-pear = "${PN}" | 188 | RDEPENDS_${PN}-pear = "${PN}" |
120 | RDEPENDS_${PN}-cli = "${PN}" | 189 | RDEPENDS_${PN}-cli = "${PN}" |
190 | RDEPENDS_${PN}-modphp = "${PN} apache2" | ||
121 | RDEPENDS_${PN}-dev = "${PN}" | 191 | RDEPENDS_${PN}-dev = "${PN}" |
122 | 192 | ||
123 | INITSCRIPT_PACKAGES = "${PN}-fpm" | 193 | INITSCRIPT_PACKAGES = "${PN}-fpm" |
124 | inherit update-rc.d | 194 | inherit update-rc.d |
125 | 195 | ||
126 | FILES_${PN}-dbg =+ "${bindir}/.debug" | 196 | FILES_${PN}-dbg =+ "${bindir}/.debug \ |
127 | FILES_${PN}-doc += "${libdir}/php/doc" | 197 | ${libdir}/apache2/modules/.debug" |
198 | FILES_${PN}-doc += "${PHP_LIBDIR}/php/doc" | ||
128 | FILES_${PN}-cli = "${bindir}/php" | 199 | FILES_${PN}-cli = "${bindir}/php" |
129 | FILES_${PN}-cgi = "${bindir}/php-cgi" | 200 | FILES_${PN}-cgi = "${bindir}/php-cgi" |
130 | FILES_${PN}-fpm = "${sbindir}/php-fpm ${sysconfdir}/php-fpm.conf ${datadir}/fpm ${sysconfdir}/init.d/php-fpm" | 201 | FILES_${PN}-fpm = "${sbindir}/php-fpm ${sysconfdir}/php-fpm.conf ${datadir}/fpm ${sysconfdir}/init.d/php-fpm" |
@@ -133,19 +204,26 @@ CONFFILES_${PN}-fpm = "${sysconfdir}/php-fpm.conf" | |||
133 | CONFFILES_${PN}-fpm-apache2 = "${sysconfdir}/apache2/conf.d/php-fpm.conf" | 204 | CONFFILES_${PN}-fpm-apache2 = "${sysconfdir}/apache2/conf.d/php-fpm.conf" |
134 | INITSCRIPT_NAME_${PN}-fpm = "php-fpm" | 205 | INITSCRIPT_NAME_${PN}-fpm = "php-fpm" |
135 | INITSCRIPT_PARAMS_${PN}-fpm = "defaults 60" | 206 | INITSCRIPT_PARAMS_${PN}-fpm = "defaults 60" |
136 | FILES_${PN}-pear = "${bindir}/pear* ${bindir}/pecl ${libdir}/php/PEAR \ | 207 | FILES_${PN}-pear = "${bindir}/pear* ${bindir}/pecl ${PHP_LIBDIR}/php/PEAR \ |
137 | ${libdir}/php/PEAR.php ${libdir}/php/System.php \ | 208 | ${PHP_LIBDIR}/php/PEAR*.php ${PHP_LIBDIR}/php/System.php \ |
138 | ${libdir}php/peclcmd.php ${libdir}/php/pearcmd.php \ | 209 | ${PHP_LIBDIR}/php/peclcmd.php ${PHP_LIBDIR}/php/pearcmd.php \ |
139 | ${libdir}/php/.channels ${libdir}/php/.channels/.alias \ | 210 | ${PHP_LIBDIR}/php/.channels ${PHP_LIBDIR}/php/.channels/.alias \ |
140 | ${libdir}/php/.channels\__uri.reg \ | 211 | ${PHP_LIBDIR}/php/.registry ${PHP_LIBDIR}/php/Archive/Tar.php \ |
141 | ${libdir}/php/.channels\pear.php.net.reg \ | 212 | ${PHP_LIBDIR}/php/Console/Getopt.php ${PHP_LIBDIR}/php/OS/Guess.php \ |
142 | ${libdir}/php/.channels/pecl.php.net.reg \ | 213 | ${PHP_LIBDIR}/php/data/PEAR \ |
143 | ${libdir}/php/.registry ${libdir}/php/Archive/Tar.php \ | ||
144 | ${libdir}/php/Console/Getopt.php ${libdir}/php/OS/Guess.php \ | ||
145 | ${sysconfdir}/pear.conf" | 214 | ${sysconfdir}/pear.conf" |
146 | FILES_${PN}-dev = "${includedir}/php ${libdir}/build ${bindir}/phpize \ | 215 | FILES_${PN}-dev = "${includedir}/php ${PHP_LIBDIR}/build ${bindir}/phpize \ |
147 | ${bindir}/php-config ${libdir}/php/.depdb \ | 216 | ${bindir}/php-config ${PHP_LIBDIR}/php/.depdb \ |
148 | ${libdir}/php/.depdblock ${libdir}/php/.filemap \ | 217 | ${PHP_LIBDIR}/php/.depdblock ${PHP_LIBDIR}/php/.filemap \ |
149 | ${libdir}/php/.lock ${libdir}/php/test" | 218 | ${PHP_LIBDIR}/php/.lock ${PHP_LIBDIR}/php/test" |
150 | FILES_${PN} = "${libdir}/php" | 219 | FILES_${PN} = "${PHP_LIBDIR}/php" |
151 | FILES_${PN} += "${bindir}" | 220 | FILES_${PN} += "${bindir}" |
221 | |||
222 | SUMMARY_${PN}-modphp = "PHP module for the Apache HTTP server" | ||
223 | FILES_${PN}-modphp = "${libdir}/apache2 ${sysconfdir}" | ||
224 | |||
225 | MODPHP_OLDPACKAGE = "${@bb.utils.contains('PACKAGECONFIG', 'apache2', 'modphp', '', d)}" | ||
226 | RPROVIDES_${PN}-modphp = "${MODPHP_OLDPACKAGE}" | ||
227 | RREPLACES_${PN}-modphp = "${MODPHP_OLDPACKAGE}" | ||
228 | RCONFLICTS_${PN}-modphp = "${MODPHP_OLDPACKAGE}" | ||
229 | |||