summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorPeter Eisentraut <peter@eisentraut.org>2025-11-07 10:11:44 +0100
committerPeter Eisentraut <peter@eisentraut.org>2025-11-07 10:14:25 +0100
commita3ea5330fcf47390c8ab420bbf433a97a54505d6 (patch)
treef84bc12498c000757e9b842cba9d7c34d55aca1f /src
parentf6a4c498dcf6f05b4ef79051e95de12cc48bdeee (diff)
Fix "inconsistent DLL linkage" warning on Windows MSVC
This warning was disabled in meson.build (warning 4273). If you enable it, it looks like this: ../src/backend/utils/misc/ps_status.c(27): warning C4273: '__p__environ': inconsistent dll linkage C:\Program Files (x86)\Windows Kits\10\include\10.0.22621.0\ucrt\stdlib.h(1158): note: see previous definition of '__p__environ' The declaration in ps_status.c was: #if !defined(WIN32) || defined(_MSC_VER) extern char **environ; #endif The declaration in the OS header file is: _DCRTIMP char*** __cdecl __p__environ (void); #define _environ (*__p__environ()) So it is evident that this could be problematic. The old declaration was required by the old MSVCRT library, but we don't support that anymore with MSVC. To fix, disable the re-declaration in ps_status.c, and also in some other places that use the same code pattern but didn't trigger the warning. Then we can also re-enable the warning (delete the disablement in meson.build). Reviewed-by: Bryan Green <dbryan.green@gmail.com> Reviewed-by: Andres Freund <andres@anarazel.de> Discussion: https://www.postgresql.org/message-id/flat/bf060644-47ff-441b-97cf-c685d0827757@eisentraut.org
Diffstat (limited to 'src')
-rw-r--r--src/backend/postmaster/postmaster.c2
-rw-r--r--src/backend/utils/misc/ps_status.c2
-rw-r--r--src/test/regress/regress.c2
3 files changed, 3 insertions, 3 deletions
diff --git a/src/backend/postmaster/postmaster.c b/src/backend/postmaster/postmaster.c
index 00de559ba8f..7c064cf9fbb 100644
--- a/src/backend/postmaster/postmaster.c
+++ b/src/backend/postmaster/postmaster.c
@@ -880,7 +880,7 @@ PostmasterMain(int argc, char *argv[])
/* For debugging: display postmaster environment */
if (message_level_is_interesting(DEBUG3))
{
-#if !defined(WIN32) || defined(_MSC_VER)
+#if !defined(WIN32)
extern char **environ;
#endif
char **p;
diff --git a/src/backend/utils/misc/ps_status.c b/src/backend/utils/misc/ps_status.c
index 4df25944deb..8709c4f5125 100644
--- a/src/backend/utils/misc/ps_status.c
+++ b/src/backend/utils/misc/ps_status.c
@@ -23,7 +23,7 @@
#include "utils/guc.h"
#include "utils/ps_status.h"
-#if !defined(WIN32) || defined(_MSC_VER)
+#if !defined(WIN32)
extern char **environ;
#endif
diff --git a/src/test/regress/regress.c b/src/test/regress/regress.c
index 465ac148ac9..a2db6080876 100644
--- a/src/test/regress/regress.c
+++ b/src/test/regress/regress.c
@@ -432,7 +432,7 @@ PG_FUNCTION_INFO_V1(get_environ);
Datum
get_environ(PG_FUNCTION_ARGS)
{
-#if !defined(WIN32) || defined(_MSC_VER)
+#if !defined(WIN32)
extern char **environ;
#endif
int nvals = 0;