summaryrefslogtreecommitdiff
path: root/vms
diff options
context:
space:
mode:
authorCraig A. Berry <craigberry@mac.com>2012-06-08 18:33:33 -0500
committerCraig A. Berry <craigberry@mac.com>2012-06-08 18:48:05 -0500
commite2367aa89c2dff8e12ae9e50931f1e00e8a57124 (patch)
tree7b49f6df4aa8009eb73860b1205ba534f62cfc17 /vms
parent7d8fd4f5df7c6f24e5ce56603c0be2f07599ead0 (diff)
downloadperl-e2367aa89c2dff8e12ae9e50931f1e00e8a57124.tar.gz
Upgrade initialization code in vms/vms.c.
The LIB$INITIALIZE program section is examined by the image activator for an array of 32-bit pointers to functions that will get called early in start-up, before main() is called. We use this mechanism to get and set various run-time features. The implementation we had was a bit cluttered with undocumented features that weren't being used, and it didn't work under C++. This new implementation is simpler and follows the documented usage in the C++ release notes much more closely, and it works under both C and C++. We also now explicitly export the LIB$INITIALIZE psect in the linker options file used to create the PERLSHR shareable image.
Diffstat (limited to 'vms')
-rw-r--r--vms/gen_shrfls.pl1
-rw-r--r--vms/vms.c86
2 files changed, 39 insertions, 48 deletions
diff --git a/vms/gen_shrfls.pl b/vms/gen_shrfls.pl
index 0cac88bd26..f44779e00e 100644
--- a/vms/gen_shrfls.pl
+++ b/vms/gen_shrfls.pl
@@ -170,6 +170,7 @@ unless ($isgcc) {
print OPTBLD "PSECT_ATTR=\$GLOBAL_RO_VARS,PIC,NOEXE,RD,NOWRT,SHR\n";
print OPTBLD "PSECT_ATTR=\$GLOBAL_RW_VARS,PIC,NOEXE,RD,WRT,NOSHR\n";
}
+ print OPTBLD "PSECT_ATTR=LIB\$INITIALIZE,GBL,NOEXE,NOWRT,NOSHR,LONG\n";
}
print OPTBLD "case_sensitive=yes\n" if $care_about_case;
my $count = 0;
diff --git a/vms/vms.c b/vms/vms.c
index a6b4395682..a235a10b95 100644
--- a/vms/vms.c
+++ b/vms/vms.c
@@ -13836,10 +13836,14 @@ int Perl_vms_case_tolerant(void)
/* C RTL Feature settings */
-static int set_features
- (int (* init_coroutine)(int *, int *, void *), /* Needs casts if used */
- int (* cli_routine)(void), /* Not documented */
- void *image_info) /* Not documented */
+#if defined(__DECC) || defined(__DECCXX)
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+extern void
+vmsperl_set_features(void)
{
int status;
int s;
@@ -14106,52 +14110,38 @@ static int set_features
else
vms_posix_exit = 0;
}
-
-
- /* CRTL can be initialized past this point, but not before. */
-/* DECC$CRTL_INIT(); */
-
- return SS$_NORMAL;
-}
-
-#if defined(__DECC) || defined(__DECCXX)
-#pragma nostandard
-#pragma extern_model save
-#pragma extern_model strict_refdef "LIB$INITIALIZ" nowrt
- const __align (LONGWORD) int spare[8] = {0};
-
-/* .psect LIB$INITIALIZE, NOPIC, USR, CON, REL, GBL, NOSHR, NOEXE, RD, NOWRT, LONG */
-#if __DECC_VER >= 60560002
-#pragma extern_model strict_refdef "LIB$INITIALIZE" nopic, con, rel, gbl, noshr, noexe, nowrt, long
-#else
-#pragma extern_model strict_refdef "LIB$INITIALIZE" nopic, con, gbl, noshr, nowrt, long
-#endif
-#endif /* __DECC */
-
-const long vms_cc_features = (const long)set_features;
-
-/*
-** Force a reference to LIB$INITIALIZE to ensure it
-** exists in the image.
-*/
-#define lib$initialize LIB$INITIALIZE
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-int lib$initialize(void);
-#ifdef __cplusplus
}
-#endif
-
-#if defined(__DECC) || defined(__DECCXX)
-#pragma extern_model strict_refdef
-#endif
- int lib_init_ref = (int) lib$initialize;
-#if defined(__DECC) || defined(__DECCXX)
-#pragma extern_model restore
-#pragma standard
+/* Use 32-bit pointers because that's what the image activator
+ * assumes for the LIB$INITIALZE psect.
+ */
+#if __INITIAL_POINTER_SIZE
+#pragma pointer_size save
+#pragma pointer_size 32
+#endif
+
+/* Create a reference to the LIB$INITIALIZE function. */
+extern void LIB$INITIALIZE(void);
+extern void (*vmsperl_unused_global_1)(void) = LIB$INITIALIZE;
+
+/* Create an array of pointers to the init functions in the special
+ * LIB$INITIALIZE section. In our case, the array only has one entry.
+ */
+#pragma extern_model save
+#pragma extern_model strict_refdef "LIB$INITIALIZE" gbl,noexe,nowrt,noshr,long
+extern void (* const vmsperl_unused_global_2[])() =
+{
+ vmsperl_set_features,
+};
+#pragma extern_model restore
+
+#if __INITIAL_POINTER_SIZE
+#pragma pointer_size restore
+#endif
+
+#ifdef __cplusplus
+}
#endif
+#endif /* defined(__DECC) || defined(__DECCXX) */
/* End of vms.c */