> > 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. Which repository these patches apply? Frediano _______________________________________________ Spice-devel mailing list Spice-devel@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/spice-devel