ID: 50140
Updated by: [email protected]
Reported By: basant dot kukreja at gmail dot com
Status: Feedback
Bug Type: iPlanet related
Operating System: Linux
PHP Version: 5.3SVN-2009-11-10 (SVN)
New Comment:
Thanks Jani for your suggestion. Based on your suggestion, I have
revised the patch. Here is the new patch :
---------------------------------------------
Index: sapi/nsapi/nsapi.c
===================================================================
--- sapi/nsapi/nsapi.c (revision 290447)
+++ sapi/nsapi/nsapi.c (working copy)
@@ -67,6 +67,11 @@
* NSAPI includes
*/
#include "nsapi.h"
+/* fix for gcc4 visibility issue */
+#ifndef PHP_WIN32
+# undef NSAPI_PUBLIC
+# define NSAPI_PUBLIC PHPAPI
+#endif
#define NSLS_D struct nsapi_request_context *request_context
#define NSLS_DC , NSLS_D
-------------------------------------------
With this patch, when I preprocess the file, on linux I get following
for php5_init :
int __attribute__ ((visibility("default"))) php5_init(pblock *pb,
Session *sn, Request *rq)
-------------------------------------------
The above correctly export the symbols.
Previous Comments:
------------------------------------------------------------------------
[2009-11-11 12:35:11] [email protected]
Check how this is fixed for Apache: sapi/apache2handler/php_apache.h
and search for "visibility". I think you should do that instead of using
any #pragma's.
------------------------------------------------------------------------
[2009-11-10 19:20:57] [email protected]
>From nsapi.h :
#ifdef XP_UNIX
#define NSAPI_PUBLIC
...
It seems NSAPI_PUBLIC is expanded to empty string.
--------------------------------------------
When I expanded after preprocessing nsapi.c, here is what I got :
# 915 ".../php-src-5.3/sapi/nsapi/nsapi.c"
int php5_init(pblock *pb, Session *sn, Request *rq)
--------------------------------------
So we need to tell gcc to export the NSAPI_PUBLIC symbols.
------------------------------------------------------------------------
[2009-11-10 19:14:51] [email protected]
The previous patch didn't resolve the problem, here is what helped
resolved the issue. NSAPI_PUBLIC should have made the symbols public
but it seems it doesn't.
Index: sapi/nsapi/nsapi.c
===================================================================
--- sapi/nsapi/nsapi.c (revision 290447)
+++ sapi/nsapi/nsapi.c (working copy)
@@ -67,6 +67,7 @@
* NSAPI includes
*/
#include "nsapi.h"
+#pragma GCC visibility push(default)
#define NSLS_D struct nsapi_request_context *request_context
#define NSLS_DC , NSLS_D
------------------------------------------------------------------------
[2009-11-10 18:59:16] [email protected]
Here is the snipp from gcc man page :
<man gcc>
"
-fvisibility=default|internal|hidden|protected
...
For those adding visibility support to existing code, you may
find #pragma GCC visibility of
use. This works by you enclosing the declarations you wish
to set visibility for with (for
example) #pragma GCC visibility push(hidden) and #pragma GCC
visibility pop.
...
"
Pusing default visibility before including nsapi.h (and popping after)
would
help in compiling and loading php correctly with nsapi servers.
Here is the patch against recent php 5.3 svn
--------------------------------------------
Index: sapi/nsapi/nsapi.c
===================================================================
--- sapi/nsapi/nsapi.c (revision 290447)
+++ sapi/nsapi/nsapi.c (working copy)
@@ -66,7 +66,9 @@
/*
* NSAPI includes
*/
+#pragma GCC visibility push(default)
#include "nsapi.h"
+#pragma GCC visibility pop
#define NSLS_D struct nsapi_request_context *request_context
#define NSLS_DC , NSLS_D
--------------------------------------------
------------------------------------------------------------------------
[2009-11-10 18:48:30] [email protected]
Here is how symbols looks like :
$ nm .libs/libphp5.so | grep php5
004dcfb7 t php5_auth_trans
004dc661 t php5_close
004dc802 t php5_execute
004dc6d4 t php5_init
Symbols are not exported by default.
If we remove
-fvisibility=hidden from compilation options then php compiles
fine and server is able to load libphp5.so correctly.
------------------------------------------------------------------------
The remainder of the comments for this report are too long. To view
the rest of the comments, please view the bug report online at
http://bugs.php.net/50140
--
Edit this bug report at http://bugs.php.net/?id=50140&edit=1