VMS: Use strict refdef extern model when building library object files
authorRichard Levitte <levitte@openssl.org>
Sun, 21 Aug 2016 21:36:49 +0000 (23:36 +0200)
committerRichard Levitte <levitte@openssl.org>
Mon, 22 Aug 2016 08:10:59 +0000 (10:10 +0200)
Most of the time, this isn't strictly needed.  However, in the default
extern model (called relaxed refdef), symbols are treated as weak
common objects unless they are initialised.  The librarian doesn't
include weak symbols in the (static) libraries, which renders them
invisible when linking a program with said those libraries, which is a
problem at times.

Using the strict refdef model is much more like standard C on all
other platforms, and thereby avoid the issues that come with the
relaxed refdef model.

Reviewed-by: Rich Salz <rsalz@openssl.org>
Configurations/10-main.conf

index cc1a207ea8ce58c66fc2d5a0e4a5f53fff16342d..4a2abaeb3a4f6af108197a6ce5a1544e4ad5e5db 100644 (file)
@@ -1730,7 +1730,7 @@ sub vms_info {
         lflags           => picker(default => "/MAP",
                                    debug   => "/DEBUG/TRACEBACK",
                                    release => "/NODEBUG/NOTRACEBACK"),
-        lib_cflags       => add("/NAMES=(AS_IS,SHORTENED)"),
+        lib_cflags       => add("/NAMES=(AS_IS,SHORTENED)/EXTERN_MODEL=STRICT_REFDEF"),
         dso_cflags       => add("/NAMES=(AS_IS,SHORTENED)"),
         shared_target    => "vms-shared",
         dso_scheme       => "vms",