patch 8.1.1119: no support for Windows on ARM64.
Problem: No support for Windows on ARM64. Solution: Add ARM64 support (Leendert van Doorn)
This commit is contained in:
		
							
								
								
									
										5
									
								
								Filelist
									
									
									
									
									
								
							
							
						
						
									
										5
									
								
								Filelist
									
									
									
									
									
								
							| @ -508,13 +508,14 @@ SRC_DOS_BIN =	\ | |||||||
| 		src/vim.tlb \ | 		src/vim.tlb \ | ||||||
| 		src/xpm/COPYRIGHT \ | 		src/xpm/COPYRIGHT \ | ||||||
| 		src/xpm/README.txt \ | 		src/xpm/README.txt \ | ||||||
|  | 		src/xpm/arm64/lib-vc14/libXpm.lib \ | ||||||
| 		src/xpm/include/*.h \ | 		src/xpm/include/*.h \ | ||||||
|  | 		src/xpm/x64/lib-vc14/libXpm.lib \ | ||||||
| 		src/xpm/x64/lib/libXpm.a \ | 		src/xpm/x64/lib/libXpm.a \ | ||||||
| 		src/xpm/x64/lib/libXpm.lib \ | 		src/xpm/x64/lib/libXpm.lib \ | ||||||
| 		src/xpm/x64/lib-vc14/libXpm.lib \ | 		src/xpm/x86/lib-vc14/libXpm.lib \ | ||||||
| 		src/xpm/x86/lib/libXpm.a \ | 		src/xpm/x86/lib/libXpm.a \ | ||||||
| 		src/xpm/x86/lib/libXpm.lib \ | 		src/xpm/x86/lib/libXpm.lib \ | ||||||
| 		src/xpm/x86/lib-vc14/libXpm.lib \ |  | ||||||
| 		nsis/icons.zip \ | 		nsis/icons.zip \ | ||||||
|  |  | ||||||
| # source files for Amiga, DOS, etc. (also in the extra archive) | # source files for Amiga, DOS, etc. (also in the extra archive) | ||||||
|  | |||||||
| @ -25,6 +25,8 @@ PLATFORM = $(TARGET_CPU) | |||||||
| !  ifdef PLATFORM | !  ifdef PLATFORM | ||||||
| !   if ("$(PLATFORM)" == "x64") || ("$(PLATFORM)" == "X64") | !   if ("$(PLATFORM)" == "x64") || ("$(PLATFORM)" == "X64") | ||||||
| CPU = AMD64 | CPU = AMD64 | ||||||
|  | !   elseif ("$(PLATFORM)" == "arm64") || ("$(PLATFORM)" == "ARM64") | ||||||
|  | CPU = ARM64 | ||||||
| !   elseif ("$(PLATFORM)" != "x86") && ("$(PLATFORM)" != "X86") | !   elseif ("$(PLATFORM)" != "x86") && ("$(PLATFORM)" != "X86") | ||||||
| !    error *** ERROR Unknown target platform "$(PLATFORM)". Make aborted. | !    error *** ERROR Unknown target platform "$(PLATFORM)". Make aborted. | ||||||
| !   endif | !   endif | ||||||
| @ -56,11 +58,17 @@ SUBSYSTEM = console | |||||||
| SUBSYSTEM = $(SUBSYSTEM),$(SUBSYSTEM_VER) | SUBSYSTEM = $(SUBSYSTEM),$(SUBSYSTEM_VER) | ||||||
| !endif | !endif | ||||||
|  |  | ||||||
|  | !if "$(CPU)" == "ARM64" | ||||||
|  | OFFSET = 0x11C000000 | ||||||
|  | !else | ||||||
|  | OFFSET = 0x1C000000 | ||||||
|  | !endif | ||||||
|  |  | ||||||
| all: gvimext.dll | all: gvimext.dll | ||||||
|  |  | ||||||
| gvimext.dll:    gvimext.obj	\ | gvimext.dll:    gvimext.obj	\ | ||||||
| 		gvimext.res | 		gvimext.res | ||||||
| 	$(link) $(lflags) -dll -def:gvimext.def -base:0x1C000000 -out:$*.dll $** $(olelibsdll) shell32.lib comctl32.lib -subsystem:$(SUBSYSTEM) | 	$(link) $(lflags) -dll -def:gvimext.def -base:$(OFFSET) -out:$*.dll $** $(olelibsdll) shell32.lib comctl32.lib -subsystem:$(SUBSYSTEM) | ||||||
| 	if exist $*.dll.manifest mt -nologo -manifest $*.dll.manifest -outputresource:$*.dll;2 | 	if exist $*.dll.manifest mt -nologo -manifest $*.dll.manifest -outputresource:$*.dll;2 | ||||||
|  |  | ||||||
| gvimext.obj: gvimext.h | gvimext.obj: gvimext.h | ||||||
|  | |||||||
| @ -174,6 +174,15 @@ The following Visual C++ team blog can serve as a reference page: | |||||||
|     http://blogs.msdn.com/b/vcblog/archive/2012/10/08/windows-xp-targeting-with-c-in-visual-studio-2012.aspx |     http://blogs.msdn.com/b/vcblog/archive/2012/10/08/windows-xp-targeting-with-c-in-visual-studio-2012.aspx | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Cross compile support for Windows on ARM64 | ||||||
|  | ------------------------------------------ | ||||||
|  |  | ||||||
|  | This depends on VS2017 with the optional ARM64 compiler and SDK | ||||||
|  | installed. Use "vcvarsall.bat x64_arm64" as the build environment. | ||||||
|  |  | ||||||
|  | The ARM64 support was provided by Leendert van Doorn. | ||||||
|  |  | ||||||
|  |  | ||||||
| OLDER VERSIONS | OLDER VERSIONS | ||||||
|  |  | ||||||
| The minimal supported version is Windows XP. Building with older compilers | The minimal supported version is Windows XP. Building with older compilers | ||||||
|  | |||||||
| @ -240,6 +240,8 @@ PLATFORM = $(TARGET_CPU) | |||||||
| !  ifdef PLATFORM | !  ifdef PLATFORM | ||||||
| !   if ("$(PLATFORM)" == "x64") || ("$(PLATFORM)" == "X64") | !   if ("$(PLATFORM)" == "x64") || ("$(PLATFORM)" == "X64") | ||||||
| CPU = AMD64 | CPU = AMD64 | ||||||
|  | !   elseif ("$(PLATFORM)" == "arm64") || ("$(PLATFORM)" == "ARM64") | ||||||
|  | CPU = ARM64 | ||||||
| !   elseif ("$(PLATFORM)" != "x86") && ("$(PLATFORM)" != "X86") | !   elseif ("$(PLATFORM)" != "x86") && ("$(PLATFORM)" != "X86") | ||||||
| !    error *** ERROR Unknown target platform "$(PLATFORM)". Make aborted. | !    error *** ERROR Unknown target platform "$(PLATFORM)". Make aborted. | ||||||
| !   endif | !   endif | ||||||
| @ -442,6 +444,8 @@ DIRECTX_OBJ	= $(OUTDIR)\gui_dwrite.obj | |||||||
| # on the architecture. | # on the architecture. | ||||||
| !if "$(CPU)" == "AMD64" | !if "$(CPU)" == "AMD64" | ||||||
| XPM = xpm\x64 | XPM = xpm\x64 | ||||||
|  | !elseif "$(CPU)" == "ARM64" | ||||||
|  | XPM = xpm\arm64 | ||||||
| !elseif "$(CPU)" == "i386" | !elseif "$(CPU)" == "i386" | ||||||
| XPM = xpm\x86 | XPM = xpm\x86 | ||||||
| !else | !else | ||||||
|  | |||||||
| @ -1677,7 +1677,9 @@ install_registry(void) | |||||||
|  |  | ||||||
|     printf("Creating an uninstall entry\n"); |     printf("Creating an uninstall entry\n"); | ||||||
|     sprintf(display_name, "Vim " VIM_VERSION_SHORT |     sprintf(display_name, "Vim " VIM_VERSION_SHORT | ||||||
| #ifdef _WIN64 | #ifdef _M_ARM64 | ||||||
|  | 	    " (arm64)" | ||||||
|  | #elif _M_X64 | ||||||
| 	    " (x64)" | 	    " (x64)" | ||||||
| #endif | #endif | ||||||
| 	    ); | 	    ); | ||||||
|  | |||||||
| @ -771,6 +771,8 @@ static char *(features[]) = | |||||||
|  |  | ||||||
| static int included_patches[] = | static int included_patches[] = | ||||||
| {   /* Add new patch number below this line */ | {   /* Add new patch number below this line */ | ||||||
|  | /**/ | ||||||
|  |     1119, | ||||||
| /**/ | /**/ | ||||||
|     1118, |     1118, | ||||||
| /**/ | /**/ | ||||||
|  | |||||||
							
								
								
									
										
											BIN
										
									
								
								src/xpm/arm64/lib-vc14/libXpm.lib
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/xpm/arm64/lib-vc14/libXpm.lib
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
		Reference in New Issue
	
	Block a user