[Spice-devel] [nsis 1/2] Add Windows 10 support
Christophe Fergeau
cfergeau at redhat.com
Wed Jan 4 12:16:06 UTC 2017
This requires WinVer from nsis 3.01.
---
WinVer.nsh | 495 ---------------------------------------------------
win-guest-tools.nsis | 11 +-
2 files changed, 3 insertions(+), 503 deletions(-)
delete mode 100755 WinVer.nsh
diff --git a/WinVer.nsh b/WinVer.nsh
deleted file mode 100755
index f7169f4..0000000
--- a/WinVer.nsh
+++ /dev/null
@@ -1,495 +0,0 @@
-; ---------------------
-; WinVer.nsh
-; ---------------------
-;
-; LogicLib extensions for handling Windows versions and service packs.
-;
-; IsNT checks if the installer is running on Windows NT family (NT4, 2000, XP, etc.)
-;
-; ${If} ${IsNT}
-; DetailPrint "Running on NT. Installing Unicode enabled application."
-; ${Else}
-; DetailPrint "Not running on NT. Installing ANSI application."
-; ${EndIf}
-;
-; IsServer checks if the installer is running on a server version of Windows (NT4, 2003, 2008, etc.)
-;
-; AtLeastWin<version> checks if the installer is running on Windows version at least as specified.
-; IsWin<version> checks if the installer is running on Windows version exactly as specified.
-; AtMostWin<version> checks if the installer is running on Windows version at most as specified.
-;
-; <version> can be replaced with the following values:
-;
-; 95
-; 98
-; ME
-;
-; NT4
-; 2000
-; XP
-; 2003
-; Vista
-; 2008
-; 7
-; 2008R2
-;
-; AtLeastServicePack checks if the installer is running on Windows service pack version at least as specified.
-; IsServicePack checks if the installer is running on Windows service pack version exactly as specified.
-; AtMostServicePack checks if the installer is running on Windows service version pack at most as specified.
-;
-; Usage examples:
-;
-; ${If} ${IsNT}
-; DetailPrint "Running on NT family."
-; DetailPrint "Surely not running on 95, 98 or ME."
-; ${AndIf} ${AtLeastWinNT4}
-; DetailPrint "Running on NT4 or better. Could even be 2003."
-; ${EndIf}
-;
-; ${If} ${AtLeastWinXP}
-; DetailPrint "Running on XP or better."
-; ${EndIf}
-;
-; ${If} ${IsWin2000}
-; DetailPrint "Running on 2000."
-; ${EndIf}
-;
-; ${If} ${IsWin2000}
-; ${AndIf} ${AtLeastServicePack} 3
-; ${OrIf} ${AtLeastWinXP}
-; DetailPrint "Running Win2000 SP3 or above"
-; ${EndIf}
-;
-; ${If} ${AtMostWinXP}
-; DetailPrint "Running on XP or older. Surely not running on Vista. Maybe 98, or even 95."
-; ${EndIf}
-;
-; Warning:
-;
-; Windows 95 and NT both use the same version number. To avoid getting NT4 misidentified
-; as Windows 95 and vice-versa or 98 as a version higher than NT4, always use IsNT to
-; check if running on the NT family.
-;
-; ${If} ${AtLeastWin95}
-; ${And} ${AtMostWinME}
-; DetailPrint "Running 95, 98 or ME."
-; DetailPrint "Actually, maybe it's NT4?"
-; ${If} ${IsNT}
-; DetailPrint "Yes, it's NT4! oops..."
-; ${Else}
-; DetailPrint "Nope, not NT4. phew..."
-; ${EndIf}
-; ${EndIf}
-;
-;
-; Other useful extensions are:
-;
-; * IsWin2003R2
-; * IsStarterEdition
-; * OSHasMediaCenter
-; * OSHasTabletSupport
-;
-
-!verbose push
-!verbose 3
-
-!ifndef ___WINVER__NSH___
-!define ___WINVER__NSH___
-
-!include LogicLib.nsh
-!include Util.nsh
-
-# masks for our variables
-
-!define _WINVER_VERXBIT 0x00000001
-!define _WINVER_MASKVMAJ 0x7F000000
-!define _WINVER_MASKVMIN 0x00FF0000
-
-!define _WINVER_NTBIT 0x80000000
-!define _WINVER_NTMASK 0x7FFFFFFF
-!define _WINVER_NTSRVBIT 0x40000000
-!define _WINVER_MASKVBLD 0x0000FFFF
-!define _WINVER_MASKSP 0x000F0000
-
-# possible variable values for different versions
-
-!define WINVER_95_NT 0x04000000 ;4.00.0950
-!define WINVER_95 0x04000000 ;4.00.0950
-!define WINVER_98_NT 0x040a0000 ;4.10.1998
-!define WINVER_98 0x040a0000 ;4.10.1998
-;define WINVER_98SE 0x040a0000 ;4.10.2222
-!define WINVER_ME_NT 0x045a0000 ;4.90.3000
-!define WINVER_ME 0x045a0000 ;4.90.3000
-;define WINVER_NT3d51 ;3.51.1057
-!define WINVER_NT4_NT 0x84000000 ;4.00.1381
-!define WINVER_NT4 0x04000000 ;4.00.1381
-!define WINVER_2000_NT 0x85000000 ;5.00.2195
-!define WINVER_2000 0x05000000 ;5.00.2195
-!define WINVER_XP_NT 0x85010000 ;5.01.2600
-!define WINVER_XP 0x05010000 ;5.01.2600
-;define WINVER_XP64 ;5.02.3790
-!define WINVER_2003_NT 0x85020000 ;5.02.3790
-!define WINVER_2003 0x05020000 ;5.02.3790
-!define WINVER_VISTA_NT 0x86000000 ;6.00.6000
-!define WINVER_VISTA 0x06000000 ;6.00.6000
-!define WINVER_2008_NT 0x86000001 ;6.00.6001
-!define WINVER_2008 0x06000001 ;6.00.6001
-!define WINVER_7_NT 0x86010000 ;6.01.????
-!define WINVER_7 0x06010000 ;6.01.????
-!define WINVER_2008R2_NT 0x86010001 ;6.01.????
-!define WINVER_2008R2 0x06010001 ;6.01.????
-
-# from nsis svn
-!define WINVER_8_NT 0x86020000 ;6.02.9200
-!define WINVER_8 0x06020000 ;6.02.9200
-!define WINVER_2012_NT 0x86020001 ;6.02.9200
-!define WINVER_2012 0x06020001 ;6.02.9200
-!define WINVER_8.1_NT 0x86030000 ;6.03.9600
-!define WINVER_8.1 0x06030000 ;6.03.9600
-!define WINVER_2012R2_NT 0x86030001 ;6.03.9600
-!define WINVER_2012R2 0x06030001 ;6.03.9600
-
-
-
-# use this to make all nt > 9x
-
-!ifdef WINVER_NT4_OVER_W95
- !define __WINVERTMP ${WINVER_NT4}
- !undef WINVER_NT4
- !define /math WINVER_NT4 ${__WINVERTMP} | ${_WINVER_VERXBIT}
- !undef __WINVERTMP
-!endif
-
-# some definitions from header files
-
-!define OSVERSIONINFOA_SIZE 148
-!define OSVERSIONINFOEXA_SIZE 156
-!define VER_PLATFORM_WIN32_NT 2
-!define VER_NT_WORKSTATION 1
-
-!define SM_TABLETPC 86
-!define SM_MEDIACENTER 87
-!define SM_STARTER 88
-!define SM_SERVERR2 89
-
-# variable declaration
-
-!macro __WinVer_DeclareVars
-
- !ifndef __WINVER_VARS_DECLARED
-
- !define __WINVER_VARS_DECLARED
-
- Var /GLOBAL __WINVERV
- Var /GLOBAL __WINVERSP
-
- !endif
-
-!macroend
-
-# lazy initialization macro
-
-!ifmacrondef __WinVer_Call_GetVersionEx
-
- !macro __WinVer_Call_GetVersionEx STRUCT_SIZE
-
- System::Call '*$0(i ${STRUCT_SIZE})'
- System::Call kernel32::GetVersionEx(ir0)i.r3
-
- !macroend
-
-!endif
-
-!macro __WinVer_InitVars
- # variables
- !insertmacro __WinVer_DeclareVars
-
- # only calculate version once
- StrCmp $__WINVERV "" _winver_noveryet
- Return
- _winver_noveryet:
-
- # push used registers on the stack
- Push $0
- Push $1 ;maj
- Push $2 ;min
- Push $3 ;bld
- Push $R0 ;temp
-
- # allocate memory
- System::Alloc ${OSVERSIONINFOEXA_SIZE}
- Pop $0
-
- # use OSVERSIONINFOEX
- !insertmacro __WinVer_Call_GetVersionEx ${OSVERSIONINFOEXA_SIZE}
-
- IntCmp $3 0 "" _winver_ex _winver_ex
- # OSVERSIONINFOEX not allowed (Win9x or NT4 w/SP < 6), use OSVERSIONINFO
- !insertmacro __WinVer_Call_GetVersionEx ${OSVERSIONINFOA_SIZE}
- _winver_ex:
-
- # get results from struct
- System::Call '*$0(i.s,i.r1,i.r2,i.r3,i.s,&t128.s,&i2.s,&i2,&i2,&i1.s,&i1)'
-
- # free struct
- System::Free $0
-
- # win9x has major and minor info in high word of dwBuildNumber - remove it
- IntOp $3 $3 & 0xFFFF
-
- # get dwOSVersionInfoSize
- Pop $R0
-
- # get dwPlatformId
- Pop $0
-
- # NT?
- IntCmp $0 ${VER_PLATFORM_WIN32_NT} "" _winver_notnt _winver_notnt
- IntOp $__WINVERSP $__WINVERSP | ${_WINVER_NTBIT}
- IntOp $__WINVERV $__WINVERV | ${_WINVER_NTBIT}
- _winver_notnt:
-
- # get service pack information
- IntCmp $0 ${VER_PLATFORM_WIN32_NT} _winver_nt "" _winver_nt # win9x
-
- # get szCSDVersion
- Pop $0
-
- # copy second char
- StrCpy $0 $0 1 1
-
- # discard invalid wServicePackMajor and wProductType
- Pop $R0
- Pop $R0
-
- # switch
- StrCmp $0 'A' "" +3
- StrCpy $0 1
- Goto _winver_sp_done
- StrCmp $0 'B' "" +3
- StrCpy $0 2
- Goto _winver_sp_done
- StrCmp $0 'C' "" +3
- StrCpy $0 3
- Goto _winver_sp_done
- StrCpy $0 0
- Goto _winver_sp_done
-
- _winver_nt: # nt
-
- IntCmp $R0 ${OSVERSIONINFOEXA_SIZE} "" _winver_sp_noex _winver_sp_noex
-
- # discard szCSDVersion
- Pop $0
-
- # get wProductType
- Exch
- Pop $0
-
- # is server?
- IntCmp $0 ${VER_NT_WORKSTATION} _winver_noserver _winver_noserver ""
- IntOp $__WINVERSP $__WINVERSP | ${_WINVER_NTSRVBIT}
- _winver_noserver:
-
- # get wServicePackMajor
- Pop $0
-
- # done with sp
- Goto _winver_sp_done
-
- _winver_sp_noex: # OSVERSIONINFO, not OSVERSIONINFOEX
-
- #### TODO
- ## For IsServer to support < NT4SP6, we need to check the registry
- ## here to see if we are a server and/or DC
-
- # get szCSDVersion
- Pop $0
-
- # discard invalid wServicePackMajor and wProductType
- Pop $R0
- Pop $R0
-
- # get service pack number from text
- StrCpy $R0 $0 13
- StrCmp $R0 "Service Pack " "" +3
- StrCpy $0 $0 "" 13 # cut "Service Pack "
- Goto +2
- StrCpy $0 0 # no service pack
-
-!ifdef WINVER_NT4_OVER_W95
- IntOp $__WINVERV $__WINVERV | ${_WINVER_VERXBIT}
-!endif
-
- _winver_sp_done:
-
- # store service pack
- IntOp $0 $0 << 16
- IntOp $__WINVERSP $__WINVERSP | $0
-
- ### now for the version
-
- # is server?
- IntOp $0 $__WINVERSP & ${_WINVER_NTSRVBIT}
-
- # windows xp x64?
- IntCmp $0 0 "" _winver_not_xp_x64 _winver_not_xp_x64 # not server
- IntCmp $1 5 "" _winver_not_xp_x64 _winver_not_xp_x64 # maj 5
- IntCmp $2 2 "" _winver_not_xp_x64 _winver_not_xp_x64 # min 2
- # change XP x64 from 5.2 to 5.1 so it's still XP
- StrCpy $2 1
- _winver_not_xp_x64:
-
- # server 2008?
- IntCmp $0 0 _winver_not_ntserver # server
- IntCmp 6 $1 "" "" _winver_not_ntserver # maj 6
- # extra bit so Server 2008 comes after Vista SP1 that has the same minor version, same for Win7 vs 2008R2
- IntOp $__WINVERV $__WINVERV | ${_WINVER_VERXBIT}
- _winver_not_ntserver:
-
- # pack version
- IntOp $1 $1 << 24 # VerMajor
- IntOp $__WINVERV $__WINVERV | $1
- IntOp $0 $2 << 16
- IntOp $__WINVERV $__WINVERV | $0 # VerMinor
- IntOp $__WINVERSP $__WINVERSP | $3 # VerBuild
-
- # restore registers
- Pop $R0
- Pop $3
- Pop $2
- Pop $1
- Pop $0
-
-!macroend
-
-# version comparison LogicLib macros
-
-!macro _WinVerAtLeast _a _b _t _f
- !insertmacro _LOGICLIB_TEMP
- ${CallArtificialFunction} __WinVer_InitVars
- IntOp $_LOGICLIB_TEMP $__WINVERV & ${_WINVER_NTMASK}
- !insertmacro _>= $_LOGICLIB_TEMP `${_b}` `${_t}` `${_f}`
-!macroend
-!macro _WinVerIs _a _b _t _f
- ${CallArtificialFunction} __WinVer_InitVars
- !insertmacro _= $__WINVERV `${_b}` `${_t}` `${_f}`
-!macroend
-!macro _WinVerAtMost _a _b _t _f
- !insertmacro _LOGICLIB_TEMP
- ${CallArtificialFunction} __WinVer_InitVars
- IntOp $_LOGICLIB_TEMP $__WINVERV & ${_WINVER_NTMASK}
- !insertmacro _<= $_LOGICLIB_TEMP `${_b}` `${_t}` `${_f}`
-!macroend
-
-!macro __WinVer_DefineOSTest Test OS Suffix
- !define ${Test}Win${OS} `"" WinVer${Test} ${WINVER_${OS}${Suffix}}`
-!macroend
-
-!macro __WinVer_DefineOSTests Test Suffix
- !insertmacro __WinVer_DefineOSTest ${Test} 95 '${Suffix}'
- !insertmacro __WinVer_DefineOSTest ${Test} 98 '${Suffix}'
- !insertmacro __WinVer_DefineOSTest ${Test} ME '${Suffix}'
- !insertmacro __WinVer_DefineOSTest ${Test} NT4 '${Suffix}'
- !insertmacro __WinVer_DefineOSTest ${Test} 2000 '${Suffix}'
- !insertmacro __WinVer_DefineOSTest ${Test} XP '${Suffix}'
- !insertmacro __WinVer_DefineOSTest ${Test} 2003 '${Suffix}'
- !insertmacro __WinVer_DefineOSTest ${Test} VISTA '${Suffix}'
- !insertmacro __WinVer_DefineOSTest ${Test} 2008 '${Suffix}'
- !insertmacro __WinVer_DefineOSTest ${Test} 7 '${Suffix}'
- !insertmacro __WinVer_DefineOSTest ${Test} 2008R2 '${Suffix}'
- !insertmacro __WinVer_DefineOSTest ${Test} 8 '${Suffix}'
- !insertmacro __WinVer_DefineOSTest ${Test} 2012 '${Suffix}'
- !insertmacro __WinVer_DefineOSTest ${Test} 8.1 '${Suffix}'
- !insertmacro __WinVer_DefineOSTest ${Test} 2012R2 '${Suffix}'
-!macroend
-
-!insertmacro __WinVer_DefineOSTests AtLeast ""
-!insertmacro __WinVer_DefineOSTests Is _NT
-!insertmacro __WinVer_DefineOSTests AtMost ""
-
-# version feature LogicLib macros
-
-!macro _IsNT _a _b _t _f
- !insertmacro _LOGICLIB_TEMP
- ${CallArtificialFunction} __WinVer_InitVars
- IntOp $_LOGICLIB_TEMP $__WINVERSP & ${_WINVER_NTBIT}
- !insertmacro _!= $_LOGICLIB_TEMP 0 `${_t}` `${_f}`
-!macroend
-!define IsNT `"" IsNT ""`
-
-!macro _IsServerOS _a _b _t _f
- !insertmacro _LOGICLIB_TEMP
- ${CallArtificialFunction} __WinVer_InitVars
- IntOp $_LOGICLIB_TEMP $__WINVERSP & ${_WINVER_NTSRVBIT}
- !insertmacro _!= $_LOGICLIB_TEMP 0 `${_t}` `${_f}`
-!macroend
-!define IsServerOS `"" IsServerOS ""`
-
-# service pack macros
-
-!macro _WinVer_GetServicePackLevel OUTVAR
- ${CallArtificialFunction} __WinVer_InitVars
- IntOp ${OUTVAR} $__WINVERSP & ${_WINVER_MASKSP}
- IntOp ${OUTVAR} ${OUTVAR} >> 16
-!macroend
-!define WinVerGetServicePackLevel '!insertmacro _WinVer_GetServicePackLevel '
-
-!macro _AtLeastServicePack _a _b _t _f
- !insertmacro _LOGICLIB_TEMP
- ${WinVerGetServicePackLevel} $_LOGICLIB_TEMP
- !insertmacro _>= $_LOGICLIB_TEMP `${_b}` `${_t}` `${_f}`
-!macroend
-!define AtLeastServicePack `"" AtLeastServicePack`
-
-!macro _AtMostServicePack _a _b _t _f
- !insertmacro _LOGICLIB_TEMP
- ${WinVerGetServicePackLevel} $_LOGICLIB_TEMP
- !insertmacro _<= $_LOGICLIB_TEMP `${_b}` `${_t}` `${_f}`
-!macroend
-!define AtMostServicePack `"" AtMostServicePack`
-
-!macro _IsServicePack _a _b _t _f
- !insertmacro _LOGICLIB_TEMP
- ${WinVerGetServicePackLevel} $_LOGICLIB_TEMP
- !insertmacro _= $_LOGICLIB_TEMP `${_b}` `${_t}` `${_f}`
-!macroend
-!define IsServicePack `"" IsServicePack`
-
-# special feature LogicLib macros
-
-!macro _WinVer_SysMetricCheck m _b _t _f
- !insertmacro _LOGICLIB_TEMP
- System::Call user32::GetSystemMetrics(i${m})i.s
- pop $_LOGICLIB_TEMP
- !insertmacro _!= $_LOGICLIB_TEMP 0 `${_t}` `${_f}`
-!macroend
-
-!define IsWin2003R2 `${SM_SERVERR2} WinVer_SysMetricCheck ""`
-!define IsStarterEdition `${SM_STARTER} WinVer_SysMetricCheck ""`
-!define OSHasMediaCenter `${SM_MEDIACENTER} WinVer_SysMetricCheck ""`
-!define OSHasTabletSupport `${SM_TABLETPC} WinVer_SysMetricCheck ""`
-
-# version retrieval macros
-
-!macro __WinVer_GetVer var rshift mask outvar
- ${CallArtificialFunction} __WinVer_InitVars
- !if "${mask}" != ""
- IntOp ${outvar} ${var} & ${mask}
- !if "${rshift}" != ""
- IntOp ${outvar} ${outvar} >> ${rshift}
- !endif
- !else
- IntOp ${outvar} ${var} >> ${rshift}
- !endif
-!macroend
-
-!define WinVerGetMajor '!insertmacro __WinVer_GetVer $__WINVERV 24 ${_WINVER_MASKVMAJ}'
-!define WinVerGetMinor '!insertmacro __WinVer_GetVer $__WINVERV 16 ${_WINVER_MASKVMIN}'
-!define WinVerGetBuild '!insertmacro __WinVer_GetVer $__WINVERSP "" ${_WINVER_MASKVBLD}'
-
-# done
-
-!endif # !___WINVER__NSH___
-
-!verbose pop
diff --git a/win-guest-tools.nsis b/win-guest-tools.nsis
index 1951721..2092edc 100644
--- a/win-guest-tools.nsis
+++ b/win-guest-tools.nsis
@@ -154,14 +154,7 @@ Section "install"
Push "PCI\VEN_1AF4&DEV_1001&SUBSYS_00021AF4&REV_00"
Call InstallDriver
- ${If} ${IsWinVista}
- ${OrIf} ${IsWin2008}
- ${OrIf} ${IsWin7}
- ${OrIf} ${IsWin2008R2}
- ${OrIf} ${IsWin8}
- ${OrIf} ${IsWin2012}
- ${OrIf} ${IsWin8.1}
- ${OrIf} ${IsWin2012R2}
+ ${If} ${AtLeastWinVista}
Push "vioscsi"
Push "vioscsi"
Push "PCI\VEN_1AF4&DEV_1004&SUBSYS_00081AF4&REV_00"
@@ -291,6 +284,8 @@ Function GetDriverSubdir
StrCpy $0 "$0\w8.1"
${ElseIf} ${IsWin2012R2}
StrCpy $0 "$0\w2k12r2"
+ ${ElseIf} ${IsWin10}
+ StrCpy $0 "$0\w10"
${Else}
MessageBox MB_ICONEXCLAMATION "Unsupported Windows version"
Abort ; causes installer to quit.
--
2.9.3
More information about the Spice-devel
mailing list