8043491: warning LNK4197: export '... ...' specified multiple times; using first specification

No need to use the /export linker option on windows 64-bit platform

Reviewed-by: ctornqvi, minqi
This commit is contained in:
Calvin Cheung 2014-11-12 16:22:12 -08:00
parent ae5c5e80cd
commit 1f7d2d4c0d
3 changed files with 33 additions and 24 deletions

View File

@ -89,8 +89,10 @@ AGCT_EXPORT=/export:AsyncGetCallTrace
# If you modify exports below please do the corresponding changes in # If you modify exports below please do the corresponding changes in
# src/share/tools/ProjectCreator/WinGammaPlatformVC7.java # src/share/tools/ProjectCreator/WinGammaPlatformVC7.java
LD_FLAGS=$(LD_FLAGS) $(STACK_SIZE) /subsystem:windows /dll /base:0x8000000 \ !if "$(BUILDARCH)" == "amd64"
/export:JNI_GetDefaultJavaVMInitArgs \ EXPORT_LIST=
!else
EXPORT_LIST=/export:JNI_GetDefaultJavaVMInitArgs \
/export:JNI_CreateJavaVM \ /export:JNI_CreateJavaVM \
/export:JVM_FindClassFromBootLoader \ /export:JVM_FindClassFromBootLoader \
/export:JNI_GetCreatedJavaVMs \ /export:JNI_GetCreatedJavaVMs \
@ -102,6 +104,9 @@ LD_FLAGS=$(LD_FLAGS) $(STACK_SIZE) /subsystem:windows /dll /base:0x8000000 \
$(AGCT_EXPORT) \ $(AGCT_EXPORT) \
/export:JVM_GetVersionInfo \ /export:JVM_GetVersionInfo \
/export:JVM_InitAgentProperties /export:JVM_InitAgentProperties
!endif
LD_FLAGS=$(LD_FLAGS) $(STACK_SIZE) /subsystem:windows /dll /base:0x8000000 $(EXPORT_LIST)
CXX_INCLUDE_DIRS=/I "..\generated" CXX_INCLUDE_DIRS=/I "..\generated"

View File

@ -512,9 +512,11 @@ abstract class GenericDebugConfig extends BuildConfig {
abstract class GenericDebugNonKernelConfig extends GenericDebugConfig { abstract class GenericDebugNonKernelConfig extends GenericDebugConfig {
protected void init(Vector includes, Vector defines) { protected void init(Vector includes, Vector defines) {
super.init(includes, defines); super.init(includes, defines);
if (get("PlatformName").equals("Win32")) {
getCI().getAdditionalNonKernelLinkerFlags(getV("LinkerFlags")); getCI().getAdditionalNonKernelLinkerFlags(getV("LinkerFlags"));
} }
} }
}
class C1DebugConfig extends GenericDebugNonKernelConfig { class C1DebugConfig extends GenericDebugNonKernelConfig {
String getOptFlag() { String getOptFlag() {

View File

@ -401,6 +401,7 @@ class CompilerInterfaceVC10 extends CompilerInterface {
Vector getBaseLinkerFlags(String outDir, String outDll, String platformName) { Vector getBaseLinkerFlags(String outDir, String outDll, String platformName) {
Vector rv = new Vector(); Vector rv = new Vector();
if(platformName.equals("Win32")) {
addAttr(rv, "AdditionalOptions", addAttr(rv, "AdditionalOptions",
"/export:JNI_GetDefaultJavaVMInitArgs " + "/export:JNI_GetDefaultJavaVMInitArgs " +
"/export:JNI_CreateJavaVM " + "/export:JNI_CreateJavaVM " +
@ -411,6 +412,7 @@ class CompilerInterfaceVC10 extends CompilerInterface {
"/export:jio_vsnprintf "+ "/export:jio_vsnprintf "+
"/export:JVM_GetVersionInfo "+ "/export:JVM_GetVersionInfo "+
"/export:JVM_InitAgentProperties"); "/export:JVM_InitAgentProperties");
}
addAttr(rv, "AdditionalDependencies", "kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;Wsock32.lib;winmm.lib;psapi.lib;version.lib"); addAttr(rv, "AdditionalDependencies", "kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;Wsock32.lib;winmm.lib;psapi.lib;version.lib");
addAttr(rv, "OutputFile", outDll); addAttr(rv, "OutputFile", outDll);
addAttr(rv, "SuppressStartupBanner", "true"); addAttr(rv, "SuppressStartupBanner", "true");