mirror of https://github.com/tongzx/nt5src
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
4790 lines
152 KiB
4790 lines
152 KiB
;*************************************************************************
|
|
;
|
|
; UTILITY.INF
|
|
;
|
|
; Network Installation utility functions. Each major piece of
|
|
; functionality is coded as a [Section], and is invoked by name from
|
|
; the outer level INF. See TEMPLATE.INF for example usage.
|
|
;
|
|
; CHANGES:
|
|
; DavidHov 6/11/92 Added Service"Linkage" key return
|
|
; value to [AddSoftwareComponent]
|
|
;
|
|
; DavidHov 8/24/92 Add WinSock support routines for
|
|
; transports
|
|
;
|
|
;
|
|
;
|
|
;*************************************************************************
|
|
|
|
;
|
|
;--------------------------------------------------------------------------
|
|
; Header to be used at the front of all externally available INF sections.
|
|
;--------------------------------------------------------------------------
|
|
;
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: sectionname
|
|
;
|
|
; PURPOSE: <describe purpose of section>
|
|
;
|
|
; ARGUMENTS: $0
|
|
; $1
|
|
;
|
|
; RETURNS: $R0
|
|
; $R1
|
|
;
|
|
; REFERENCES: <list of global or parent variables referenced>
|
|
;
|
|
; MODIFIES: <list of global or parent variables modified>
|
|
;
|
|
;
|
|
;*************************************************************************
|
|
;*************************************************************************
|
|
; end of section sectionname
|
|
;*************************************************************************
|
|
|
|
;
|
|
; Initialize general constants
|
|
;
|
|
[InitBaseVars]
|
|
|
|
KeyNull = ""
|
|
MAXIMUM_ALLOWED = 33554432
|
|
KeyInfo = {}
|
|
RegistryErrorIndex = NO_ERROR
|
|
NoTitle = 0
|
|
|
|
CurrentControlSet = "SYSTEM\CurrentControlSet"
|
|
ServicesBaseName = $(CurrentControlSet)"\Services"
|
|
NetworkCardKeyName = $(!NTN_SoftwareBase)"\Microsoft\Windows NT\CurrentVersion\NetworkCards"
|
|
|
|
!RegLastError = NO_ERROR
|
|
|
|
[RegistryErrorSetup]
|
|
RegistryErrorIndex = ^(RegistryErrors$(!STF_LANGUAGE),1)
|
|
RegistryErrorList = ^(RegistryErrors$(!STF_LANGUAGE),2)
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: RegistryErrorString
|
|
;
|
|
; PURPOSE: Translate a numeric registry error code into a string
|
|
;
|
|
; ARGUMENTS: $0 Registry error code
|
|
;
|
|
; RETURNS: $R0 String containing displayable text in language
|
|
;
|
|
; REFERENCES: !STF_LANGUAGE -- global "user's language" variable;
|
|
; see [RegistryErrorSetup]
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;
|
|
;*************************************************************************
|
|
[RegistryErrorString]
|
|
|
|
read-syms RegistryErrorSetup
|
|
read-syms RegistryErrorUnknown$(!STF_LANGUAGE)
|
|
|
|
set RE_String = *($(RegistryErrorList),~($(RegistryErrorIndex),$($0)))
|
|
|
|
Ifstr $(RE_String) == ""
|
|
set RE_String = $(Error_Bogus)
|
|
endif
|
|
|
|
return $(RE_String)
|
|
|
|
;*************************************************************************
|
|
; end of section RegistryErrorString
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: BaseServiceKey
|
|
;
|
|
; PURPOSE: Return an open key handle to the top of the services tree
|
|
;
|
|
; ARGUMENTS: none
|
|
;
|
|
; RETURNS: $R0 Registry error code
|
|
; $R1 Registry key variable for SERVICES0
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
[BaseServiceKey]
|
|
read-syms InitBaseVars
|
|
set BS_KeyServices = ""
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(ServicesBaseName) $(MAXIMUM_ALLOWED) BS_KeyServices
|
|
|
|
Ifstr $(BS_KeyServices) == $(KeyNull)
|
|
Debug-Output "UTILITY.INF: could not open Services base key"
|
|
set RegistryErrorIndex = UNABLE_ACCESS_CONFIGURE_SERVICE
|
|
endif
|
|
|
|
B_S_Return = +
|
|
return $(RegistryErrorIndex), $(BS_KeyServices)
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: ReduceInfPath
|
|
;
|
|
; PURPOSE: Process the path\name string to an INF file. If
|
|
; its path points to STF_WINDOWSSYSPATH, remove the path prefix.
|
|
;
|
|
; ARGUMENTS: $0 Path\name to INF file
|
|
;
|
|
; RETURNS: $R0 Resulting string
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
[ReduceInfPath]
|
|
Set RIP_Result = $($0)
|
|
|
|
Split-String $(RIP_Result) "\" InList
|
|
Set BasePath = $(!STF_WINDOWSSYSPATH)"\"
|
|
Split-String $(BasePath) "\" BaseList
|
|
|
|
;
|
|
; See how many of the path elements match
|
|
;
|
|
|
|
Set Indx = 0
|
|
Set Matched = 0
|
|
QueryListSize InListSize, $(InList)
|
|
ForListDo $(BaseList)
|
|
Set-add Indx = $(Indx),1
|
|
Ifint $(Indx) <= $(InListSize)
|
|
Set Instr = *($(InList),$(Indx))
|
|
Ifstr(i) $($) == $(Instr)
|
|
Set-add Matched = $(Matched),1
|
|
Endif
|
|
Endif
|
|
EndForListDo
|
|
|
|
;
|
|
; If all the path elements of the input path matched
|
|
; those of STF_WINDOWSSYSPATH, strip them off of the result.
|
|
;
|
|
|
|
Ifint $(Indx) == $(Matched)
|
|
Set RIP_Result = ""
|
|
Set Indx2 = 0
|
|
ForListDo $(InList)
|
|
Set-add Indx2 = $(Indx2),1
|
|
Ifint $(Indx2) > $(Indx)
|
|
Set RIP_Result = $(RIP_Result)$($)
|
|
Endif
|
|
EndForListDo
|
|
Endif
|
|
|
|
Return $(RIP_Result)
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: InstallSoftwareProduct
|
|
;
|
|
; PURPOSE: Add a new component into the Registry
|
|
;
|
|
; ARGUMENTS: $0 name of Manufacturer
|
|
; $1 name of Product
|
|
; $2 full INF path and name
|
|
;
|
|
; RETURNS: $R0 error code or zero if no error
|
|
; $R1 Registry key variable for
|
|
; SOFTWARE\Manufacturer\Product\Version key
|
|
; $R2 Registry key variable for
|
|
; ...\NetRules
|
|
;
|
|
; REFERENCES: none
|
|
;
|
|
; MODIFIES: none
|
|
;
|
|
;*************************************************************************
|
|
|
|
[InstallSoftwareProduct]
|
|
read-syms InitBaseVars
|
|
|
|
set IS_MfgName = $($0)
|
|
set IS_ProdName = $($1)
|
|
set IS_Infname = $($2)
|
|
set IS_KeySoftware = ""
|
|
set IS_KeyMfg = ""
|
|
set IS_KeyProduct = ""
|
|
set IS_KeyVersion = ""
|
|
set IS_KeyNetRules = ""
|
|
set IS_MfgCreated = 1
|
|
set IS_ProductCreated = 1
|
|
;
|
|
; Validate the arguments passed in
|
|
;
|
|
set RegistryErrorIndex = INVALID_DATA_PASSED
|
|
|
|
Ifstr(i) $(IS_MfgName) == ""
|
|
goto I_S_Return
|
|
endif
|
|
Ifstr(i) $(IS_ProdName) == ""
|
|
goto I_S_Return
|
|
endif
|
|
|
|
set RegistryErrorIndex = NO_ERROR
|
|
;
|
|
; Open the HKEY_LOCAL_MACHINE\SOFTWARE key
|
|
;
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(!NTN_SoftwareBase) $(MAXIMUM_ALLOWED) IS_KeySoftware
|
|
|
|
Ifstr $(IS_KeySoftware) == $(KeyNull)
|
|
set RegistryErrorIndex = UNABLE_ACCESS_SOFTWARE_REG
|
|
goto I_S_Return
|
|
endif
|
|
;
|
|
; Create the Manufacturer's key if necessary
|
|
;
|
|
CreateRegKey $(IS_KeySoftware) {$(IS_MfgName),$(NoTitle),GenericClass} "" $(MAXIMUM_ALLOWED) "" IS_KeyMfg
|
|
Ifstr $(IS_KeyMfg) == $(KeyNull)
|
|
set IS_MfgCreated = 0
|
|
OpenRegKey $(IS_KeySoftware) "" $(IS_MfgName) $(MAXIMUM_ALLOWED) IS_KeyMfg
|
|
Ifstr $(IS_KeyMfg) == $(KeyNull)
|
|
set RegistryErrorIndex = UNABLE_OPEN_MICROSOFT_KEY
|
|
goto I_S_Return
|
|
endif
|
|
endif
|
|
;
|
|
; Create the Software Product key if necessary
|
|
;
|
|
CreateRegKey $(IS_KeyMfg) {$(IS_ProdName),$(NoTitle),GenericClass} "" $(MAXIMUM_ALLOWED) "" IS_KeyProduct
|
|
Ifstr $(IS_KeyProduct) == $(KeyNull)
|
|
set IS_ProductCreated = 0
|
|
OpenRegKey $(IS_KeyMfg) "" $(IS_ProdName) $(MAXIMUM_ALLOWED) IS_KeyProduct
|
|
Ifstr $(IS_KeyProduct) == $(KeyNull)
|
|
set RegistryErrorIndex = UNABLE_CREATE_PRODUCT_KEY
|
|
goto I_S_Return
|
|
endif
|
|
endif
|
|
;
|
|
; Create the software product version key.
|
|
;
|
|
CreateRegKey $(IS_KeyProduct) {"CurrentVersion",$(NoTitle),GenericClass} "" $(MAXIMUM_ALLOWED) "" IS_KeyVersion
|
|
Ifstr $(IS_KeyVersion) == $(KeyNull)
|
|
OpenRegKey $(IS_KeyProduct) "" "CurrentVersion" $(MAXIMUM_ALLOWED) IS_KeyVersion
|
|
Ifstr $(IS_KeyVersion) == $(KeyNull)
|
|
set RegistryErrorIndex = UNABLE_CREATE_PRODUCT_VERSION
|
|
goto I_S_Return
|
|
endif
|
|
endif
|
|
|
|
set RegistryErrorIndex = NO_ERROR
|
|
;
|
|
; Create the NetRules key
|
|
;
|
|
CreateRegKey $(IS_KeyVersion) {NetRules,$(NoTitle),GenericClass} "" $(MAXIMUM_ALLOWED) "" IS_KeyNetRules
|
|
Ifstr $(IS_KeyNetRules) == $(KeyNull)
|
|
OpenRegKey $(IS_KeyVersion) "" NetRules $(MAXIMUM_ALLOWED) IS_KeyNetRules
|
|
Ifstr $(IS_KeyNetRules) == $(KeyNull)
|
|
set RegistryErrorIndex = UNABLE_CREATE_NETRULES_KEY
|
|
goto I_S_Return
|
|
endif
|
|
endif
|
|
;
|
|
; Set the "Infname" value if non-null; reduce it if it's in %SystemRoot%
|
|
;
|
|
Ifstr $(IS_Infname) != ""
|
|
Shell "", ReduceInfPath, $(IS_Infname)
|
|
SetRegValue $(IS_KeyNetRules) {InfName,$(NoTitle),$(!REG_VT_SZ),$($R0)}
|
|
endif
|
|
|
|
;
|
|
; Exit, leaving $(IS_KeyVersion) and $(IS_KeyNetRules) open for the caller...
|
|
;
|
|
I_S_Return = +
|
|
Ifstr $(IS_KeyProduct) != ""
|
|
Ifint $(IS_ProductCreated) == 1
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
Debug-Output "UTILITY.INF: DeleteRegTree Product Key"
|
|
;DeleteRegTree $(IS_KeyProduct) ""
|
|
set IS_KeyProduct = ""
|
|
endif
|
|
endif
|
|
Ifstr $(IS_KeyProduct) != ""
|
|
CloseRegKey $(IS_KeyProduct)
|
|
endif
|
|
endif
|
|
Ifstr $(IS_KeyMfg) != ""
|
|
Ifint $(IS_MfgCreated) == 1
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
;DeleteRegTree $(IS_KeyMfg) ""
|
|
Debug-Output "UTILITY.INF: DeleteRegTree Manufacturer Key"
|
|
set IS_KeyMfg = ""
|
|
endif
|
|
endif
|
|
Ifstr $(IS_KeyMfg) != ""
|
|
CloseRegKey $(IS_KeyMfg)
|
|
endif
|
|
endif
|
|
Ifstr $(IS_KeySoftware) != ""
|
|
CloseRegKey $(IS_KeySoftware)
|
|
endif
|
|
return $(RegistryErrorIndex), $(IS_KeyVersion), $(IS_KeyNetRules)
|
|
|
|
;*************************************************************************
|
|
; end of section InstallSoftwareProduct
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: AddValueList
|
|
;
|
|
; PURPOSE: Given a nested list of value items, add each to the given
|
|
; key. Key is left open.
|
|
;
|
|
; ARGUMENTS: $0 Registry key handle
|
|
; $1 List of value items; for example:
|
|
; { {ValueName1,0,$(!REG_VT_SZ),$(ValueData1)}, +
|
|
; {ValueName2,0,$(!REG_VT_SZ),$(ValueData2)} }
|
|
;
|
|
; RETURNS: $R0 Registry error code.
|
|
;
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
[AddValueList]
|
|
set RegistryErrorIndex = NO_ERROR
|
|
|
|
ForListDo $($1)
|
|
SetRegValue $($0) $($)
|
|
ifint $(RegLastError) != 0
|
|
Debug-Output "UTILITY.INF: Value write fail data: "$($)
|
|
Debug-Output "UTILITY.INF: Value write fail key: "$($0)
|
|
return UNABLE_WRITE_REGISTRY
|
|
endif
|
|
EndForListDo
|
|
|
|
return $(RegistryErrorIndex)
|
|
|
|
;*************************************************************************
|
|
; end of section AddValueList
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: DeleteSoftwareProduct
|
|
;
|
|
; PURPOSE: Delete the given product from the Registry entirely
|
|
;
|
|
; ARGUMENTS: $0 Product Key Handle
|
|
;
|
|
; RETURNS: $R0 Registry error code
|
|
; $R1
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
[DeleteSoftwareProduct]
|
|
|
|
set RegistryErrorIndex = NO_ERROR
|
|
|
|
Debug-Output "UTILITY.INF: DeleteRegTree Software Product"
|
|
DeleteRegTree $($0) ""
|
|
|
|
return $(RegistryErrorIndex)
|
|
|
|
;*************************************************************************
|
|
; end of section DeleteSoftwareProduct
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: VerExistedDlg
|
|
;
|
|
; PURPOSE: Popup a dialog and tell the user that the same ver of
|
|
; the software already exists in the registery tree.
|
|
; Ask the user whether he want to continue or not
|
|
;
|
|
; ARGUMENTS: $0 Product Name
|
|
; $0 Product version
|
|
;
|
|
; RETURNS: $R0 Registry error code
|
|
; $R1 either "continue" or "exit"
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
|
|
[VerExistedDlg]
|
|
|
|
set RegistryErrorIndex = NO_ERROR
|
|
|
|
set-subst LF = "\n"
|
|
read-syms VerExisted$(!STF_LANGUAGE)
|
|
|
|
set DlgText = $($0)+
|
|
$(ver)+
|
|
$($1)+
|
|
$(Text)
|
|
Shell "Subroutn.Inf" SetupMessage $(!STF_LANGUAGE) "NONFATAL" $(DlgText)
|
|
|
|
ifint $($ShellCode) != $(!SHELL_CODE_OK)
|
|
set RegistryErrorIndex = ERROR
|
|
endif
|
|
|
|
return $(RegistryErrorIndex), $($R1)
|
|
|
|
;*************************************************************************
|
|
; end of section VerExistedDialog
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: CardExistedDlg
|
|
;
|
|
; PURPOSE: Popup a dialog and tell the user that the network card
|
|
; is lready installed and ask them whether theyr want to
|
|
; continue.
|
|
;
|
|
; ARGUMENTS: NONE
|
|
;
|
|
; RETURNS: $R0 Registry error code
|
|
; $R1 either "continue" or "exit"
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
|
|
[CardExistedDlg]
|
|
|
|
set RegistryErrorIndex = NO_ERROR
|
|
set ButtonReturn = "OK"
|
|
|
|
ifstr(i) $(!STF_GUI_UNATTENDED) != "YES"
|
|
set-subst LF = "\n"
|
|
read-syms CardExisted$(!STF_LANGUAGE)
|
|
|
|
set DlgText = $(Text)
|
|
|
|
Shell "Subroutn.Inf" SetupMessage $(!STF_LANGUAGE) "WARNING" $(DlgText)
|
|
|
|
ifint $($ShellCode) != $(!SHELL_CODE_OK)
|
|
set RegistryErrorIndex = ERROR
|
|
endif
|
|
set ButtonReturn = $($R1)
|
|
endif
|
|
|
|
return $(RegistryErrorIndex), $(ButtonReturn)
|
|
|
|
;*************************************************************************
|
|
; end of section CardExistedDialog
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: CreateService
|
|
;
|
|
; PURPOSE: Create the Services area entry for a new product
|
|
;
|
|
; ARGUMENTS: $0 Name of the service (no imbedded blanks, etc.)
|
|
; $1 Display Name of service
|
|
; $2 image path string
|
|
; $3 type of service:
|
|
; system
|
|
; adapter
|
|
; driver
|
|
; transport
|
|
; service
|
|
; serviceshare
|
|
; $4 group, if any or ""
|
|
; $5 dependency **list**, if any or {}
|
|
; $6 ObjectName, usually ""
|
|
; $7 EventMessageFile [Optional]
|
|
; $8 TypeSupported [Optional]
|
|
; $9 EventLog Location[Optional]
|
|
; $10 Error control value [Optional]
|
|
; $11 Event Source name [Optional]
|
|
; $12 ParameterMessageFile [Optional]
|
|
; $13 Services area key [Optional]
|
|
;
|
|
;
|
|
; RETURNS: $R0 Registry error code
|
|
; $R1 Service area key handle
|
|
; $R2 Parameters key handle
|
|
; $R3 Linkage key handle
|
|
;
|
|
; REFERENCES: <list of global or parent variables referenced>
|
|
;
|
|
; MODIFIES: <list of global or parent variables modified>
|
|
;
|
|
; NOTES: If $(!NTN_ScUseRegistry) is != "", then direct Registry
|
|
; access is used in lieu of the Service Controller API
|
|
; wrapper. The Registry is automatically used if the
|
|
; service type is "adapter".
|
|
;
|
|
; The image path format varies for drivers and other
|
|
; services. For drivers of any kind, it's an NT name space
|
|
; name. For services, it's a REG_EXPAND_SZ format Win32 name.
|
|
;
|
|
;
|
|
; CHANGES: DavidHov: 6/11/92. "Groups" is REG_SZ, not REG_EXPAND_SZ
|
|
; Adapters are type=4, start=4.
|
|
; Only services get "ObjectName" value
|
|
;
|
|
;
|
|
;
|
|
;
|
|
;*************************************************************************
|
|
[CreateService]
|
|
read-syms InitBaseVars
|
|
|
|
set CS_NameOfService = $($0)
|
|
set CS_DisplayName = $($1)
|
|
set CS_ImagePath = $($2)
|
|
set CS_TypeOfService = $($3)
|
|
set CS_Group = $($4)
|
|
set CS_Dependencies = $($5)
|
|
set CS_ObjectName = $($6)
|
|
set CS_EventFile = $($7)
|
|
set CS_TypeSupported = $($8)
|
|
ifstr(i) $(CS_TypeSupported) == ""
|
|
set CS_TypeSupported = 7
|
|
endif
|
|
; Set event log location
|
|
set CS_EventLogLocation = $($9)
|
|
ifstr(i) $(CS_EventLogLocation) == ""
|
|
set CS_EventLogLocation = "System"
|
|
endif
|
|
set CS_ErrorControl = $($10)
|
|
ifstr(i) $(CS_ErrorControl) == ""
|
|
set CS_ErrorControl = 1
|
|
endif
|
|
set CS_EventSourceName = $($11)
|
|
ifstr(i) $(CS_EventSourceName) == ""
|
|
set CS_EventSourceName = $(CS_NameOfService)
|
|
endif
|
|
|
|
set CS_ParameterMessageFile = $($12)
|
|
|
|
set CS_KeyServices = $($13)
|
|
|
|
set CS_KeyTempSvc = ""
|
|
set CS_KeySvcManager = ""
|
|
set CS_KeyParameters = ""
|
|
set CS_KeyLinkage = ""
|
|
set CS_UseRegistry = $(!NTN_ScUseRegistry)
|
|
|
|
Debug-Output "UTILITY.INF: [CreateService] entered for "$(CS_NameOfService)
|
|
|
|
Ifstr(i) $(CS_UseRegistry) != "YES"
|
|
Ifstr(i) $(CS_UseRegistry) != "NO"
|
|
Set CS_UseRegistry = "NO"
|
|
Endif
|
|
Endif
|
|
|
|
Ifstr(i) $(CS_Dependencies) == ""
|
|
Set CS_Dependencies = {}
|
|
Endif
|
|
|
|
;
|
|
; Get the base key handle for the services area if not passed in
|
|
;
|
|
Ifstr(i) $(CS_KeyServices) == ""
|
|
Shell "", BaseServiceKey
|
|
set RegistryErrorIndex = $($R0)
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
set RegistryErrorIndex = UNABLE_ACCESS_CONFIGURE_SERVICE
|
|
goto C_S_Return
|
|
endif
|
|
|
|
set CS_KeyServices = $($R1)
|
|
set CS_KeyServicesOpened = $($R1)
|
|
Endif
|
|
|
|
ifstr(i) $(CS_TypeOfService) == "system"
|
|
set TypeValue = 2
|
|
set StartValue = 3
|
|
else-ifstr(i) $(CS_TypeOfService) == "systemstart"
|
|
set TypeValue = 2
|
|
set StartValue = 1
|
|
else-ifstr(i) $(CS_TypeOfService) == "systemauto"
|
|
set TypeValue = 2
|
|
set StartValue = 2
|
|
else-ifstr(i) $(CS_TypeOfService) == "adapter"
|
|
set TypeValue = 4
|
|
set StartValue = 3
|
|
Set CS_UseRegistry = "YES"
|
|
else-ifstr(i) $(CS_TypeOfService) == "kernelauto"
|
|
set TypeValue = 1
|
|
set StartValue = 1
|
|
else-ifstr(i) $(CS_TypeOfService) == "autoserviceshare"
|
|
set TypeValue = 32
|
|
set StartValue = 2
|
|
else-ifstr(i) $(CS_TypeOfService) == "transport"
|
|
set TypeValue = 2
|
|
set StartValue = 3
|
|
else-ifstr(i) $(CS_TypeOfService) == "kernel"
|
|
set TypeValue = 1
|
|
set StartValue = 3
|
|
else-ifstr(i) $(CS_TypeOfService) == "kernelautostart"
|
|
set TypeValue = 1
|
|
set StartValue = 2
|
|
else-ifstr(i) $(CS_TypeOfService) == "kerneldisable"
|
|
set TypeValue = 1
|
|
set StartValue = 4
|
|
else-ifstr(i) $(CS_TypeOfService) == "service"
|
|
set TypeValue = 16
|
|
set StartValue = 3
|
|
else-ifstr(i) $(CS_TypeOfService) == "serviceauto"
|
|
set TypeValue = 16
|
|
set StartValue = 2
|
|
else-ifstr(i) $(CS_TypeOfService) == "servicedisable"
|
|
set TypeValue = 16
|
|
set StartValue = 4
|
|
else-ifstr(i) $(CS_TypeOfService) == "serviceshare"
|
|
set TypeValue = 32
|
|
set StartValue = 3
|
|
else
|
|
Set CS_UseRegistry = "YES"
|
|
Debug-Output "UTILITY.INF: [CreateService] Unrecognized TypeOfService parameter"
|
|
set TypeValue = 4
|
|
set StartValue = 3
|
|
endif
|
|
|
|
Ifint $(TypeValue) > 4
|
|
Ifstr(i) $(CS_ObjectName) == ""
|
|
set CS_ObjectName = "LocalSystem"
|
|
Endif
|
|
Endif
|
|
|
|
OpenRegKey $(CS_KeyServices) "" $(CS_NameOfService) $(MAXIMUM_ALLOWED) +
|
|
CS_KeyTempSvc
|
|
ifstr $(CS_KeyTempSvc) != $(KeyNull)
|
|
; wait a minute.. somebody already installed the driver
|
|
; go to open other keys
|
|
|
|
; check whether it is marked for deletion
|
|
GetRegValue $(CS_KeyTempSvc),"DeleteFlag", DeleteFlagInfo
|
|
set DeleteFlag = *($(DeleteFlagInfo), 4)
|
|
ifint $(DeleteFlag) == 1
|
|
Set RegistryErrorIndex = REBOOT_MACHINE_BEFORE_ADD_ADAPTER
|
|
goto C_S_Return
|
|
endif
|
|
;
|
|
; Device section of the registry already exist.
|
|
; Let the code below to handle it. It will popup a dialog
|
|
; and returns error code.
|
|
;
|
|
endif
|
|
|
|
ifstr(i) $(CS_UseRegistry) == "YES"
|
|
;
|
|
Debug-Output "UTILITY.INF: [CreateService] "$(CS_NameOfService)" using Registry"
|
|
;
|
|
; Create our own service
|
|
;
|
|
ifstr(i) $(CS_KeyTempSvc) == $(KeyNull)
|
|
CreateRegKey $(CS_KeyServices) {$(CS_NameOfService),$(NoTitle),GenericClass} "" $(MAXIMUM_ALLOWED) "" CS_KeyTempSvc
|
|
else
|
|
Debug-Output "UTILITY.INF: service key "$(CS_NameOfService)" already existed"
|
|
Set RegistryErrorIndex = UNABLE_CREATE_CONFIGURE_SERVICE
|
|
CloseRegKey $(CS_KeyTempSvc)
|
|
Goto C_S_Return
|
|
endif
|
|
|
|
Ifstr(i) $(CS_KeyTempSvc) == $(KeyNull)
|
|
|
|
Debug-Output "UTILITY.INF: could not create service key "$(CS_NameOfService)
|
|
Set RegistryErrorIndex = UNABLE_CREATE_CONFIGURE_SERVICE
|
|
CloseRegKey $(CS_KeyTempSvc)
|
|
Goto C_S_Return
|
|
|
|
else
|
|
|
|
set NewValueList = {+
|
|
{Type,$(NoTitle),$(!REG_VT_DWORD),$(TypeValue)},+
|
|
{Start,$(NoTitle),$(!REG_VT_DWORD),$(StartValue)},+
|
|
{ErrorControl,$(NoTitle),$(!REG_VT_DWORD),$(CS_ErrorControl)}+
|
|
}
|
|
|
|
Ifint $(TypeValue) > 4
|
|
Set NewValueList = >($(NewValueList), +
|
|
{ObjectName,$(NoTitle),$(!REG_VT_SZ),$(CS_ObjectName)})
|
|
Endif
|
|
|
|
ifstr(i) $(CS_Group) != ""
|
|
set NewValueList = >($(NewValueList), +
|
|
{Group,$(NoTitle),$(!REG_VT_SZ),$(CS_Group)})
|
|
endif
|
|
|
|
ifstr(i) $(CS_ImagePath) != ""
|
|
set NewValueList = >($(NewValueList), +
|
|
{ImagePath,$(NoTitle),$(!REG_VT_EXPAND_SZ),$(CS_ImagePath)})
|
|
endif
|
|
|
|
ifstr(i) $(CS_Dependencies) != ""
|
|
ifstr(i) $(CS_Dependencies) != {}
|
|
set NewValueList = >($(NewValueList), +
|
|
{Dependencies,$(NoTitle),$(!REG_VT_MULTI_SZ),$(CS_Dependencies)})
|
|
endif
|
|
endif
|
|
|
|
Shell "", AddValueList, $(CS_KeyTempSvc), $(NewValueList)
|
|
|
|
set RegistryErrorIndex = $($R0)
|
|
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
Debug-Output "Registry error: Add value list"
|
|
endif
|
|
|
|
endif
|
|
else
|
|
Debug-Output "UTILITY.INF: [CreateService] "$(CS_NameOfService)" using CreateService() wrapper"
|
|
;
|
|
; Call NCPA to create service key.
|
|
;
|
|
Set FLibraryErrCtl = 1
|
|
LibraryProcedure CS_CreateResult $(!NCPA_HANDLE), CPlSetup, $(!STF_HWND), CREATESVC,+
|
|
$(CS_NameOfService), $(CS_DisplayName), $(StartValue), $(TypeValue), $(CS_ErrorControl),+
|
|
$(CS_ImagePath), $(CS_Group),$(CS_Dependencies),$(CS_ObjectName)
|
|
Set FLibraryErrCtl = 0
|
|
;
|
|
; Check the return code
|
|
;
|
|
Set CS_CreateError = *($(CS_CreateResult),1)
|
|
Ifint $(CS_CreateError) != 0
|
|
Debug-Output "UTILITY.INF: CreateService wrapper failed, error: "$(CS_CreateResult)
|
|
;
|
|
; See if the error is special
|
|
;
|
|
Ifint $(CS_CreateError) == 1073
|
|
Set RegistryErrorIndex = SERVICE_ALREADY_EXISTS
|
|
Else-ifint $(CS_CreateError) == 1072
|
|
Set RegistryErrorIndex = SERVICE_MARKED_FOR_DELETE
|
|
Else
|
|
Set RegistryErrorIndex = UNABLE_CREATE_CONFIGURE_SERVICE
|
|
Endif
|
|
CloseRegKey $(CS_KeyTempSvc)
|
|
Goto C_S_Return
|
|
Endif
|
|
;
|
|
; Now open the key which should have been created by the service controller
|
|
;
|
|
OpenRegKey $(CS_KeyServices) "" $(CS_NameOfService) $(MAXIMUM_ALLOWED) CS_KeyTempSvc
|
|
ifstr $(CS_KeyTempSvc) == $(KeyNull)
|
|
Debug-Output "UTILITY.INF: unable to open new service key"
|
|
set RegistryErrorIndex = UNABLE_CREATE_CONFIGURE_SERVICE
|
|
CloseRegKey $(CS_KeyTempSvc)
|
|
Goto C_S_Return
|
|
endif
|
|
endif
|
|
|
|
;
|
|
; Open or Create the Parameters subkey
|
|
;
|
|
CreateRegKey $(CS_KeyTempSvc) {"Parameters",$(NoTitle),GenericClass} "" $(MAXIMUM_ALLOWED) "" CS_KeyParameters
|
|
ifstr $(CS_KeyParameters) == $(KeyNull)
|
|
OpenRegKey $(CS_KeyTempSvc) "" "Parameters" $(MAXIMUM_ALLOWED) +
|
|
CS_KeyParameters
|
|
endif
|
|
|
|
Ifstr $(CS_KeyParameters) == $(KeyNull)
|
|
set RegistryErrorIndex = UNABLE_CREATE_SERVICE_SUBKEY
|
|
CloseRegKey $(CS_KeyTempSvc)
|
|
goto C_S_Return
|
|
endif
|
|
|
|
set RegistryErrorIndex = NO_ERROR
|
|
;
|
|
; Open or Create the Linkage subkey
|
|
;
|
|
CreateRegKey $(CS_KeyTempSvc) {"Linkage",$(NoTitle),GenericClass} "" $(MAXIMUM_ALLOWED) "" CS_KeyLinkage
|
|
Ifstr $(CS_KeyLinkage) == $(KeyNull)
|
|
OpenRegKey $(CS_KeyTempSvc) "" "Linkage" $(MAXIMUM_ALLOWED) CS_KeyLinkage
|
|
Endif
|
|
|
|
Ifstr $(CS_KeyLinkage) == $(KeyNull)
|
|
set RegistryErrorIndex = UNABLE_CREATE_SERVICE_SUBKEY
|
|
CloseRegKey $(CS_KeyTempSvc)
|
|
goto C_S_Return
|
|
endif
|
|
;
|
|
; Open or Create the Linkage\Disabled subkey
|
|
;
|
|
CreateRegKey $(CS_KeyLinkage) {"Disabled",$(NoTitle),GenericClass} "" $(MAXIMUM_ALLOWED) "" CS_KeyDisabled
|
|
Ifstr $(CS_KeyDisabled) == $(KeyNull)
|
|
OpenRegKey $(CS_KeyLinkage) "" "Disabled" $(MAXIMUM_ALLOWED) CS_KeyDisabled
|
|
Endif
|
|
|
|
Ifstr $(CS_KeyDisabled) == $(KeyNull)
|
|
set RegistryErrorIndex = UNABLE_CREATE_SERVICE_SUBKEY
|
|
CloseRegKey $(CS_KeyTempSvc)
|
|
CloseRegKey $(CS_KeyLinkage)
|
|
goto C_S_Return
|
|
endif
|
|
CloseRegKey $(CS_KeyDisabled)
|
|
|
|
|
|
;
|
|
; Create Eventlog information
|
|
;
|
|
ifstr(i) $(CS_EventFile) != ""
|
|
OpenRegKey $(!REG_H_LOCAL) "" "SYSTEM\CurrentControlSet\Services\EventLog\"$(CS_EventLogLocation) $(MAXIMUM_ALLOWED) CS_KeyEventLog
|
|
Ifstr $(CS_KeyEventLog) == $(KeyNull)
|
|
; cannot open eventlog
|
|
debug-output "Cannot open eventlog key"
|
|
set RegistryErrorIndex = UNABLE_OPEN_EVENTLOG_SUBKEY
|
|
CloseRegKey $(CS_KeyTempSvc)
|
|
CloseRegKey $(CS_KeyParameters)
|
|
CloseRegKey $(CS_KeyLinkage)
|
|
goto C_S_Return
|
|
else
|
|
; set up the service key
|
|
CreateRegKey $(CS_KeyEventLog) {$(CS_EventSourceName),$(NoTitle),GenericClass} "" $(MAXIMUM_ALLOWED) "" CS_KeyService
|
|
ifstr(i) $(CS_KeyService) == ""
|
|
OpenRegKey $(CS_KeyEventLog) "" $(CS_EventSourceName) $(MAXIMUM_ALLOWED) CS_KeyService
|
|
endif
|
|
|
|
Ifstr $(CS_KeyService) != $(KeyNull)
|
|
; create the EventMessageFile and TypeSupported fields
|
|
SetRegValue $(CS_KeyService) {EventMessageFile,$(NoTitle),$(!REG_VT_EXPAND_SZ),$(CS_EventFile)}
|
|
SetRegValue $(CS_KeyService) {TypesSupported,$(NoTitle),$(!REG_VT_DWORD),$(CS_TypeSupported)}
|
|
ifstr(i) $(CS_ParameterMessageFile) != ""
|
|
SetRegValue $(CS_KeyService) {ParameterMessageFile,$(NoTitle),$(!REG_VT_EXPAND_SZ),$(CS_ParameterMessageFile)}
|
|
endif
|
|
CloseRegKey $(CS_KeyService)
|
|
endif
|
|
Endif
|
|
endif
|
|
|
|
;
|
|
; Return the keys and error codes
|
|
;
|
|
C_S_Return = +
|
|
; Only close the services key if it was opened in this routine.
|
|
Ifstr $(CS_KeyServicesOpened) != $(KeyNull)
|
|
CloseRegKey $(CS_KeyServices)
|
|
endif
|
|
return $(RegistryErrorIndex), $(CS_KeyTempSvc), $(CS_KeyParameters), $(CS_KeyLinkage)
|
|
|
|
;*************************************************************************
|
|
; end of section CreateService
|
|
;*************************************************************************
|
|
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: AssignAdapterNumber
|
|
;
|
|
; PURPOSE: Enumerate the netcards, and return a numeric value which
|
|
; is unused.
|
|
;
|
|
; ARGUMENTS: $0 - Optional - NetworkCardKey - for performance
|
|
; $1 - Optional - AdapterNumber to start with - for performance
|
|
;
|
|
; RETURNS: $R0 Regisitry Error Code
|
|
; $R1 Numeric value to be use for new adapter;
|
|
; (1,2,3..)
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;
|
|
;*************************************************************************
|
|
[AssignAdapterNumber]
|
|
read-syms InitBaseVars
|
|
|
|
set AA_KeyNetcards = $($0)
|
|
ifstr $($1) == ""
|
|
set AA_AdapterNumber = 1
|
|
else
|
|
set AA_AdapterNumber = $($1)
|
|
endif
|
|
set AA_KeyNetcards = ""
|
|
set AA_KeyTemp = ""
|
|
set RegistryErrorIndex = NO_ERROR
|
|
|
|
Debug-Output "[AssignAdapterNumber] starting with "$(AA_AdapterNumber)
|
|
|
|
Ifstr(i) $(AA_KeyNetcards) == $(KeyNull)
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(NetworkCardKeyName) $(MAXIMUM_ALLOWED) AA_KeyNetcards
|
|
set AA_KeyNetcardsOpened = $(AA_KeyNetcards)
|
|
endif
|
|
|
|
Ifstr $(AA_KeyNetcards) == $(KeyNull)
|
|
set RegistryErrorIndex = UNABLE_OPEN_NETWORKCARD_SECTION
|
|
goto A_A_Return
|
|
endif
|
|
;
|
|
; Loop to find an unused adapter number
|
|
;
|
|
A_A_TryAgain = +
|
|
ifint $(AA_AdapterNumber) < 10
|
|
set Tmp_Zero_AdapterNumber = "0"$(AA_AdapterNumber)
|
|
OpenRegKey $(AA_KeyNetcards) "" $(Tmp_Zero_AdapterNumber) $(MAXIMUM_ALLOWED) AA_Zero_KeyTemp
|
|
ifstr(i) $(AA_Zero_KeyTemp) != ""
|
|
CloseRegKey $(AA_Zero_KeyTemp)
|
|
goto Next_Number
|
|
endif
|
|
endif
|
|
|
|
set Tmp_AA_AdapterNumber = $(AA_AdapterNumber)
|
|
|
|
OpenRegKey $(AA_KeyNetcards) "" $(Tmp_AA_AdapterNumber) $(MAXIMUM_ALLOWED) AA_KeyTemp
|
|
|
|
Ifstr $(AA_KeyTemp) == $(KeyNull)
|
|
Goto A_A_Found
|
|
Endif
|
|
|
|
CloseRegKey $(AA_KeyTemp)
|
|
|
|
Next_Number = +
|
|
|
|
Set AA_KeyTemp = $(KeyNull)
|
|
Set-add AA_AdapterNumber = $(AA_AdapterNumber),1
|
|
Goto A_A_TryAgain
|
|
|
|
A_A_Found =+
|
|
CloseRegKey $(AA_KeyNetcardsOpened)
|
|
|
|
A_A_Return = +
|
|
return $(RegistryErrorIndex) $(AA_AdapterNumber)
|
|
|
|
;*************************************************************************
|
|
; end of section AssignAdapterNumber
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: InstallNetcard
|
|
;
|
|
; PURPOSE: Create a new HARDWARE\Netcard\(n) area in the Registry
|
|
;
|
|
; ARGUMENTS: $0 Name if the INF file
|
|
; $1 Optional - Netcards Area key
|
|
; $2 Optional - net card number to start with
|
|
;
|
|
; RETURNS: $R0 Registry error code
|
|
; $R1 Netcard\(n) key handle
|
|
; $R2 numeric index of netcard (n)
|
|
; $R3 NetRules key handle
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;
|
|
;*************************************************************************
|
|
[InstallNetcard]
|
|
read-syms InitBaseVars
|
|
|
|
set IN_Infname = $($0)
|
|
set IN_KeyNetcardsArea = $($1)
|
|
set IN_CardNumber = $($2)
|
|
set IN_KeyNetcard = ""
|
|
set IN_KeyNetRules = ""
|
|
;
|
|
; Assign a number to this network card and create its key
|
|
;
|
|
Shell "" AssignAdapterNumber $(IN_KeyNetcardsArea) $(IN_CardNumber)
|
|
|
|
set RegistryErrorIndex = $($R0)
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
goto I_N_Return
|
|
endif
|
|
|
|
set IN_CardNumber = $($R1)
|
|
|
|
CreateRegKey $(!REG_H_LOCAL) {$(NetworkCardKeyName)\$(IN_CardNumber),$(NoTitle),GenericClass} +
|
|
"" $(MAXIMUM_ALLOWED) "" IN_KeyNetcard
|
|
|
|
Ifstr $(IN_KeyNetcard) == $(KeyNull)
|
|
set RegistryErrorIndex = UNABLE_CREATE_NETCARD_CONFIGURATION
|
|
goto I_N_Return
|
|
endif
|
|
;
|
|
; Create the NetRules key
|
|
;
|
|
CreateRegKey $(IN_KeyNetcard) {NetRules,$(NoTitle),GenericClass} "" $(MAXIMUM_ALLOWED) "" IN_KeyNetRules
|
|
Ifstr $(IN_KeyNetRules) == $(KeyNull)
|
|
set RegistryErrorIndex = UNABLE_CREATE_NETRULES_KEY
|
|
goto I_N_Return
|
|
endif
|
|
;
|
|
; Set the "Infname" value if non-null; reduce it if it's in %SystemRoot%
|
|
;
|
|
Ifstr $(IN_Infname) != ""
|
|
Shell "", ReduceInfPath, $(IN_Infname)
|
|
SetRegValue $(IN_KeyNetRules) {InfName,$(NoTitle),$(!REG_VT_SZ),$($R0)}
|
|
endif
|
|
|
|
set RegistryErrorIndex = NO_ERROR
|
|
|
|
I_N_Return = +
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
Debug-Output "UTILITY.INF: [InstallNetcard]: "$(RegistryErrorIndex)
|
|
Ifstr $(IN_KeyNetRules) != $(KeyNull)
|
|
CloseRegKey $(IN_KeyNetRules)
|
|
set IN_KeyNetrules = ''
|
|
endif
|
|
;BUGBUG DeleteRegTree $(IN_KeyNetcard)
|
|
set IN_KeyNetcard = ""
|
|
endif
|
|
return $(RegistryErrorIndex), $(IN_KeyNetcard), $(IN_CardNumber), $(IN_KeyNetRules)
|
|
|
|
;*************************************************************************
|
|
; end of section InstallNetcard
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: LinkToService
|
|
;
|
|
; PURPOSE: Link a software or hardware component to its
|
|
; corresponding service area entry
|
|
;
|
|
; ARGUMENTS: $0 Registry key handle to primary component key
|
|
; $1 Name of service (no imbedded blanks, etc.)
|
|
;
|
|
; RETURNS: $R0 Registry error code
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;
|
|
;*************************************************************************
|
|
[LinkToService]
|
|
|
|
read-syms InitBaseVars
|
|
|
|
SetRegValue $($0) {ServiceName,$(NoTitle),$(!REG_VT_SZ),$($1)}
|
|
|
|
L_S_Return = +
|
|
return $(RegistryErrorIndex)
|
|
|
|
;*************************************************************************
|
|
; end of section LinkToService
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: IncrementRefCount
|
|
;
|
|
; PURPOSE: Increment the reference counter in the registry
|
|
;
|
|
; ARGUMENTS: $0 Registry key name
|
|
;
|
|
; RETURNS: $R0 Registry error code
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;
|
|
;*************************************************************************
|
|
[IncrementRefCount]
|
|
read-syms InitBaseVars
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $($0) $(MAXIMUM_ALLOWED) SoftwareKey
|
|
|
|
Ifstr $(SoftwareKey) == $(KeyNull)
|
|
Debug-Output "UTILITY.INF: could not open Software base key"
|
|
set RegistryErrorIndex = UNABLE_ACCESS_CONFIGURE_SERVICE
|
|
goto IncrementRefCount_Return
|
|
endif
|
|
|
|
GetRegValue $(SoftwareKey),"RefCount", RefCountInfo
|
|
set RefCount = *($(RefCountInfo), 4)
|
|
Set-add RefCount = $(RefCount),1
|
|
SetRegValue $(SoftwareKey) {RefCount,$(NoTitle),$(!REG_VT_DWORD),$(RefCount)}
|
|
CloseRegKey $(SoftwareKey)
|
|
|
|
IncrementRefCount_Return = +
|
|
return $(RegistryErrorIndex)
|
|
|
|
;*************************************************************************
|
|
; end of section IncrementRefCount
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: DecrementRefCount
|
|
;
|
|
; PURPOSE: Decrement the reference counter in the registry
|
|
;
|
|
; ARGUMENTS: $0 Registry key name
|
|
;
|
|
; RETURNS: $R0 Registry error code
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;
|
|
;*************************************************************************
|
|
[DecrementRefCount]
|
|
read-syms InitBaseVars
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $($0) $(MAXIMUM_ALLOWED) SoftwareKey
|
|
|
|
Ifstr $(SoftwareKey) == $(KeyNull)
|
|
Debug-Output "UTILITY.INF: could not open Software base key"
|
|
set RegistryErrorIndex = UNABLE_ACCESS_CONFIGURE_SERVICE
|
|
goto DecrementRefCount_Return
|
|
endif
|
|
|
|
GetRegValue $(SoftwareKey),"RefCount", RefCountInfo
|
|
set RefCount = *($(RefCountInfo), 4)
|
|
ifint $(RefCount) == 0
|
|
; something wrong
|
|
goto DecrementRefCount_Return
|
|
endif
|
|
Set-sub RefCount = $(RefCount),1
|
|
SetRegValue $(SoftwareKey) {RefCount,$(NoTitle),$(!REG_VT_DWORD),$(RefCount)}
|
|
CloseRegKey $(SoftwareKey)
|
|
|
|
DecrementRefCount_Return = +
|
|
return $(RegistryErrorIndex)
|
|
|
|
;*************************************************************************
|
|
; end of section DecrementRefCount
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: IsRefCountEqual0
|
|
;
|
|
; PURPOSE: check the reference counter in the registry is equal to 0 or
|
|
; not
|
|
;
|
|
; ARGUMENTS: $0 Registry key name
|
|
;
|
|
; RETURNS: $R0 Registry error code
|
|
; $R1 0 - if ref count != 0
|
|
; 1 - if ref count = 0
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;
|
|
;*************************************************************************
|
|
[IsRefCountEqualZero]
|
|
read-syms InitBaseVars
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $($0) $(MAXIMUM_ALLOWED) SoftwareKey
|
|
|
|
Ifstr $(SoftwareKey) == $(KeyNull)
|
|
Debug-Output "UTILITY.INF: could not open Software base key"
|
|
set RegistryErrorIndex = UNABLE_ACCESS_CONFIGURE_SERVICE
|
|
set RefCountEqualZero = 1
|
|
goto IsRefCountEqualZero_Return
|
|
endif
|
|
|
|
GetRegValue $(SoftwareKey),"RefCount", RefCountInfo
|
|
Ifint $(RegLastError) != $(!REG_ERROR_SUCCESS)
|
|
set RefCount = 0
|
|
else
|
|
set RefCount = *($(RefCountInfo), 4)
|
|
endif
|
|
Ifint $(RefCount) == 0
|
|
set RefCountEqualZero = 1
|
|
else
|
|
set RefCountEqualZero = 0
|
|
endif
|
|
CloseRegKey $(SoftwareKey)
|
|
|
|
IsRefCountEqualZero_Return = +
|
|
return $(RegistryErrorIndex) $(RefCountEqualZero)
|
|
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: FindService
|
|
;
|
|
; PURPOSE: Given a hardware or software component key handle,
|
|
; return a key handle to the corresponding Service entry
|
|
;
|
|
; ARGUMENTS: $0 Registry key handle to primary component
|
|
; $1 type of component (adapter, etc.)
|
|
;
|
|
; RETURNS: $R0 Registry error code
|
|
; $R1 Registry key handle for Service area
|
|
; $R2 Registry key handle for Parameters subkey
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;
|
|
;*************************************************************************
|
|
[FindService]
|
|
read-syms InitBaseVars
|
|
|
|
set FS_KeyThisService = ""
|
|
set FS_KeyParameters = ""
|
|
set FS_KeyComponent = $($0)
|
|
set FS_TypeComponent = $($1)
|
|
|
|
Shell "", BaseServiceKey
|
|
|
|
set FS_KeyServices = $($R1)
|
|
set RegistryErrorIndex = $($R0)
|
|
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
goto F_S_Return
|
|
endif
|
|
;
|
|
; Obtain the all the values for the component key.
|
|
;
|
|
EnumRegValue $(FS_KeyComponent) FS_ValueList
|
|
|
|
; BUGBUG: Check RegLastError
|
|
|
|
set FS_SvcName = ""
|
|
|
|
ForListDo $(FS_ValueList)
|
|
set FS_ValueName = *($($),1)
|
|
Ifstr(i) $(FS_ValueName) == ServiceName
|
|
set FS_SvcName = *($($),4)
|
|
goto F_S_Break1
|
|
endif
|
|
EndForListDo
|
|
F_S_Break1 = +
|
|
|
|
Ifstr $(FS_SvcName) == $(KeyNull)
|
|
set RegistryErrorIndex = CANNOT_FIND_COMPONENT_SERVICE
|
|
goto F_S_Return
|
|
endif
|
|
|
|
OpenRegKey $(FS_KeyServices) "" $(FS_SvcName) $(MAXIMUM_ALLOWED) FS_KeyThisService
|
|
Ifstr $(FS_KeyThisService) == $(KeyNull)
|
|
set RegistryErrorIndex = CANNOT_FIND_COMPONENT_SERVICE
|
|
goto F_S_Return
|
|
endif
|
|
|
|
OpenRegKey $(FS_KeyThisService) "" "Parameters" $(MAXIMUM_ALLOWED) FS_KeyParameters
|
|
Ifstr $(FS_KeyParameters) == $(KeyNull)
|
|
set RegistryErrorIndex = CANNOT_FIND_COMPONENT_SERVICE
|
|
goto F_S_Return
|
|
endif
|
|
|
|
F_S_Return = +
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
Ifstr $(FS_KeyParameters) != $(KeyNull)
|
|
CloseRegKey $(FS_KeyParameters)
|
|
endif
|
|
Ifstr $(FS_KeyThisService) != $(KeyNull)
|
|
CloseRegKey $(FS_KeyThisService)
|
|
endif
|
|
endif
|
|
return $(RegistryErrorIndex), $(FS_KeyThisService) $(FS_KeyParameters)
|
|
|
|
;*************************************************************************
|
|
; end of section FindService
|
|
;*************************************************************************
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: GetServiceParameters
|
|
;
|
|
; PURPOSE: Given a component key and type, return a list of
|
|
; all its current parameters
|
|
;
|
|
; ARGUMENTS: $0 Registry key handle to primary component
|
|
; $1 type of component (adapter, etc.)
|
|
;
|
|
; RETURNS: $R0 Registry error code
|
|
; $R1 Registry key handle for Service area
|
|
; $R2 Registry key handle for Parameters subkey
|
|
; $R3 Value list of all values under Parameters subkey
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
[GetServiceParameters]
|
|
read-syms InitBaseVars
|
|
set GP_KeyComponent = $($0)
|
|
set GP_KeyService = ""
|
|
set GP_KeyParameters = ""
|
|
set GP_ValueList = {}
|
|
|
|
FindService $(GP_KeyComponent) $($1)
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
goto G_P_Return
|
|
endif
|
|
|
|
set GP_KeyService = $($R1)
|
|
set GP_KeyParameters = $($R2)
|
|
|
|
EnumRegValue $(GP_KeyParameters) GP_ValueList
|
|
|
|
G_P_Return = +
|
|
return $(RegistryErrorIndex) $(GP_KeyService) $(GP_KeyParameters) $(GP_ValueList)
|
|
|
|
;*************************************************************************
|
|
; end of section sectionname
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: AddSoftwareComponent
|
|
;
|
|
; PURPOSE: Adds all the Registry information necessary for
|
|
; a new software component. This involves creating
|
|
; the SOFTWARE area and the SERVICE area.
|
|
;
|
|
; ARGUMENTS: $0 name of Manufacturer
|
|
; $1 name of Product
|
|
; $2 service name to use (no imbedded blanks, etc.)
|
|
; $3 Display Name for service
|
|
; $4 full path name to the INF file for configuration
|
|
; $5 ImagePath
|
|
; $6 type of the software,
|
|
; see [CreateService] for complete list
|
|
; $7 service order group, if any or ""
|
|
; $8 dependency **list**, if any or {}
|
|
; $9 ObjectName. if "", it will set to "LocalSystem"
|
|
; $10 EventMessageFile [optional]
|
|
; $11 TypeSupported [optional]
|
|
; $12 event log location [optional]
|
|
; $13 error control value [optional]
|
|
; $14 event log source [optional]
|
|
; $15 ParameterMessageFile[optional]
|
|
;
|
|
; RETURNS: $R0 error code or zero if no error
|
|
; $R1 Registry key variable for
|
|
; SOFTWARE\Manufacturer\Product\Version key
|
|
; $R2 Registry key variable for
|
|
; SOFTWARE\...\NetRules
|
|
; $R3 Registry key handle for Services key
|
|
; $R4 "Parameters" key handle for Services area
|
|
; $R5 "Linkage" key handle for Services area
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
[AddSoftwareComponent]
|
|
read-syms InitBaseVars
|
|
|
|
set AS_MfgName = $($0)
|
|
set AS_ProdName = $($1)
|
|
set AS_SvcName = $($2)
|
|
set AS_DisplayName = $($3)
|
|
set AS_Infname = $($4)
|
|
set AS_ImagePath = $($5)
|
|
set AS_ServiceType = $($6)
|
|
set AS_Group = $($7)
|
|
set AS_Dependencies = $($8)
|
|
set AS_ObjectName = $($9)
|
|
set AS_EventFile = $($10)
|
|
set AS_TypeSupported = $($11)
|
|
set AS_EventLocation = $($12)
|
|
set AS_ErrorCtlValue = $($13)
|
|
set AS_EventSource = $($14)
|
|
set AS_ParameterMessageFile = $($15)
|
|
set AS_KeyServicesArea = $($16)
|
|
set AS_KeyVersion = ""
|
|
set AS_KeyNetRules = ""
|
|
set AS_KeyService = ""
|
|
set AS_KeyParameters = ""
|
|
set AS_KeyLinkage = ""
|
|
|
|
;
|
|
; Create the Service entry for this product
|
|
;
|
|
Shell "", CreateService,$(AS_SvcName),$(AS_DisplayName),$(AS_ImagePath),+
|
|
$(AS_ServiceType),$(AS_Group),$(AS_Dependencies),$(AS_ObjectName),+
|
|
$(AS_EventFile),$(AS_TypeSupported),$(AS_EventLocation),+
|
|
$(AS_ErrorCtlValue),$(AS_EventSource),$(AS_ParameterMessageFile),+
|
|
$(AS_KeyServicesArea)
|
|
|
|
set RegistryErrorIndex = $($R0)
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
goto A_S_Return
|
|
endif
|
|
|
|
set AS_KeyService = $($R1)
|
|
set AS_KeyParameters = $($R2)
|
|
set AS_KeyLinkage = $($R3)
|
|
;
|
|
; Service area is created. Create the software area and link them
|
|
;
|
|
Shell "", InstallSoftwareProduct, $(AS_MfgName), $(AS_ProdName), $(AS_Infname)
|
|
|
|
set RegistryErrorIndex = $($R0)
|
|
Ifstr(i) $(RegistryErrorIndex) == NO_ERROR
|
|
set AS_KeyVersion = $($R1)
|
|
set AS_KeyNetRules = $($R2)
|
|
Shell "", LinkToService, $(AS_KeyVersion), $(AS_SvcName), service
|
|
|
|
set RegistryErrorIndex = $($R0)
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
goto A_S_Return
|
|
endif
|
|
|
|
;
|
|
; Add Reference Counter
|
|
;
|
|
GetRegValue $(AS_KeyVersion),"RefCount", RefCountInfo
|
|
Ifint $(RegLastError) != $(!REG_ERROR_SUCCESS)
|
|
; no RefCount variable
|
|
SetRegValue $(AS_KeyVersion) {RefCount,$(NoTitle),$(!REG_VT_DWORD),0}
|
|
endif
|
|
|
|
endif
|
|
|
|
A_S_Return = +
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
Ifstr $(AS_KeyNetRules) != $(KeyNull)
|
|
CloseRegKey $(AS_KeyNetRules)
|
|
endif
|
|
Ifstr $(AS_KeyParameters) != $(KeyNull)
|
|
CloseRegKey $(AS_KeyParameters)
|
|
endif
|
|
Ifstr $(AS_KeyLinkage) != $(KeyNull)
|
|
CloseRegKey $(AS_KeyLinkage)
|
|
endif
|
|
Ifstr $(AS_KeyVersion) != $(KeyNull)
|
|
CloseRegKey $(AS_KeyVersion)
|
|
Set AS_ProdKeyName = $(!NTN_SoftwareBase)"\"$(AS_MfgName)"\"$(AS_ProdName)
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(AS_ProdKeyName) $(MAXIMUM_ALLOWED) AS_KeyProduct
|
|
Ifstr(i) $(AS_KeyProduct) != $(KeyNull)
|
|
DeleteRegKey $(AS_KeyProduct) "CurrentVersion"
|
|
CloseRegKey $(AS_KeyProduct)
|
|
Endif
|
|
Endif
|
|
Ifstr $(AS_KeyService) != $(KeyNull)
|
|
Debug-Output "UTILITY.INF: DeleteRegTree Service Key"
|
|
;DeleteRegTree $(AS_KeyService) ""
|
|
endif
|
|
|
|
set AS_KeyVersion = ""
|
|
set AS_KeyNetRules = ""
|
|
set AS_KeyService = ""
|
|
set AS_KeyParameters = ""
|
|
set AS_KeyLinkage = ""
|
|
|
|
endif
|
|
return $(RegistryErrorIndex), $(AS_KeyVersion), $(AS_KeyNetRules), $(AS_KeyService),+
|
|
$(AS_KeyParameters), $(AS_KeyLinkage)
|
|
|
|
;*************************************************************************
|
|
; end of section AddSoftwareComponent
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: AddHardwareComponent
|
|
;
|
|
; PURPOSE: Adds all the Registry information necessary for
|
|
; a new network adapater card
|
|
;
|
|
; ARGUMENTS: $0 service name to use (no imbedded blanks, etc.).
|
|
; This name will have the numeric value from
|
|
; InstallNetCard appended to it for uniqueness.
|
|
; $1 INF name for this adapter
|
|
; $2 Driver name in software section
|
|
; $3 Optional - Services area Key (for performance if an
|
|
; INF will be calling this routine many times)
|
|
; $4 Optional - Netcards area Key (for performance if an
|
|
; INF will be calling this routine many times)
|
|
; $5 Optional - number of netcard to start with when looking
|
|
; for the next empty slot. For performance, and INF which
|
|
; is adding many adapters can pass in the value returned
|
|
; for adapter number from the last AddHardwareComponent
|
|
; call
|
|
;
|
|
;
|
|
; RETURNS: $R0 Registry error code or zero if no error
|
|
; $R1 Registry key variable for HARDWARE\Netcard\(n)
|
|
; $R2 Registry key variable for HARDWARE\Netcard\(n)\\NetRules
|
|
; $R3 Registry key handle for <service>\Parameters key
|
|
; $R4 Adapter number assigned to adapter
|
|
; $R5 Service name generated by combining svc name with
|
|
; adapter number
|
|
;
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
[AddHardwareComponent]
|
|
|
|
read-syms InitBaseVars
|
|
|
|
set AH_SvcName = $($0)
|
|
set AH_Infname = $($1)
|
|
set AH_SoftwareName = $($2)
|
|
set AH_KeyServicesArea = $($3)
|
|
set AH_KeyNetcardsArea = $($4)
|
|
set AH_AdapNum = $($5)
|
|
set AH_KeyNetcard = ""
|
|
set AH_KeyNetRules = ""
|
|
set AH_KeyService = ""
|
|
set AH_KeyParameters = ""
|
|
;
|
|
; Create the HARDWARE\Netcard entry for this adapter
|
|
;
|
|
Shell "", InstallNetcard, $(AH_Infname) $(AH_KeyNetcardsArea) $(AH_AdapNum)
|
|
|
|
set RegistryErrorIndex = $($R0)
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
Debug-Output "UTILITY.INF: [AddHardwareComponent] InstallNetcard returned: "$(RegistryErrorIndex)
|
|
goto A_H_Return
|
|
endif
|
|
|
|
set AH_KeyNetcard = $($R1)
|
|
set AH_AdapNum = $($R2)
|
|
set AH_SvcName = $(AH_SvcName)$(AH_AdapNum)
|
|
set AH_KeyNetRules = $($R3)
|
|
;
|
|
; Create the SERVICES entry for this adapter; no binary path, no group,
|
|
; no dependencies.
|
|
;
|
|
Shell "", CreateService, $(AH_SvcName), "", "", "adapter","",{},"","","","","","","", $(AH_KeyServicesArea)
|
|
|
|
set RegistryErrorIndex = $($R0)
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
Debug-Output "UTILITY.INF: CreateService returned "$(RegistryErrorIndex)
|
|
goto A_H_Return
|
|
endif
|
|
|
|
CloseRegKey $($R1)
|
|
set AH_KeyParameters = $($R2)
|
|
CloseRegKey $($R3)
|
|
|
|
;
|
|
; Link the Netcard entry to the Service created
|
|
;
|
|
Shell "", LinkToService, $(AH_KeyNetcard), $(AH_SvcName)
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
Debug-Output "UTILITY.INF: [AddHardwareComponent] LinkToService returned "$(RegistryErrorIndex)
|
|
goto A_H_Return
|
|
endif
|
|
|
|
;
|
|
; Add the reference counter in the driver section
|
|
;
|
|
Shell "", IncrementRefCount, $(AH_SoftwareName)
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
Debug-Output "UTILITY.INF: [AddHardwareComponent] IncrementRefCount returned "$(RegistryErrorIndex)
|
|
goto A_H_Return
|
|
endif
|
|
|
|
A_H_Return = +
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
Debug-Output "UTILITY.INF: [AddHardwareComponent] returning error: "$(RegistryErrorIndex)
|
|
Ifstr(i) $(AH_KeyNetRules) != $(KeyNull)
|
|
CloseRegKey $(AH_KeyNetRules)
|
|
Endif
|
|
Ifstr(i) $(AH_KeyNetcard) != $(KeyNull)
|
|
; Let the RemoveHardware handle it
|
|
;DeleteRegTree $(AH_KeyNetcard) ""
|
|
Endif
|
|
set AH_KeyNetRules = ""
|
|
set AH_KeyNetcard = ""
|
|
endif
|
|
|
|
return $(RegistryErrorIndex), $(AH_KeyNetcard), $(AH_KeyNetRules), $(AH_KeyParameters),+
|
|
$(AH_AdapNum), $(AH_SvcName)
|
|
|
|
;*************************************************************************
|
|
; end of section AddHardwareComponent
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: MCAFindBus
|
|
;
|
|
; PURPOSE: Find adpater(s) location
|
|
;
|
|
; ARGUMENTS: $0 The least signifiance byte of the device ID
|
|
; $1 The most signifiance byte of the device ID
|
|
;
|
|
;
|
|
; RETURNS: $R0 Registry error code or zero if no error
|
|
; $R1 The list of adapter location
|
|
; {{bus0,slot0},{bus1,slot1},{bus2,slot2}...{busk,slotk}}
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
|
|
[MCAFindBus]
|
|
read-syms InitBaseVars
|
|
set RegistryErrorIndex = NO_ERROR
|
|
|
|
set MultifunctionAdapter = "HARDWARE\Description\System\MultifunctionAdapter"
|
|
set InfoList = {}
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(MultifunctionAdapter) $(MAXIMUM_ALLOWED) KeyMultiAdapter
|
|
|
|
Ifstr $(KeyMultiAdapter) == $(KeyNull)
|
|
goto MCAFindBus_return
|
|
endif
|
|
|
|
EnumRegKey $(KeyMultiAdapter) BusList
|
|
|
|
Debug-Output "Buslist"
|
|
Debug-Output $(BusList)
|
|
|
|
ForListDo $(BusList)
|
|
set BusNum = *($($),1)
|
|
set RegName = $(MultifunctionAdapter)"\"$(BusNum)
|
|
Debug-Output "BusNum"
|
|
Debug-Output $(BusNum)
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(RegName) $(MAXIMUM_ALLOWED) KeyBus
|
|
|
|
ifstr $(KeyBus) != $(KeyNull)
|
|
GetRegValue $(KeyBus),"Configuration Data",ConfigData
|
|
ifstr $(ConfigData) != $(KeyNull)
|
|
set CardInfo = *($(ConfigData), 4 )
|
|
;
|
|
; Skip the header and jump to data position 33
|
|
;
|
|
set Position = 33
|
|
set SlotNum = 1
|
|
QueryListSize ListSize $(CardInfo)
|
|
Loop1 =+
|
|
ifint $(Position) < $(ListSize)
|
|
set-add NextByte = $(Position), 1
|
|
ifint *($(CardInfo), $(Position)) == $($0)
|
|
ifint *($(CardInfo), $(NextByte)) == $($1)
|
|
;
|
|
; Set up the hardware
|
|
;
|
|
LibraryProcedure RealBusNum, $(!LIBHANDLE), GetMCABusInformation, $(KeyBus), "Configuration Data", $(BusNum)
|
|
Debug-Output $(RealBusNum)
|
|
set BusNum = *($(RealBusNum),1)
|
|
Debug-Output $(SlotNum)
|
|
set-mul mcaid = $($1), 256
|
|
set-add mcaid = $(mcaid), $($0)
|
|
set InfoList = >($(InfoList),{$(BusNum),$(SlotNum),$(mcaid)})
|
|
endif
|
|
endif
|
|
set-add Position = $(Position), 6
|
|
set-add SlotNum = $(SlotNum), 1
|
|
goto Loop1
|
|
endif
|
|
endif
|
|
CloseRegKey $(KeyBus)
|
|
endif
|
|
EndForListDo
|
|
|
|
CloseRegKey $(KeyMultiAdapter)
|
|
|
|
MCAFindBus_return = +
|
|
|
|
return $(RegistryErrorIndex) $(InfoList)
|
|
|
|
;*************************************************************************
|
|
; end of section MCAFindBus
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: EISAFindBus
|
|
;
|
|
; PURPOSE: Find adpater(s) location
|
|
;
|
|
; ARGUMENTS: $0 The compress ID of the EISA card
|
|
; $1 EISA Compressed ID mask
|
|
;
|
|
;
|
|
; RETURNS: $R0 Registry error code or zero if no error
|
|
; $R1 The list of adapter location
|
|
; {{bus0,slot0},{bus1,slot1},{bus2,slot2}...{busk,slotk}}
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
|
|
[EISAFindBus]
|
|
read-syms InitBaseVars
|
|
set MaskNum = $($1)
|
|
ifstr(i) $($1) == ""
|
|
set MaskNum = 16777215 ; 0xffffff
|
|
endif
|
|
|
|
set RegistryErrorIndex = NO_ERROR
|
|
|
|
set EISAAdapter = "HARDWARE\Description\System\EISAAdapter"
|
|
set InfoList = {}
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(EISAAdapter) $(MAXIMUM_ALLOWED) KeyEISAAdapter
|
|
|
|
Ifstr $(KeyEISAAdapter) == $(KeyNull)
|
|
goto EISAFindBus_return
|
|
endif
|
|
|
|
EnumRegKey $(KeyEISAAdapter) BusList
|
|
|
|
Debug-Output "Buslist"
|
|
Debug-Output $(BusList)
|
|
|
|
ForListDo $(BusList)
|
|
set BusNum = *($($),1)
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(EISAAdapter)"\"$(BusNum) $(MAXIMUM_ALLOWED) KeyEISAAdapterBus
|
|
LibraryProcedure SlotList, $(!LIBHANDLE), GetEisaSlotInformation, $(KeyEISAAdapterBus), "Configuration Data", $($0), $(MaskNum)
|
|
ifstr(i) $(SlotList) != {}
|
|
ForListDo $(SlotList)
|
|
set SlotNum = $($)
|
|
ifstr(i) $(SlotNum) != "ERROR"
|
|
Debug-Output $(BusNum)
|
|
Debug-Output $(SlotNum)
|
|
set InfoList = >($(InfoList),{$(BusNum),$(SlotNum),$($0)})
|
|
endif
|
|
EndForListDo
|
|
endif
|
|
EndForListDo
|
|
|
|
CloseRegKey $(KeyEISAAdapter)
|
|
|
|
EISAFindBus_return = +
|
|
|
|
return $(RegistryErrorIndex) $(InfoList)
|
|
|
|
;*************************************************************************
|
|
; end of section EISAFindBus
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: GetPCIInformation
|
|
;
|
|
; PURPOSE: Get PCI vendor and device information
|
|
;
|
|
; ARGUMENTS: $0 Vendor ID
|
|
; $1 Device ID
|
|
;
|
|
;
|
|
; RETURNS: $R0 List of bus and slot information
|
|
; {{bus0,slot0},{bus1,slot1},{bus2,slot2}...{busk,slotk}}
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
|
|
[GetPCIInformation]
|
|
read-syms InitBaseVars
|
|
set VendorID = $($0)
|
|
set DeviceID = $($1)
|
|
set MultiAdapter = "HARDWARE\Description\System\MultifunctionAdapter"
|
|
set InfoList = {}
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(MultiAdapter) $(MAXIMUM_ALLOWED) KeyMultiAdapter
|
|
|
|
Ifstr $(KeyMultiAdapter) == $(KeyNull)
|
|
goto GetPCIInformation_return
|
|
endif
|
|
|
|
EnumRegKey $(KeyMultiAdapter) BusList
|
|
|
|
Debug-Output "Buslist"
|
|
Debug-Output $(BusList)
|
|
|
|
set BusNum = 0
|
|
set index = 0
|
|
ForListDo $(BusList)
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(MultiAdapter)"\"$(index) $(MAXIMUM_ALLOWED) KeyMultiAdapterBus
|
|
GetRegValue $(KeyMultiAdapterBus) "Identifier" IdentifierInfo
|
|
ifstr(i) *($(IdentifierInfo),4) == "PCI"
|
|
;
|
|
; Only check for PCI bus
|
|
;
|
|
|
|
set device = 0
|
|
next_device = +
|
|
ifint $(device) < 32
|
|
set function = 0
|
|
next_function = +
|
|
ifint $(function) < 8
|
|
LibraryProcedure Result, $(!LIBHANDLE), GetPciInformation, $(BusNum), $(device), $(function)
|
|
debug-output $(BusNum)".."$(device)".."$(function)".."$(Result)
|
|
ifint *($(Result),1) == 65535
|
|
Set-add device = $(device),1
|
|
goto next_device
|
|
endif
|
|
ifint *($(Result),1) == $(VendorID)
|
|
ifint *($(Result),2) == $(DeviceID)
|
|
set InfoList = >($(InfoList),{$(BusNum),$(device),$(function)})
|
|
endif
|
|
endif
|
|
set-add function = $(function), 1
|
|
goto next_function
|
|
endif
|
|
Set-add device = $(device),1
|
|
goto next_device
|
|
endif
|
|
finish_bus = +
|
|
set-add BusNum = $(BusNum),1
|
|
endif
|
|
set-add index = $(index),1
|
|
EndForListDo
|
|
|
|
CloseRegKey $(KeyMultiAdapter)
|
|
|
|
GetPCIInformation_return = +
|
|
return $(InfoList)
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: AddNetworkProvider
|
|
;
|
|
; PURPOSE: Add a network provider entry into the registry
|
|
;
|
|
; ARGUMENTS: $0 network provider id. i.e., lanmanredirector
|
|
; $1 network provder location. i.e, c:\nt\windows\system\ntlanman.dll
|
|
; $2 English name of the provider. i.e, NT Lan Manager
|
|
; $3 network provider device name, if different from network
|
|
; provider
|
|
;
|
|
;
|
|
; RETURNS: $R0 Registry error code or zero if no error
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
|
|
[AddNetworkProvider]
|
|
read-syms InitBaseVars
|
|
|
|
set RegistryErrorIndex = NO_ERROR
|
|
|
|
set ProviderDeviceName = $($3)
|
|
ifstr(i) $(ProviderDeviceName) == ""
|
|
set ProviderDeviceName = $($0)
|
|
endif
|
|
|
|
; OpenRegKey $(!REG_H_LOCAL) "" $(CurrentControlSet)"\control\NetworkProvider\Active\"$($0) $(MAXIMUM_ALLOWED) ActiveKey
|
|
; ifstr(i) $(OrderKey) == $(KeyNull)
|
|
; CreateRegKey $(!REG_H_LOCAL) {$(CurrentControlSet)"\control\NetworkProvider\Active\"$($0),$(NoTitle),GenericClass} "" $(MAXIMUM_ALLOWED) "" ActiveKey
|
|
; endif
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(CurrentControlSet)"\control\NetworkProvider\order" $(MAXIMUM_ALLOWED) OrderKey
|
|
ifstr(i) $(OrderKey) == $(KeyNull)
|
|
CreateRegKey $(!REG_H_LOCAL) {$(CurrentControlSet)"\control\NetworkProvider\order",$(NoTitle),GenericClass} "" $(MAXIMUM_ALLOWED) "" OrderKey
|
|
endif
|
|
|
|
GetRegValue $(OrderKey) "ProviderOrder" OrderValue
|
|
set Order = *($(OrderValue), 4 )
|
|
ifstr(i) $(OrderValue) == $(KeyNull)
|
|
goto AddFirstProvider
|
|
else-ifstr(i) $(Order) == $(KeyNull)
|
|
goto AddFirstProvider
|
|
else
|
|
goto AddProvider
|
|
endif
|
|
|
|
AddFirstProvider = +
|
|
SetRegValue $(OrderKey) {ProviderOrder,$(NoTitle),$(!REG_VT_SZ),$($0)}
|
|
goto WriteProviderInfo
|
|
|
|
AddProvider = +
|
|
Split-String $(Order) "," OrderList
|
|
ifContains(i) $($0) in $(OrderList)
|
|
; Enable if we cannot have the same provider
|
|
;
|
|
;set RegistryErrorIndex = PROVIDER_ALREADY_EXISTED
|
|
;goto AddnetworkProvider_return
|
|
else
|
|
set Order = $(Order)","$($0)
|
|
SetRegValue $(OrderKey) {ProviderOrder,$(NoTitle),$(!REG_VT_SZ),$(Order)}
|
|
endif
|
|
|
|
goto WriteProviderInfo
|
|
|
|
WriteProviderInfo = +
|
|
|
|
CloseRegKey $(OrderKey)
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(ServicesBaseName)"\"$($0)"\networkprovider" $(MAXIMUM_ALLOWED) ProviderKey
|
|
|
|
Ifstr(i) $(ProviderKey) == $(KeyNull)
|
|
CreateRegKey $(!REG_H_LOCAL) {$(ServicesBaseName)"\"$($0)"\networkprovider",$(NoTitle),GenericClass} "" $(MAXIMUM_ALLOWED) "" ProviderKey
|
|
endif
|
|
|
|
set NewValueList = {{Devicename,$(NoTitle),$(!REG_VT_SZ),"\Device\"$(ProviderDeviceName)},+
|
|
{ProviderPath, $(NoTitle), $(!REG_VT_EXPAND_SZ), $($1)},+
|
|
{Name, $(NoTitle), $(!REG_VT_SZ), $($2)}}
|
|
|
|
Shell "" AddValueList $(ProviderKey) $(NewValueList)
|
|
|
|
CloseRegKey $(ProviderKey)
|
|
|
|
AddNetworkProvider_return = +
|
|
|
|
return $(RegistryErrorIndex)
|
|
|
|
;*************************************************************************
|
|
; end of section AddNetworkProvider
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: AddServiceProvider
|
|
;
|
|
; PURPOSE: Add a Service provider entry into the registry
|
|
;
|
|
; ARGUMENTS: $0 Service provider id. i.e., tcpip
|
|
; $1 Service provder location. i.e, c:\nt\windows\system\ntlanman.dll
|
|
; $2 English name of the provider. i.e, NT Lan Manager
|
|
; $3 Class number
|
|
;
|
|
;
|
|
; RETURNS: $R0 Registry error code or zero if no error
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
|
|
[AddServiceProvider]
|
|
read-syms InitBaseVars
|
|
|
|
set RegistryErrorIndex = NO_ERROR
|
|
|
|
set ClassNum = $($3)
|
|
ifstr(i) $(ClassNum) == ""
|
|
set ClassNum = 8
|
|
endif
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(CurrentControlSet)"\control\ServiceProvider\order" $(MAXIMUM_ALLOWED) OrderKey
|
|
ifstr(i) $(OrderKey) == $(KeyNull)
|
|
CreateRegKey $(!REG_H_LOCAL) {$(CurrentControlSet)"\control\ServiceProvider\Order",$(NoTitle),GenericClass} "" $(MAXIMUM_ALLOWED) "" OrderKey
|
|
SetRegValue $(OrderKey) {ExcludedProviders,$(NoTitle),$(!REG_VT_MULTI_SZ),{}}
|
|
endif
|
|
|
|
GetRegValue $(OrderKey) "ProviderOrder" OrderValue
|
|
set Order = *($(OrderValue), 4 )
|
|
ifstr(i) $(OrderValue) == $(KeyNull)
|
|
goto AddFirstProvider
|
|
else-ifstr(i) $(Order) == $(KeyNull)
|
|
goto AddFirstProvider
|
|
else
|
|
goto AddProvider
|
|
endif
|
|
|
|
AddFirstProvider = +
|
|
SetRegValue $(OrderKey) {ProviderOrder,$(NoTitle),$(!REG_VT_MULTI_SZ),{$($0)}}
|
|
goto WriteProviderInfo
|
|
|
|
AddProvider = +
|
|
ifContains(i) $($0) in $(Order)
|
|
; Enable if we cannot have the same provider
|
|
;
|
|
;set RegistryErrorIndex = PROVIDER_ALREADY_EXISTED
|
|
;goto AddProvider_return
|
|
else
|
|
set Order = >($(Order),$($0))
|
|
SetRegValue $(OrderKey) {ProviderOrder,$(NoTitle),$(!REG_VT_MULTI_SZ),$(Order)}
|
|
endif
|
|
|
|
goto WriteProviderInfo
|
|
|
|
WriteProviderInfo = +
|
|
|
|
CloseRegKey $(OrderKey)
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(ServicesBaseName)"\"$($0)"\Serviceprovider" $(MAXIMUM_ALLOWED) ProviderKey
|
|
|
|
Ifstr(i) $(ProviderKey) == $(KeyNull)
|
|
CreateRegKey $(!REG_H_LOCAL) {$(ServicesBaseName)"\"$($0)"\Serviceprovider",$(NoTitle),GenericClass} "" $(MAXIMUM_ALLOWED) "" ProviderKey
|
|
endif
|
|
|
|
set NewValueList = {{Class,$(NoTitle),$(!REG_VT_DWORD),$(ClassNum)},+
|
|
{ProviderPath, $(NoTitle), $(!REG_VT_EXPAND_SZ), $($1)},+
|
|
{Name, $(NoTitle), $(!REG_VT_SZ), $($2)}}
|
|
|
|
Shell "" AddValueList $(ProviderKey) $(NewValueList)
|
|
|
|
CloseRegKey $(ProviderKey)
|
|
|
|
AddProvider_return = +
|
|
|
|
return $(RegistryErrorIndex)
|
|
|
|
;*************************************************************************
|
|
; end of section AddServiceProvider
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: RemoveServiceProvider
|
|
;
|
|
; PURPOSE: Remove Service provider entry
|
|
;
|
|
; ARGUMENTS: $0 provider name
|
|
;
|
|
; RETURNS: $R0 Registry error code or zero if no error
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
|
|
[RemoveServiceProvider]
|
|
read-syms InitBaseVars
|
|
|
|
set RegistryErrorIndex = NO_ERROR
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(CurrentControlSet)"\control\ServiceProvider\order" $(MAXIMUM_ALLOWED) OrderKey
|
|
ifstr(i) $(OrderKey) == $(KeyNull)
|
|
set RegistryErrorIndex = PROVIDER_ORDER_DOES_NOT_EXIST
|
|
goto RemoveProvider_return
|
|
endif
|
|
|
|
GetRegValue $(OrderKey) "ProviderOrder" OrderValue
|
|
set Order = *($(OrderValue), 4 )
|
|
|
|
set NewOrderList = {}
|
|
set FirstTime = TRUE
|
|
set Found = FALSE
|
|
ForListDo $(Order)
|
|
ifstr(i) $($) != $($0)
|
|
ifstr(i) $(FirstTime) == TRUE
|
|
set FirstTime = FALSE
|
|
set NewOrderList = {$($)}
|
|
else
|
|
set NewOrderList = >($(NewOrderList),$($))
|
|
endif
|
|
else
|
|
set Found = TRUE
|
|
endif
|
|
EndForListDo
|
|
|
|
ifstr(i) $(Found) == FALSE
|
|
; set RegistryErrorIndex = PROVIDER_ORDER_DOES_NOT_EXIST
|
|
; goto RemoveProvider_return
|
|
else
|
|
ifstr(i) $(NewOrderList) == {}
|
|
set NewOrderList = ""
|
|
endif
|
|
SetRegValue $(OrderKey) {ProviderOrder,$(NoTitle),$(!REG_VT_MULTI_SZ),$(NewOrderList)}
|
|
endif
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(ServicesBaseName)\$($0) $(MAXIMUM_ALLOWED) ProviderKey
|
|
|
|
ifstr $(ProviderKey) != $(KeyNull)
|
|
DeleteRegTree $(ProviderKey) "ServiceProvider"
|
|
endif
|
|
|
|
RemoveProvider_return = +
|
|
return $(RegistryErrorIndex)
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: RemoveNetworkProvider
|
|
;
|
|
; PURPOSE: Remove network provider entry
|
|
;
|
|
; ARGUMENTS: $0 provider name
|
|
;
|
|
; RETURNS: $R0 Registry error code or zero if no error
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
|
|
[RemoveNetworkProvider]
|
|
read-syms InitBaseVars
|
|
|
|
set RegistryErrorIndex = NO_ERROR
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(CurrentControlSet)"\control\NetworkProvider\order" $(MAXIMUM_ALLOWED) OrderKey
|
|
ifstr(i) $(OrderKey) == $(KeyNull)
|
|
set RegistryErrorIndex = PROVIDER_ORDER_DOES_NOT_EXIST
|
|
goto RemoveNetworkProvider_return
|
|
endif
|
|
|
|
GetRegValue $(OrderKey) "ProviderOrder" OrderValue
|
|
set Order = *($(OrderValue), 4 )
|
|
|
|
Split-String $(Order) "," OrderList
|
|
set NewOrderList = {}
|
|
set FirstTime = TRUE
|
|
set Found = FALSE
|
|
ForListDo $(OrderList)
|
|
ifstr(i) $($) != ","
|
|
ifstr(i) $($) != $($0)
|
|
ifstr(i) $(FirstTime) == TRUE
|
|
set FirstTime = FALSE
|
|
set NewOrderList = $($)
|
|
else
|
|
set NewOrderList = $(NewOrderList)","$($)
|
|
endif
|
|
else
|
|
set Found = TRUE
|
|
endif
|
|
endif
|
|
EndForListDo
|
|
|
|
ifstr(i) $(Found) == FALSE
|
|
; set RegistryErrorIndex = PROVIDER_ORDER_DOES_NOT_EXIST
|
|
; goto RemoveNetworkProvider_return
|
|
else
|
|
ifstr(i) $(NewOrderList) == {}
|
|
set NewOrderList = ""
|
|
endif
|
|
SetRegValue $(OrderKey) {ProviderOrder,$(NoTitle),$(!REG_VT_SZ),$(NewOrderList)}
|
|
endif
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(ServicesBaseName)\$($0) $(MAXIMUM_ALLOWED) ProviderKey
|
|
|
|
ifstr $(ProviderKey) != $(KeyNull)
|
|
DeleteRegTree $(ProviderKey) "NetworkProvider"
|
|
endif
|
|
|
|
RemoveNetworkProvider_return = +
|
|
return $(RegistryErrorIndex)
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: AddNameSpaceProvider
|
|
;
|
|
; PURPOSE: Add a NameSpace provider entry into the registry
|
|
;
|
|
; ARGUMENTS: $0 (STRING) Name Space Provider Display Name
|
|
; $1 (STRING) Name Space Provider DLL (full path)
|
|
; $2 (INT) Name Space support, see Winsock2.h or NSPApi.h in sdk\inc
|
|
; $3 (BOOL) Schema Support (TRUE | FALSE)
|
|
; $4 (STRING - GUID) Name Space Provider ID {46cd93d0-7e92-11cf-ae5a-00aa00a7112b}
|
|
;
|
|
;
|
|
; RETURNS: $R0 Registry error code or zero if no error
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
|
|
[AddNameSpaceProvider]
|
|
read-syms InitBaseVars
|
|
|
|
set RegistryErrorIndex = NO_ERROR
|
|
Set FLibraryErrCtl = 1
|
|
LibraryProcedure Result, $(!NCPA_HANDLE), AddNameSpaceProvider, $($0), $($1), $($2), $($3), $($4)
|
|
Set FLibraryErrCtl = 0
|
|
|
|
Set ResultError = *($(Result),1)
|
|
Ifint $(ResultError) != 0
|
|
Debug-Output "UTILITY.INF: AddNameSpaceProvider wrapper failed, error: "$(Result)
|
|
Set RegistryErrorIndex = UNABLE_ADD_NAMESPACE_PROVIDER
|
|
Goto AddNameSpaceProvider_return
|
|
Endif
|
|
|
|
AddNameSpaceProvider_return = +
|
|
return $(RegistryErrorIndex)
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: RemoveNameSpaceProvider
|
|
;
|
|
; PURPOSE: Remove namespace provider entry
|
|
;
|
|
; ARGUMENTS: $0 (STRING, GUID) Name Space Provider ID {46cd93d0-7e92-11cf-ae5a-00aa00a7112b}
|
|
;
|
|
; RETURNS: $R0 Registry error code or zero if no error
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
|
|
[RemoveNameSpaceProvider]
|
|
read-syms InitBaseVars
|
|
|
|
set RegistryErrorIndex = NO_ERROR
|
|
|
|
Set FLibraryErrCtl = 1
|
|
LibraryProcedure Result, $(!NCPA_HANDLE), RemoveNameSpaceProvider, $($0)
|
|
Set FLibraryErrCtl = 0
|
|
|
|
Set ResultError = *($(Result),1)
|
|
Ifint $(ResultError) != 0
|
|
Debug-Output "UTILITY.INF: RemoveNameSpaceProvider wrapper failed, error: "$(Result)
|
|
Set RegistryErrorIndex = UNABLE_REMOVE_NAMESPACE_PROVIDER
|
|
Goto RemoveNameSpaceProvider_return
|
|
Endif
|
|
|
|
RemoveNameSpaceProvider_return = +
|
|
return $(RegistryErrorIndex)
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: PrepareToCopy
|
|
;
|
|
; PURPOSE: Establish the variables required to perform
|
|
; "CopyFilesInCopyList"
|
|
;
|
|
; ARGUMENTS: none
|
|
;
|
|
; RETURNS: $R0 STATUS_SUCCESSFUL
|
|
;
|
|
; REFERENCES: nothing
|
|
;
|
|
; MODIFIES: see [ProgressCopyEng] above for list of variables
|
|
; modified/created in parent context.
|
|
;
|
|
; NOTES: Read NOTES commentary for section [DoAskSource]
|
|
;
|
|
;*************************************************************************
|
|
[PrepareToCopy]
|
|
;
|
|
; Read the progress copy symbols.
|
|
;
|
|
Read-syms ProgressCopy$(!STF_LANGUAGE)
|
|
|
|
Return STATUS_SUCCESSFUL
|
|
|
|
;*************************************************************************
|
|
; end of section PrepareToCopy
|
|
;*************************************************************************
|
|
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: DoAskSource
|
|
;
|
|
; PURPOSE: Determine or ask to location of the network binaries
|
|
;
|
|
; ARGUMENTS: $0 current value of STF_CWDDIR
|
|
; $1 current value of STF_SRCDIR
|
|
; $2 "YES" if part of NT base product (i.e., not OEM)
|
|
; "NO" otherwise.
|
|
;
|
|
; RETURNS: $R0: STATUS: STATUS_SUCCESSFUL |
|
|
; STATUS_USERCANCEL |
|
|
; STATUS_FAILED
|
|
; $R1 path to sources
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: !STF_SRCDIR_USED changed to point to the user's
|
|
; keyed location
|
|
; !STF_SRCDIR_KEYED
|
|
;
|
|
; NOTES: The SETUP copy operations read the symbol table the old way;
|
|
; this means that they will only utilize local symbols for
|
|
; the necessary progress variables. This section/function assumes
|
|
; that it's being called by an INF at THE EXACT SAME CONTEXT LEVEL
|
|
; AT WHICH THE INSTALL FUNCTION WILL BE INVOKED! It stores the
|
|
; values specifically into the parent context so the progress dialog
|
|
; function can see them.
|
|
;
|
|
;*************************************************************************
|
|
[DoAskSource]
|
|
Set DAS_CWDDIR = $($0)
|
|
Set DAS_SRCDIR = $($1)
|
|
Set DAS_BUILTIN = $($2)
|
|
Set DAS_Result = STATUS_FAILED
|
|
;
|
|
; If !STF_SRCDIR_OVERRIDE is not empty, use it instead.
|
|
;
|
|
Ifstr(i) $(!STF_SRCDIR_OVERRIDE) != ""
|
|
Set DAS_SRCDIR = $(!STF_SRCDIR_OVERRIDE)
|
|
Set DAS_Result = STATUS_SUCCESSFUL
|
|
Goto DAS_exit
|
|
Endif
|
|
;
|
|
; If this is a built-in component during primary installation,
|
|
; use the given source path automatically unless !SFT_SRCDIR_WINNT
|
|
; is set. This is for the WINNT case, where Setup's SourcePath lies.
|
|
;
|
|
Ifstr(i) $(DAS_BUILTIN) == YES
|
|
Ifstr(i) $(!NTN_InstallPhase) == primary
|
|
Ifstr(i) $(!STF_SRCDIR_WINNT) != ""
|
|
Set DAS_SRCDIR = $(!STF_SRCDIR_WINNT)
|
|
Endif
|
|
Set DAS_Result = STATUS_SUCCESSFUL
|
|
Goto DAS_exit
|
|
Endif
|
|
Else
|
|
Ifstr(i) $(!NTN_InstallPhase) == primary
|
|
; during primary install, always use the passed value
|
|
Set DAS_Result = STATUS_SUCCESSFUL
|
|
Goto DAS_exit
|
|
Else
|
|
; not a shipped item, so force to use A rather than saved location
|
|
Set DAS_SRCDIR = ""
|
|
EndIf
|
|
Endif
|
|
|
|
Debug-Output "UTILITY.INF: [DoAskSource] STF_CWDDIR = "$(DAS_CWDDIR)" STF_SRCDIR = "$(DAS_SRCDIR)
|
|
;
|
|
; Set default to drive A: if necessary
|
|
;
|
|
Ifstr(i) $(DAS_SRCDIR) == ""
|
|
Set DAS_SRCDIR = "A:\"
|
|
Endif
|
|
;
|
|
; If this is the same SRCDIR as last time, replace it with the string
|
|
; actually keyed by the user. This causes UNC names to reappear in their
|
|
; original form; the name of the automatically "used" remote drive should
|
|
; never be shown.
|
|
;
|
|
Ifstr(i) $(DAS_SRCDIR) == $(!STF_SRCDIR_USED)
|
|
Set DAS_SRCDIR = $(!STF_SRCDIR_KEYED)
|
|
Endif
|
|
;
|
|
; Ask for the setup sources
|
|
;
|
|
Shell "subroutn.inf" DoAskSource $(DAS_SRCDIR)
|
|
|
|
ifint $($ShellCode) != $(!SHELL_CODE_OK)
|
|
Debug-Output "UTILITY.INF: shelling SUBROUTN.INF [DoAskSource] failed"
|
|
goto DAS_exit
|
|
endif
|
|
|
|
Set DAS_Result = $($R0)
|
|
|
|
Ifstr(i) $(DAS_Result) == STATUS_USERCANCEL
|
|
;
|
|
; BUGBUG: All the INFs should change to handle this correctly.
|
|
;
|
|
Set !p:CommonStatus = STATUS_USERCANCEL
|
|
goto DAS_exit
|
|
Endif
|
|
|
|
Set DAS_SRCDIR = $($R1)
|
|
;
|
|
; Save the actual and converted SRCDIRs
|
|
;
|
|
Set !STF_SRCDIR_USED = $($R1)
|
|
Set !STF_SRCDIR_KEYED = $($R3)
|
|
|
|
;
|
|
; Store the new location if this is a request for NT source in the registry.
|
|
;
|
|
Ifstr(i) $(DAS_BUILTIN) == YES
|
|
OpenRegKey $(!REG_H_LOCAL) "" "SOFTWARE\Microsoft\Windows Nt\CurrentVersion" $(!REG_KEY_WRITE) KeyNt
|
|
Ifstr(i) $(KeyNt) != ""
|
|
SetRegValue $(KeyNt) {SourcePath,$(NoTitle),$(!REG_VT_SZ),$(!STF_SRCDIR_USED)}
|
|
Debug-Output "UTILITY.INF: SourcePath stored is "$(!STF_SRCDIR_USED)
|
|
CloseRegKey $(KeyNt)
|
|
Endif
|
|
Endif
|
|
|
|
DAS_exit =+
|
|
;
|
|
; Read the progress copy symbols.
|
|
;
|
|
Read-syms ProgressCopy$(!STF_LANGUAGE)
|
|
|
|
Return $(DAS_Result) $(DAS_SRCDIR)
|
|
|
|
;*************************************************************************
|
|
; end of section DoAskSource
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: RemoveSoftwareComponent
|
|
;
|
|
; PURPOSE: Remove the specified software component from the
|
|
; registry. It will remove the entry in the software
|
|
; section of the registry first. Then it will remove
|
|
; the entry in the service section of the registry.
|
|
;
|
|
; ARGUMENTS: $0 Manufacturer Name
|
|
; $1 Product Name
|
|
; $2 Boolean flag for zero reference count checking
|
|
; ( optional. If it is defined, skip checking )
|
|
;
|
|
;
|
|
; RETURNS: $R0 Registry error code or zero if no error
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
|
|
[RemoveSoftwareComponent]
|
|
Debug-Output "Remove Software Component..."
|
|
|
|
read-syms InitBaseVars
|
|
|
|
set RS_Manufacturer = $($0)
|
|
set RS_ProductName = $($1)
|
|
set RS_CheckRefCount = $($2)
|
|
set RS_VersionNum = "CurrentVersion"
|
|
set RS_ManufacturerKey = $(!NTN_SoftwareBase)"\"$(RS_Manufacturer)
|
|
set RS_ProductKey = $(!NTN_SoftwareBase)"\"$(RS_Manufacturer)"\"$(RS_ProductName)
|
|
set RS_ProductVerKey = $(!NTN_SoftwareBase)"\"$(RS_Manufacturer)"\"$(RS_ProductName)"\"$(RS_VersionNum)
|
|
|
|
set RegistryErrorIndex = NO_ERROR
|
|
|
|
;
|
|
; Check the reference counter first
|
|
;
|
|
ifstr(i) $(RS_CheckRefCount) != FALSE
|
|
|
|
Shell "", IsRefCountEqualZero, $(RS_ProductVerKey)
|
|
|
|
Ifstr(i) $($R0) != NO_ERROR
|
|
Debug-Output "UTILITY.INF: [RemoveSoftwareComponent] IsRefCountEqualZero returned "$($R0)
|
|
goto RemoveSoftwareComponent_Return
|
|
endif
|
|
|
|
Ifint $($R1) == 0
|
|
set RegistryErrorIndex = REF_COUNT_NOT_ZERO
|
|
goto RemoveSoftwareComponent_Return
|
|
endif
|
|
|
|
endif
|
|
|
|
;
|
|
; Remove the software first
|
|
;
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(RS_ManufacturerKey) $(MAXIMUM_ALLOWED) ProductKey
|
|
|
|
Ifstr $(ProductKey) == $(KeyNull)
|
|
Debug-Output "UTILITY.INF: could not open Software product key"
|
|
set RegistryErrorIndex = UNABLE_ACCESS_CONFIGURE_SERVICE
|
|
goto RemoveSoftwareComponent_Return
|
|
endif
|
|
|
|
DeleteRegTree $(ProductKey) $(RS_ProductName)
|
|
|
|
CloseRegKey $(ProductKey)
|
|
|
|
;
|
|
; Remove the service
|
|
;
|
|
Shell "" RemoveService, $(RS_ProductName), "YES"
|
|
|
|
Set RS_RemoveError = $($R0)
|
|
Ifint $(RS_RemoveError) != 0
|
|
Debug-Output "UTILITY.INF: RemoveService wrapper failed, error: "$(RS_RemoveResult)
|
|
Set RegistryErrorIndex = UNABLE_REMOVE_CONFIGURE_SERVICE
|
|
Goto RemoveSoftwareComponent_Return
|
|
Endif
|
|
|
|
RemoveSoftwareComponent_Return = +
|
|
|
|
Return $(RegistryErrorIndex)
|
|
|
|
;*************************************************************************
|
|
; end of section RemoveSoftwareComponent
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: RemoveHardwareComponent
|
|
;
|
|
; PURPOSE: Remove the adapter entry from the registry. First
|
|
; remove the adapter entry under Networkcards. Then it
|
|
; will remove the service entry under SYSTEM.
|
|
;
|
|
; ARGUMENTS: $0 Manufacturer Name (i.e., 3Com)
|
|
; $1 Product Name (i.e., Elnk)
|
|
; $2 Net Card Name (i.e., Elnkii05)
|
|
;
|
|
;
|
|
; RETURNS: $R0 Registry error code or zero if no error
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
|
|
[RemoveHardwareComponent]
|
|
Debug-Output "Remove Hardware Component..."
|
|
read-syms InitBaseVars
|
|
|
|
set RH_Manufacturer = $($0)
|
|
set RH_ProductName = $($1)
|
|
set RH_VersionNum = "CurrentVersion"
|
|
set RH_ProductKey = $(!NTN_SoftwareBase)"\"$($0)"\"$($1)"\"$(RH_VersionNum)
|
|
set RH_NetCardName = $($2)
|
|
Split-String $(RH_NetCardName), "\", CardInfo
|
|
set RH_NetCardNum = *($(CardInfo),11)
|
|
set RH_NetCardBase = *($(CardInfo),1)*($(CardInfo),2)*($(CardInfo),3)*($(CardInfo),4)*($(CardInfo),5)*($(CardInfo),6)*($(CardInfo),7)*($(CardInfo),8)*($(CardInfo),9)
|
|
|
|
set RegistryErrorIndex = NO_ERROR
|
|
|
|
;
|
|
; decrement the reference counter first
|
|
;
|
|
|
|
Shell "", DecrementRefCount, $(RH_ProductKey)
|
|
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
Debug-Output "UTILITY.INF: [AddHardwareComponent] IncrementRefCount returned "$(RegistryErrorIndex)
|
|
goto RemoveHardwareComponent_Return
|
|
endif
|
|
|
|
;
|
|
; Remove the Net card first
|
|
;
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(RH_NetCardBase) $(MAXIMUM_ALLOWED) NetCardKey
|
|
|
|
Ifstr $(NetCardKey) == $(KeyNull)
|
|
Debug-Output "UTILITY.INF: could not open NetworkCards key"
|
|
set RegistryErrorIndex = UNABLE_ACCESS_CONFIGURE_SERVICE
|
|
goto RemoveHardwareComponent_Return
|
|
endif
|
|
|
|
OpenRegKey $(NetCardKey) "" $(RH_NetCardNum) $(MAXIMUM_ALLOWED) NetCardNumKey
|
|
|
|
Ifstr $(NetCardNumKey) == $(KeyNull)
|
|
Debug-Output "UTILITY.INF: could not open NetworkCards Number key"
|
|
set RegistryErrorIndex = UNABLE_ACCESS_CONFIGURE_SERVICE
|
|
goto RemoveHardwareComponent_Return
|
|
endif
|
|
|
|
GetRegValue $(NetCardNumKey),"ServiceName", RH_ServiceNameInfo
|
|
set RH_ServiceName = *($(RH_ServiceNameInfo), 4)
|
|
|
|
ifstr(i) $(RH_ServiceName) == ""
|
|
; if we cannot get the service name, make a guess
|
|
set RH_ServiceName = $(RH_ProductName)$(RH_NetCardNum)
|
|
endif
|
|
|
|
CloseRegKey $(NetCardNumKey)
|
|
|
|
DeleteRegTree $(NetCardKey) $(RH_NetCardNum)
|
|
|
|
CloseRegKey $(NetCardKey)
|
|
|
|
Shell "", RemoveService, $(RH_ServiceName), "NO"
|
|
|
|
Set RS_RemoveError = $($R0)
|
|
Ifint $(RS_RemoveError) != 0
|
|
Debug-Output "UTILITY.INF: RemoveService wrapper failed, error: "$(RS_RemoveResult)
|
|
Set RegistryErrorIndex = UNABLE_REMOVE_CONFIGURE_SERVICE
|
|
Goto RemoveHardwareComponent_Return
|
|
Endif
|
|
|
|
|
|
;
|
|
; If driver reference count is equal to 0, remove it.
|
|
;
|
|
|
|
Shell "", IsRefCountEqualZero, $(RH_ProductKey)
|
|
|
|
Ifstr(i) $($R0) != NO_ERROR
|
|
Debug-Output "UTILITY.INF: [RemoveHardwareComponent] IsRefCountEqualZero returned "$($R0)
|
|
goto RemoveHardwareComponent_Return
|
|
endif
|
|
|
|
Ifint $($R1) == 1
|
|
Debug-Output "Remove software component..."
|
|
Shell "" RemoveSoftwareComponent, $(RH_Manufacturer), $(RH_ProductName)
|
|
set RegistryErrorIndex = $($R0)
|
|
endif
|
|
|
|
debug-output "remove netbios information..."
|
|
LibraryProcedure Result, $(!NCPA_HANDLE), RemoveRouteFromNETBIOS, $(RH_ServiceName)
|
|
|
|
RemoveHardwareComponent_Return = +
|
|
|
|
Return $(RegistryErrorIndex)
|
|
|
|
;*************************************************************************
|
|
; end of section RemoveHardwareComponent
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: RemoveService
|
|
;
|
|
; PURPOSE: Remove a specified service from the registry. It is
|
|
; called by RemoveSoftwareComponent and
|
|
; RemoveHardwareComponent. Or, if the service is
|
|
; created by calling "CreateService", we will
|
|
; need to use this subroutine to remove it.
|
|
;
|
|
; ARGUMENTS: $0 Service Name
|
|
; $1 "YES" - we use DeleteService to remove the service
|
|
; "NO" - we use DeleteRegTree to remove the
|
|
; registry tree
|
|
;
|
|
; RETURNS: $R0 Registry error code or zero if no error
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
|
|
[RemoveService]
|
|
read-syms InitBaseVars
|
|
Set RS_SvcName = $($0)
|
|
Set RS_UseDelSvc = $($1)
|
|
|
|
; Make sure the service key exists first.
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" "SYSTEM\CurrentControlSet\Services\"$(RS_SvcName) +
|
|
$(MAXIMUM_ALLOWED) ServiceKey
|
|
|
|
Ifstr $(ServiceKey) == $(KeyNull)
|
|
Debug-Output "UTILITY.INF: could not open SYSTEM Service key "$(RS_SvcName)
|
|
goto RemoveService_Return
|
|
endif
|
|
|
|
; Remove the NbProvider value if it exists
|
|
|
|
OpenRegKey $(ServiceKey) "" "Parameters" $(MAXIMUM_ALLOWED) ParameterKey
|
|
|
|
Ifstr $(ParameterKey) != $(KeyNull)
|
|
DeleteRegValue $(ParameterKey) "NbProvider"
|
|
CloseRegKey $(ParameterKey)
|
|
Endif
|
|
|
|
CloseRegKey $(ServiceKey)
|
|
|
|
ifstr(i) $(RS_UseDelSvc) == "YES"
|
|
|
|
; Remove the service
|
|
|
|
Set FLibraryErrCtl = 1
|
|
LibraryProcedure RS_RemoveResult $(!NCPA_HANDLE), CPlSetup, +
|
|
$(!STF_HWND), DELETESVC, $(RS_SvcName)
|
|
Set FLibraryErrCtl = 0
|
|
|
|
; Check the return code
|
|
|
|
Set RS_RemoveError = *($(RS_RemoveResult),1)
|
|
Ifint $(RS_RemoveError) != 0
|
|
Debug-Output "UTILITY.INF: RemoveService wrapper failed, error: "$(RS_RemoveResult)
|
|
Set RegistryErrorIndex = UNABLE_REMOVE_CONFIGURE_SERVICE
|
|
Goto RemoveService_Return
|
|
Endif
|
|
|
|
else
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" "SYSTEM\CurrentControlSet\Services" +
|
|
$(MAXIMUM_ALLOWED) ServiceKey
|
|
|
|
Ifstr $(ServiceKey) == $(KeyNull)
|
|
Debug-Output "UTILITY.INF: could not open SYSTEM Service key "$(RS_SvcName)
|
|
set RegistryErrorIndex = UNABLE_ACCESS_CONFIGURE_SERVICE
|
|
goto RemoveService_Return
|
|
endif
|
|
|
|
DeleteRegTree $(ServiceKey) $(RS_SvcName)
|
|
|
|
CloseRegKey $(ServiceKey)
|
|
|
|
endif
|
|
|
|
RemoveService_Return = +
|
|
return $(RegistryErrorIndex)
|
|
|
|
;*************************************************************************
|
|
; end of section RemoveService
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: IsNetCardAlreadyInstalled
|
|
;
|
|
; PURPOSE: This subroutine is called by EISA and MCA net card
|
|
; setup. Given the bus number and slot number, it will
|
|
; return a boolean to idicate whether the card is
|
|
; already installed or not.
|
|
;
|
|
; ARGUMENTS: $0 Bus Number
|
|
; $1 Slot Number
|
|
; $2 Product Description
|
|
; $3 Product Name
|
|
; $4 Skip description and name checking
|
|
;
|
|
; RETURNS: $R0 Registry error code or zero if no error
|
|
; $R1 "YES" - if the net card already installed
|
|
; "NO" - if the net card is not in the registry
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
|
|
[IsNetCardAlreadyInstalled]
|
|
read-syms InitBaseVars
|
|
|
|
set AlreadyExisted = "NO"
|
|
|
|
set BusNum = $($0)
|
|
set SlotNum = $($1)
|
|
set Description = $($2)
|
|
set Product = $($3)
|
|
set SkipDescriptionCheck = $($4)
|
|
ifstr(i) $(SkipDescriptionCheck) == ""
|
|
set SkipDescriptionCheck = "NO"
|
|
endif
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(NetworkCardKeyName) $(MAXIMUM_ALLOWED) IE_KeyNetcards
|
|
|
|
Ifstr $(IE_KeyNetcards) == $(KeyNull)
|
|
set RegistryErrorIndex = UNABLE_OPEN_NETWORKCARD_SECTION
|
|
goto IE_Return
|
|
endif
|
|
|
|
EnumRegKey $(IE_KeyNetcards) IE_KeyNameList
|
|
|
|
;
|
|
; Compare all the NetworkCards entry and see whether they have the
|
|
; same title and productname.
|
|
;
|
|
ForListDo $(IE_KeyNameList)
|
|
set IE_KeyName = *($($),1)
|
|
OpenRegKey $(IE_KeyNetcards) "" $(IE_KeyName) $(MAXIMUM_ALLOWED) IE_Card
|
|
|
|
Ifstr $(IE_Card) == $(KeyNull)
|
|
set RegistryErrorIndex = UNABLE_OPEN_NETWORKCARD_SECTION
|
|
goto IE_Return
|
|
endif
|
|
|
|
GetRegValue $(IE_Card),"Description", DescriptionInfo
|
|
GetRegValue $(IE_Card),"ProductName", ProductNameInfo
|
|
set CardDescription = *($(DescriptionInfo), 4)
|
|
set CardProductName = *($(ProductNameInfo), 4)
|
|
|
|
ifstr(i) $(SkipDescriptionCheck) == "YES"
|
|
set CardDescription = $(Description)
|
|
set CardProductName = $(Product)
|
|
endif
|
|
|
|
ifstr(i) $(CardDescription) == $(Description)
|
|
ifstr(i) $(CardProductName) == $(Product)
|
|
|
|
;
|
|
; We find the same product type. make sure that it
|
|
; does not have the same bus number and slot number
|
|
;
|
|
|
|
GetRegValue $(IE_Card), "ServiceName", ServiceNameInfo
|
|
set ServiceName = *($(ServiceNameInfo), 4)
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" +
|
|
$(ServicesBaseName)"\"$(ServiceName)"\Parameters" +
|
|
$(MAXIMUM_ALLOWED) IE_KeyService
|
|
|
|
Ifstr $(IE_KeyService) == $(KeyNull)
|
|
set RegistryErrorIndex = UNABLE_OPEN_NETWORKCARD_SECTION
|
|
goto IE_Return
|
|
endif
|
|
|
|
GetRegValue $(IE_KeyService), "BusNumber", BusInfo
|
|
GetRegValue $(IE_KeyService), "SlotNumber", SlotInfo
|
|
set CardBusNum = *($(BusInfo), 4)
|
|
set CardSlotNum = *($(SlotInfo), 4)
|
|
|
|
ifint $(CardBusNum) == $(BusNum)
|
|
ifint $(CardSlotNum) == $(SlotNum)
|
|
;
|
|
; Don't install this card. It is already installed
|
|
;
|
|
set AlreadyExisted = "YES"
|
|
endif
|
|
endif
|
|
|
|
endif
|
|
endif
|
|
EndForListDo
|
|
|
|
IE_Return = +
|
|
return $(RegistryErrorIndex) $(AlreadyExisted)
|
|
|
|
;*************************************************************************
|
|
; end of section IsNetCardAlreadyInstalled
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: CopyRegTreeAs
|
|
;
|
|
; PURPOSE:
|
|
;
|
|
;
|
|
; ARGUMENTS: $0 Handle to the source reg key
|
|
; $1 Handle to the destination reg key
|
|
; $2 (optional) Name of the destination key to place the entries in
|
|
; $3 (optional) (TRUE|FALSE) Make destination volatile
|
|
;
|
|
; RETURNS: $R0 Registry error code or zero if no error
|
|
; $R1 Handle to destination key (if $2 is "" then returns $1)
|
|
;
|
|
; REFERENCES: none
|
|
;
|
|
; MODIFIES: none
|
|
;
|
|
;
|
|
;*************************************************************************
|
|
[CopyRegTreeAs]
|
|
read-syms InitBaseVars
|
|
Set RegistryErrorIndex = NO_ERROR
|
|
set CRTA_SrcKey = $($0)
|
|
set CRTA_BaseDestKey = $($1)
|
|
set CRTA_DestName = $($2)
|
|
set CRTA_DestKey = $($1)
|
|
|
|
ifstr(i) $(CRTA_DestName) != ""
|
|
;
|
|
; create the destination key
|
|
;
|
|
CreateRegKey $(CRTA_BaseDestKey) {$(CRTA_DestName),$(NoTitle),GenericClass} "" $(MAXIMUM_ALLOWED) "" CRTA_DestKey
|
|
Ifstr(i) $(CRTA_DestKey) == $(KeyNull)
|
|
Set RegistryErrorIndex = UNABLE_ACCESS_CONFIGURE_SERVICE
|
|
Goto CRTA_Return
|
|
Endif
|
|
endif
|
|
|
|
;
|
|
; call into the ncpa to copy the reg tree
|
|
;
|
|
Set FLibraryErrCtl = 1
|
|
LibraryProcedure CRTA_CopyResult $(!NCPA_HANDLE), RegCopyTree, $(CRTA_SrcKey), $(CRTA_DestKey)
|
|
Set FLibraryErrCtl = 0
|
|
Set CRTA_CopyError = *($(CRTA_CopyResult),1)
|
|
|
|
Ifint $(CRTA_CopyError) != 0
|
|
Debug-Output "UTILITY.INF: [CopyRegTreeAs] RegCopyTree returned "$(CRTA_CopyError)
|
|
Set RegistryErrorIndex = UNABLE_ACCESS_CONFIGURE_SERVICE
|
|
Goto CRTA_Return
|
|
Endif
|
|
|
|
|
|
CRTA_Return = +
|
|
|
|
return $(RegistryErrorIndex) $(CRTA_DestKey)
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: UpdateWinsockService
|
|
;
|
|
; PURPOSE: This section creates, if necessary, the WinSock
|
|
; service data object. This Registry key is a placeholder
|
|
; for all WinSock mapping information. In particular,
|
|
; it contains a value called Transports, which contains
|
|
; a REG_MULTI_SZ listing the names of all transports
|
|
; which export a sockets interface (through a DLL).
|
|
;
|
|
; Then, we either add or remove the name of this transport
|
|
; from the list.
|
|
;
|
|
; ARGUMENTS: $0 Name of Transport Service supporting WinSock
|
|
; $1 TRUE if adding data; FALSE if removing data
|
|
;
|
|
; RETURNS: $R0 Registry error code or zero if no error
|
|
;
|
|
; REFERENCES: none
|
|
;
|
|
; MODIFIES: none
|
|
;
|
|
;
|
|
;*************************************************************************
|
|
[UpdateWinsockService]
|
|
read-syms InitBaseVars
|
|
;
|
|
; Get the base key handle for the services area
|
|
;
|
|
Set UW_NameOfService = $($0)
|
|
Set UW_Adding = $($1)
|
|
Set UW_KeyServices = $(KeyNull)
|
|
Set UW_KeyParameters = $(KeyNull)
|
|
|
|
Shell "", BaseServiceKey
|
|
Set RegistryErrorIndex = $($R0)
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
Set RegistryErrorIndex = UNABLE_ACCESS_CONFIGURE_SERVICE
|
|
Goto U_W_Return
|
|
endif
|
|
Set UW_KeyServices = $($R1)
|
|
|
|
OpenRegKey $(UW_KeyServices) "" "WinSock\Parameters" $(MAXIMUM_ALLOWED) UW_KeyParameters
|
|
|
|
Ifstr(i) $(UW_KeyParameters) == $(KeyNull)
|
|
;
|
|
; Service is not correctly installed or not installed
|
|
;
|
|
set UW_KeyWinSock = $(KeyNull)
|
|
set UW_RestoreKeys = FALSE
|
|
set UW_TempKeyName = ""
|
|
set UW_TempKey = $(KeyNull)
|
|
OpenRegKey $(UW_KeyServices) "" "WinSock" $(MAXIMUM_ALLOWED) UW_KeyWinSock
|
|
Ifstr(i) $(UW_KeyWinSock) != $(KeyNull)
|
|
;
|
|
; Service is not correctly installed,
|
|
; save the everything away and then delete the key
|
|
; later after it has been installed, reload the saved
|
|
; child keys and values
|
|
;
|
|
set UW_RestoreKeys = TRUE
|
|
set UW_TempKeyName = "WinSockMergeVolatile"
|
|
Shell "", CopyRegTreeAs $(UW_KeyWinSock) $(UW_KeyServices) $(UW_TempKeyName)
|
|
set UW_TempKey = $($R1)
|
|
CloseRegKey $(UW_KeyWinSock)
|
|
DeleteRegTree $(UW_KeyServices) "WinSock"
|
|
|
|
|
|
Endif
|
|
|
|
Debug-Output "UTILITY.INF: Create WinSock Service"
|
|
Shell "", CreateService, "WinSock", "", "", "adapter", "", {}
|
|
Set RegistryErrorIndex = $($R0)
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
Debug-Output "UTILITY.INF: CreateService for WinSock returned "$(RegistryErrorIndex)
|
|
ifstr(i) $(UW_RestoreKeys) == TRUE
|
|
CloseRegKey $(UW_TempKey)
|
|
Endif
|
|
Goto U_W_Return
|
|
Endif
|
|
set UW_KeyWinSock = $($R1)
|
|
Set UW_KeyParameters = $($R2)
|
|
|
|
;
|
|
; Copy the temp key back into the Winsock key,
|
|
; then we delete it
|
|
;
|
|
ifstr(i) $(UW_RestoreKeys) == TRUE
|
|
Shell "", CopyRegTreeAs $(UW_TempKey) $(UW_KeyWinSock) ""
|
|
CloseRegKey $(UW_TempKey)
|
|
DeleteRegTree $(UW_KeyServices) "WinSockMergeVolatile"
|
|
Endif
|
|
|
|
CloseRegKey $(UW_KeyWinSock)
|
|
CloseRegKey $($R3)
|
|
Else
|
|
Debug-Output "UTILITY.INF: Open WinSock Service"
|
|
Endif
|
|
|
|
Ifstr(i) $(UW_KeyParameters) == $(KeyNull)
|
|
Set RegistryErrorIndex = UNABLE_ACCESS_CONFIGURE_SERVICE
|
|
Goto U_W_Return
|
|
Endif
|
|
;
|
|
; Get the old REG_MULTI_SZ containing the list of supported transports;
|
|
; add the new transport service name to the list or remove it.
|
|
;
|
|
GetRegValue $(UW_KeyParameters) "Transports" UW_TransportsValue
|
|
Ifint $(RegLastError) == $(!REG_ERROR_SUCCESS)
|
|
Set UW_TransportsList = *($(UW_TransportsValue), 4)
|
|
Else
|
|
Set UW_TransportsList = {}
|
|
Endif
|
|
|
|
Ifstr(i) $(UW_TransportsList) == ""
|
|
Set UW_TransportsList = {}
|
|
Endif
|
|
;
|
|
; If we're removing the transport, do so; else, append it to the
|
|
; end of the list.
|
|
;
|
|
Ifstr(i) $(UW_Adding) == "TRUE"
|
|
Set UW_TransportsList = >($(UW_TransportsList), $(UW_NameOfService))
|
|
Else
|
|
Set UW_NewList = {}
|
|
ForListDo $(UW_TransportsList)
|
|
Ifstr(i) $($) != $(UW_NameOfService)
|
|
Set UW_NewList = >($(UW_NewList), $($))
|
|
Endif
|
|
EndForListDo
|
|
Set UW_TransportsList = $(UW_NewList)
|
|
Endif
|
|
|
|
SetRegValue $(UW_KeyParameters) {Transports, $(NoTitle), $(!REG_VT_MULTI_SZ), $(UW_TransportsList)}
|
|
|
|
Debug-Output "UTILITY.INF: WinSock transport info added/deleted for "$(UW_NameOfService)
|
|
|
|
U_W_Return = +
|
|
Ifstr $(UW_KeyParameters) != $(KeyNull)
|
|
CloseRegKey $(UW_KeyParameters)
|
|
Endif
|
|
Ifstr $(UW_KeyServices) != $(KeyNull)
|
|
CloseRegKey $(UW_KeyServices)
|
|
Endif
|
|
|
|
Return $(RegistryErrorIndex)
|
|
|
|
;*************************************************************************
|
|
; end of section UpdateWinsockService
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: UpdateWinsockMappings
|
|
;
|
|
; PURPOSE: This function calls into CPLSetup to get new mapping
|
|
; information for the protocol
|
|
;
|
|
; ARGUMENTS: $0 Service name of transport driver
|
|
; $1 DLL name for WinSock interface to transport
|
|
;
|
|
; RETURNS: $R0 Registry error code or zero if no error
|
|
; $R1 Key handle to <service>\Parameters\Winsock
|
|
;
|
|
; REFERENCES: none
|
|
;
|
|
; MODIFIES: none
|
|
;
|
|
;*************************************************************************
|
|
[UpdateWinsockMappings]
|
|
read-syms InitBaseVars
|
|
Set AW_NameOfService = $($0)
|
|
Set AW_DLLName = $($1)
|
|
|
|
Shell "", BaseServiceKey
|
|
Set RegistryErrorIndex = $($R0)
|
|
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
Set RegistryErrorIndex = UNABLE_ACCESS_CONFIGURE_SERVICE
|
|
Goto M_W_Return
|
|
endif
|
|
|
|
OpenRegKey $($R1) "" $(AW_NameOfService)"\Parameters\Winsock" $(MAXIMUM_ALLOWED) KeyWinsock
|
|
|
|
Ifstr(i) $(KeyWinsock) == ""
|
|
Set RegistryErrorIndex = UNABLE_ACCESS_CONFIGURE_SERVICE
|
|
Goto M_W_Return
|
|
Endif
|
|
|
|
Set FLibraryErrCtl = 1
|
|
LibraryProcedure MW_MapResult $(!NCPA_HANDLE), CPlSetup, $(!STF_HWND), WINSOCKMAP, $(AW_DLLName), $(KeyWinsock)
|
|
Set FLibraryErrCtl = 0
|
|
Set AW_MapError = *($(MW_MapResult),1)
|
|
|
|
Ifint $(AW_MapError) != 0
|
|
Debug-Output "UTILITY.INF: [UpdateWinsockMappings] WINSOCKMAP returned "$(AW_MapError)
|
|
Set RegistryErrorIndex = UNABLE_ACCESS_WINSOCK_MAP_INFO
|
|
Goto M_W_Return
|
|
Endif
|
|
|
|
|
|
M_W_Return = +
|
|
Ifstr $(KeyWinsock) != $(KeyNull)
|
|
CloseRegKey $(KeyWinsock)
|
|
Endif
|
|
Return $(RegistryErrorIndex)
|
|
;*************************************************************************
|
|
; end of section AddWinsockInfo
|
|
;*************************************************************************
|
|
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: AddWinsockInfo
|
|
;
|
|
; PURPOSE: This function adds WinSock sockets provider info
|
|
; to a transport.
|
|
;
|
|
; ARGUMENTS: $0 Service name of transport driver
|
|
; $1 DLL name for WinSock interface to transport
|
|
; $2 integer value for MaxSockAddrLength
|
|
; $3 integer value for MinSockAddrLength
|
|
;
|
|
; RETURNS: $R0 Registry error code or zero if no error
|
|
; $R1 Key handle to <service>\Parameters\Winsock
|
|
;
|
|
; REFERENCES: none
|
|
;
|
|
; MODIFIES: none
|
|
;
|
|
;
|
|
; NOTES: This function/section calls the NCPA function CPlSetup
|
|
; to bind to the DLL in question and add the value of the
|
|
; export function WSHWinSockMapping() to the Registry under
|
|
; the "<service>\Parameters\Winsock:Mapping" value. To do
|
|
; this, the Registry key handle in SETUP form is passed
|
|
; to the NCPA export.
|
|
;
|
|
;
|
|
;*************************************************************************
|
|
[AddWinsockInfo]
|
|
read-syms InitBaseVars
|
|
;
|
|
; Get the base key handle for the services area
|
|
;
|
|
Set AW_NameOfService = $($0)
|
|
Set AW_DLLName = $($1)
|
|
Set AW_MaxAddrLgt = $($2)
|
|
Set AW_MinAddrLgt = $($3)
|
|
|
|
Set AW_KeyServices = $(KeyNull)
|
|
Set AW_KeyParameters = $(KeyNull)
|
|
Set AW_KeySockets = $(KeyNull)
|
|
|
|
Shell "", AddAFD
|
|
Set RegistryErrorIndex = $($R0)
|
|
|
|
Ifstr(i) $(RegistryErrorIndex) == NO_ERROR
|
|
Shell "", BaseServiceKey
|
|
Set RegistryErrorIndex = $($R0)
|
|
Endif
|
|
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
Set RegistryErrorIndex = UNABLE_ACCESS_CONFIGURE_SERVICE
|
|
Goto A_W_Return
|
|
endif
|
|
Set AW_KeyServices = $($R1)
|
|
|
|
OpenRegKey $(AW_KeyServices) "" $(AW_NameOfService)"\Parameters" $(MAXIMUM_ALLOWED) AW_KeyParameters
|
|
Ifstr(i) $(AW_KeyParameters) == $(KeyNull)
|
|
Set RegistryErrorIndex = UNABLE_ACCESS_CONFIGURE_SERVICE
|
|
Goto A_W_Return
|
|
Endif
|
|
|
|
OpenRegKey $(AW_KeyParameters) "" "Winsock" $(MAXIMUM_ALLOWED) AW_KeySockets
|
|
Ifstr(i) $(AW_KeySockets) == $(KeyNull)
|
|
CreateRegKey $(AW_KeyParameters) {Winsock,$(NoTitle),GenericClass} "" $(MAXIMUM_ALLOWED) "" AW_KeySockets
|
|
Endif
|
|
|
|
Ifstr(i) $(AW_KeySockets) == $(KeyNull)
|
|
Set RegistryErrorIndex = UNABLE_ACCESS_CONFIGURE_SERVICE
|
|
Goto A_W_Return
|
|
Endif
|
|
|
|
Set AW_ValueList = {{HelperDllName ,$(NoTitle),$(!REG_VT_EXPAND_SZ),$(AW_DLLName)},+
|
|
{MaxSockAddrLength,$(NoTitle),$(!REG_VT_DWORD),$(AW_MaxAddrLgt)},+
|
|
{MinSockAddrLength,$(NoTitle),$(!REG_VT_DWORD),$(AW_MinAddrLgt)}}
|
|
|
|
Shell "", AddValueList, $(AW_KeySockets), $(AW_ValueList)
|
|
|
|
Set RegistryErrorIndex = $($R0)
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
Debug-Output "UTILITY.INF: [AddWinsockInfo] Registry error: Add value list"
|
|
Endif
|
|
;
|
|
; Extract the WinSock mapping information from the DLL
|
|
;
|
|
Set FLibraryErrCtl = 1
|
|
LibraryProcedure AW_MapResult $(!NCPA_HANDLE), CPlSetup, $(!STF_HWND), WINSOCKMAP, $(AW_DLLName), $(AW_KeySockets)
|
|
Set FLibraryErrCtl = 0
|
|
|
|
Set AW_MapError = *($(AW_MapResult),1)
|
|
Ifint $(AW_MapError) != 0
|
|
Debug-Output "UTILITY.INF: [AddWinsockInfo] WINSOCKMAP returned "$(AW_MapError)
|
|
Set RegistryErrorIndex = UNABLE_ACCESS_WINSOCK_MAP_INFO
|
|
Goto A_W_Return
|
|
Endif
|
|
;
|
|
; Add this service to the WinSock transports list.
|
|
;
|
|
Shell "" UpdateWinsockService $(AW_NameOfService) TRUE
|
|
Set RegistryErrorIndex = $($R0)
|
|
|
|
A_W_Return = +
|
|
Ifstr $(AW_KeySockets) != $(KeyNull)
|
|
CloseRegKey $(AW_KeySockets)
|
|
Endif
|
|
Ifstr $(AW_KeyParameters) != $(KeyNull)
|
|
CloseRegKey $(AW_KeyParameters)
|
|
Endif
|
|
Ifstr $(AW_KeyServices) != $(KeyNull)
|
|
CloseRegKey $(AW_KeyServices)
|
|
Endif
|
|
|
|
Return $(RegistryErrorIndex)
|
|
|
|
;*************************************************************************
|
|
; end of section AddWinsockInfo
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: RemoveWinsockInfo
|
|
;
|
|
; PURPOSE: This function removes WinSock sockets provider
|
|
; information from a transport
|
|
;
|
|
; ARGUMENTS: $0 Service name of transport driver
|
|
;
|
|
; RETURNS: $R0 Registry error code or zero if no error
|
|
;
|
|
; REFERENCES: none
|
|
;
|
|
; MODIFIES: none
|
|
;
|
|
;
|
|
;*************************************************************************
|
|
[RemoveWinsockInfo]
|
|
read-syms InitBaseVars
|
|
;
|
|
; Get the base key handle for the services area
|
|
;
|
|
Set RW_NameOfService = $($0)
|
|
|
|
Set RW_KeyServices = $(KeyNull)
|
|
Set RW_KeySockets = $(KeyNull)
|
|
|
|
Shell "", BaseServiceKey
|
|
Set RegistryErrorIndex = $($R0)
|
|
|
|
Ifstr(i) $(RegistryErrorIndex) != NO_ERROR
|
|
Set RegistryErrorIndex = UNABLE_ACCESS_CONFIGURE_SERVICE
|
|
Goto R_W_Return
|
|
endif
|
|
|
|
Set RW_KeyServices = $($R1)
|
|
|
|
OpenRegKey $(RW_KeyServices) "" $(RW_NameOfService)"\Parameters" $(MAXIMUM_ALLOWED) RW_KeySockets
|
|
Ifstr(i) $(RW_KeySockets) == $(KeyNull)
|
|
Set RegistryErrorIndex = NO_ERROR
|
|
else
|
|
;
|
|
; Delete the \Parameters\Winsock key. Ignore errors, since the service
|
|
; is almost certainly being deinstalled.
|
|
;
|
|
DeleteRegTree $(RW_KeySockets) "Winsock"
|
|
Endif
|
|
;
|
|
; Remove this service from the WinSock transports list.
|
|
;
|
|
Shell "" UpdateWinsockService $(RW_NameOfService) FALSE
|
|
Set RegistryErrorIndex = $($R0)
|
|
|
|
R_W_Return = +
|
|
Ifstr $(RW_KeySockets) != $(KeyNull)
|
|
CloseRegKey $(RW_KeySockets)
|
|
Endif
|
|
Ifstr $(RW_KeyServices) != $(KeyNull)
|
|
CloseRegKey $(RW_KeyServices)
|
|
Endif
|
|
|
|
Return $(RegistryErrorIndex)
|
|
|
|
;*************************************************************************
|
|
; end of section RemoveWinsockInfo
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: GetBindingInfo
|
|
;
|
|
; PURPOSE: This function returns the bindable rules for the given
|
|
; manufacturer.
|
|
;
|
|
; ARGUMENTS: $0 manufacturer name
|
|
;
|
|
; RETURNS: $R0 Registry error code or zero if no error
|
|
; $R1 Bindable rule
|
|
;
|
|
; REFERENCES: none
|
|
;
|
|
; MODIFIES: none
|
|
;
|
|
;
|
|
;*************************************************************************
|
|
|
|
[BindingInfo-DEC]
|
|
BindingInfo = {+
|
|
"lanceDriver dec100Adapter non exclusive 100",+
|
|
"lanceDriver dec101Adapter non exclusive 100",+
|
|
"lanceDriver decetherworksturboAdapter non exclusive 100",+
|
|
"lanceDriver dec422Adapter non exclusive 100",+
|
|
"lanceDriver decpcAdapter non exclusive 100",+
|
|
"lanceDriver decstatAdapter non exclusive 100"+
|
|
}
|
|
|
|
[BindingInfo-WD]
|
|
BindingInfo = {+
|
|
"smc8000nDriver smcisaAdapter non exclusive 100",+
|
|
"smc8000nDriver wd8003eaAdapter non exclusive 100",+
|
|
"smc8000nDriver wd8003waAdapter non exclusive 100",+
|
|
"smc8000nDriver wd8013epaAdapter non exclusive 100",+
|
|
"smc8000nDriver wd8013wpaAdapter non exclusive 100"+
|
|
}
|
|
[BindingInfo-PROTEON]
|
|
BindingInfo = {+
|
|
"proteonDriver p1990Adapter non exclusive 100",+
|
|
"proteonDriver p1390Adapter non exclusive 100"+
|
|
}
|
|
|
|
[BindingInfo-PRONET16]
|
|
BindingInfo = {+
|
|
"pronet16Driver p199XAdapter non exclusive 100",+
|
|
"pronet16Driver p139XAdapter non exclusive 100"+
|
|
}
|
|
|
|
[BindingInfo-IBMTOK2E]
|
|
BindingInfo = {+
|
|
"ibmtok2eDriver ibmtok2eAdapter non exclusive 100"+
|
|
}
|
|
|
|
[BindingInfo-IBM]
|
|
BindingInfo = {"ibmtokDriver ibmtokAdapter non exclusive 100",+
|
|
"ibmtokDriver ibmtokmcAdapter non exclusive 100"}
|
|
|
|
[GetBindingInfo]
|
|
set BindingInfo = {}
|
|
read-syms BindingInfo-$($0)
|
|
return "NO_ERROR", $(BindingInfo)
|
|
|
|
;*************************************************************************
|
|
; end of section GetBindingInfo
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: AddStreams
|
|
;
|
|
; PURPOSE: Add Streams component
|
|
;
|
|
; ARGUMENTS: nothing
|
|
;
|
|
; RETURNS: $R0 error code
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
|
|
[AddStreams]
|
|
read-syms InitBaseVars
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(ServicesBaseName)"\streams" $(MAXIMUM_ALLOWED) BS_KeyServices
|
|
|
|
Ifstr $(BS_KeyServices) == $(KeyNull)
|
|
|
|
set OldOption = $(!NTN_InfOption)
|
|
set !NTN_InfOption = STREAMS
|
|
Shell "oemnxpst.inf" InstallOption $(!STF_LANGUAGE) "STREAMS" $(!STF_SRCDIR) $(!NtLmAddCopy) $(!NtLmDoCopy) $(!NtLmDoConfig)
|
|
set !NTN_InfOption = $(OldOption)
|
|
else
|
|
CloseRegKey $(BS_KeyServices)
|
|
Debug-Output "UTILITY.INF: streams already installed"
|
|
endif
|
|
;
|
|
; Increase the reference counter
|
|
;
|
|
Shell "", IncrementRefCount, "Software\Microsoft\streams\CurrentVersion"
|
|
|
|
AddStreamsReturn = +
|
|
return NO_ERROR
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: RemoveStreams
|
|
;
|
|
; PURPOSE: Remove Streams component
|
|
;
|
|
; ARGUMENTS: nothing
|
|
;
|
|
; RETURNS: $R0 error code
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
|
|
[RemoveStreams]
|
|
read-syms InitBaseVars
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(ServicesBaseName)"\streams" $(MAXIMUM_ALLOWED) BS_KeyServices
|
|
|
|
Ifstr $(BS_KeyServices) != $(KeyNull)
|
|
CloseRegKey $(BS_KeyServices)
|
|
Shell "", DecrementRefCount, "Software\Microsoft\streams\CurrentVersion"
|
|
Shell "", IsRefCountEqualZero, "Software\Microsoft\streams\CurrentVersion"
|
|
Ifstr(i) $($R0) != NO_ERROR
|
|
Debug-Output "UTILITY.INF: [RemoveSoftwareComponent] IsRefCountEqualZero returned "$($R0)
|
|
goto RemoveStreamsReturn
|
|
endif
|
|
|
|
Ifint $($R1) != 1
|
|
; if not zero, remove it next time
|
|
goto RemoveStreamsReturn
|
|
endif
|
|
|
|
set OldOption = $(!NTN_InfOption)
|
|
set OldInstallMode = $(!NTN_InstallMode)
|
|
set !NTN_InfOption = STREAMS
|
|
set !NTN_InstallMode = deinstall
|
|
Shell "oemnxpst.inf" InstallOption $(!STF_LANGUAGE) "STREAMS" $(!STF_SRCDIR) $(!NtLmAddCopy) $(!NtLmDoCopy) $(!NtLmDoConfig)
|
|
set !NTN_InfOption = $(OldOption)
|
|
set !NTN_InstallMode = $(OldInstallMode)
|
|
endif
|
|
|
|
RemoveStreamsReturn = +
|
|
return NO_ERROR
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: AddAFD
|
|
;
|
|
; PURPOSE: Add AFD component
|
|
;
|
|
; ARGUMENTS: nothing
|
|
;
|
|
; RETURNS: $R0 error code
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
|
|
[AddAFD]
|
|
read-syms InitBaseVars
|
|
read-syms AFDVars
|
|
Set Result = NO_ERROR
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(ServicesBaseName)"\AFD" $(MAXIMUM_ALLOWED) BS_KeyServices
|
|
|
|
Ifstr $(BS_KeyServices) == $(KeyNull)
|
|
|
|
Shell "", CreateService, $(ProductAFDName),+
|
|
$(ProductAFDTitle),+
|
|
$(ProductAFDImagePath),+
|
|
$(ProductAFDSvcType), "TDI", {}, "",+
|
|
"%SystemRoot%\System32\IoLogMsg.dll"
|
|
Set Result = $($R0)
|
|
else
|
|
CloseRegKey $(BS_KeyServices)
|
|
endif
|
|
|
|
AddAFDReturn = +
|
|
return $(Result)
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: UpgradeAFD
|
|
;
|
|
; PURPOSE: Upgrade the AFD component
|
|
;
|
|
; ARGUMENTS: nothing
|
|
;
|
|
; RETURNS: $R0 error code
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
|
|
[UpgradeAFD]
|
|
read-syms InitBaseVars
|
|
Set Result = NO_ERROR
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(ServicesBaseName)"\AFD" $(MAXIMUM_ALLOWED) BS_KeyServices
|
|
|
|
Ifstr $(BS_KeyServices) != $(KeyNull)
|
|
;
|
|
; add group value
|
|
;
|
|
SetRegValue $(BS_KeyServices) {Group,$(NoTitle),$(!REG_VT_SZ),"TDI"}
|
|
|
|
CloseRegKey $(BS_KeyServices)
|
|
endif
|
|
|
|
return $(Result)
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: GetBusTypeNum
|
|
;
|
|
; PURPOSE: return the Bus Type Number
|
|
;
|
|
; ARGUMENTS: nothing
|
|
;
|
|
; RETURNS: $R0 error code
|
|
; $R1 bus number
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
|
|
[GetBusTypeNum]
|
|
read-syms InitBaseVars
|
|
set DetCard = $(!p:DetectedCard)
|
|
ifstr(i) $(DetCard) == ""
|
|
set DetCard = FALSE
|
|
endif
|
|
ifstr(i) $(DetCard) == FALSE
|
|
; Assume it is an ISA Bus
|
|
set BusType = 1
|
|
ifstr(i) $(!STF_BUSTYPE) == "ISA"
|
|
set BusType = 1
|
|
else-ifstr(i) $(!STF_BUSTYPE) == "EISA"
|
|
set BusType = 2
|
|
else-ifstr(i) $(!STF_BUSTYPE) == "Jazz-Internal Bus"
|
|
set BusType = 0
|
|
else-ifstr(i) $(!STF_BUSTYPE) == "MCA"
|
|
set BusType = 3
|
|
else-ifstr(i) $(!STF_BUSTYPE) == "TCChannel"
|
|
set BusType = 4
|
|
else-ifstr(i) $(!STF_BUSTYPE) == "PCI"
|
|
set BusType = 5
|
|
else-ifstr(i) $(!STF_BUSTYPE) == "PCMCIA"
|
|
;
|
|
; when we have plug and play, we need to change it to 8 (not 1)
|
|
;
|
|
set BusType = 1
|
|
else
|
|
debug-output "Utility.inf: Unknown bus type"
|
|
endif
|
|
else
|
|
set BusType = *($(!STF_NCDETINFO),5)
|
|
endif
|
|
return NO_ERROR, $(BusType)
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: AddRpcProtocol
|
|
;
|
|
; PURPOSE: Update the sections of the SOFTWARE\Microsoft\Rpc keys
|
|
; to reflect the presenceof a new protocol in the system.
|
|
;
|
|
; ARGUMENTS: $0 complete RPC protocol string; e.g., "ncacn_ip_tcp"
|
|
; $1 name of client DLL (no path); e.g., "rpclt1.dll"
|
|
; $2 name of server DLL (no path); e.g., "rpclt1.dll"
|
|
;
|
|
; RETURNS: $R0 STATUS_SUCCESSFUL if ok; error otherwise.
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;
|
|
;*************************************************************************
|
|
[AddRpcProtocol]
|
|
Set ARP_Protocol = $($0)
|
|
Set ARP_ClientDll = $($1)
|
|
Set ARP_ServerDll = $($2)
|
|
read-syms InitBaseVars
|
|
Set ARP_KeyRpc = $(KeyNull)
|
|
Set ARP_KeyRpcServer = $(KeyNull)
|
|
Set ARP_KeyRpcClient = $(KeyNull)
|
|
Set RegistryErrorIndex = UNABLE_ACCESS_SOFTWARE_REG
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" "SOFTWARE\Microsoft\Rpc" $(MAXIMUM_ALLOWED) ARP_KeyRpc
|
|
|
|
Ifstr(i) $(ARP_KeyRpc) == $(KeyNull)
|
|
Goto ARP_Return
|
|
Endif
|
|
|
|
OpenRegKey $(ARP_KeyRpc) "" "ClientProtocols" $(MAXIMUM_ALLOWED) ARP_KeyClient
|
|
Ifstr(i) $(ARP_KeyClient) == $(KeyNull)
|
|
Goto ARP_Return
|
|
Endif
|
|
|
|
OpenRegKey $(ARP_KeyRpc) "" "ServerProtocols" $(MAXIMUM_ALLOWED) ARP_KeyServer
|
|
Ifstr(i) $(ARP_KeyServer) == $(KeyNull)
|
|
Goto ARP_Return
|
|
Endif
|
|
|
|
SetRegValue $(ARP_KeyClient) {$(ARP_Protocol),$(NoTitle),$(!REG_VT_SZ),$(ARP_ClientDll)}
|
|
Ifint $(RegLastError) != $(!REG_ERROR_SUCCESS)
|
|
Goto ARP_Return
|
|
Endif
|
|
|
|
SetRegValue $(ARP_KeyServer) {$(ARP_Protocol),$(NoTitle),$(!REG_VT_SZ),$(ARP_ServerDll)}
|
|
Ifint $(RegLastError) != $(!REG_ERROR_SUCCESS)
|
|
Goto ARP_Return
|
|
Endif
|
|
|
|
Set RegistryErrorIndex = NO_ERROR
|
|
|
|
ARP_Return = +
|
|
Ifstr(i) $(ARP_KeyServer) != $(KeyNull)
|
|
CloseRegKey $(ARP_KeyServer)
|
|
Endif
|
|
Ifstr(i) $(ARP_KeyClient) != $(KeyNull)
|
|
CloseRegKey $(ARP_KeyClient)
|
|
Endif
|
|
Ifstr(i) $(ARP_KeyRpc) != $(KeyNull)
|
|
CloseRegKey $(ARP_KeyRpc)
|
|
Endif
|
|
Return $(RegistryErrorIndex)
|
|
|
|
;*************************************************************************
|
|
; end of section AddRpcProtocol
|
|
;*************************************************************************
|
|
|
|
[AddClientRpcProtocol]
|
|
Set ARP_Protocol = $($0)
|
|
Set ARP_ClientDll = $($1)
|
|
read-syms InitBaseVars
|
|
Set ARP_KeyRpc = $(KeyNull)
|
|
Set ARP_KeyRpcClient = $(KeyNull)
|
|
Set RegistryErrorIndex = UNABLE_ACCESS_SOFTWARE_REG
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" "SOFTWARE\Microsoft\Rpc" $(MAXIMUM_ALLOWED) ARP_KeyRpc
|
|
|
|
Ifstr(i) $(ARP_KeyRpc) == $(KeyNull)
|
|
Goto ARP_Return
|
|
Endif
|
|
|
|
OpenRegKey $(ARP_KeyRpc) "" "ClientProtocols" $(MAXIMUM_ALLOWED) ARP_KeyClient
|
|
Ifstr(i) $(ARP_KeyClient) == $(KeyNull)
|
|
Goto ARP_Return
|
|
Endif
|
|
|
|
SetRegValue $(ARP_KeyClient) {$(ARP_Protocol),$(NoTitle),$(!REG_VT_SZ),$(ARP_ClientDll)}
|
|
Ifint $(RegLastError) != $(!REG_ERROR_SUCCESS)
|
|
Goto ARP_Return
|
|
Endif
|
|
|
|
Set RegistryErrorIndex = NO_ERROR
|
|
|
|
ARP_Return = +
|
|
Ifstr(i) $(ARP_KeyClient) != $(KeyNull)
|
|
CloseRegKey $(ARP_KeyClient)
|
|
Endif
|
|
Ifstr(i) $(ARP_KeyRpc) != $(KeyNull)
|
|
CloseRegKey $(ARP_KeyRpc)
|
|
Endif
|
|
Return $(RegistryErrorIndex)
|
|
|
|
[AddServerRpcProtocol]
|
|
Set ARP_Protocol = $($0)
|
|
Set ARP_ServerDll = $($1)
|
|
read-syms InitBaseVars
|
|
Set ARP_KeyRpc = $(KeyNull)
|
|
Set ARP_KeyRpcServer = $(KeyNull)
|
|
Set RegistryErrorIndex = UNABLE_ACCESS_SOFTWARE_REG
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" "SOFTWARE\Microsoft\Rpc" $(MAXIMUM_ALLOWED) ARP_KeyRpc
|
|
|
|
Ifstr(i) $(ARP_KeyRpc) == $(KeyNull)
|
|
Goto ARP_Return
|
|
Endif
|
|
|
|
OpenRegKey $(ARP_KeyRpc) "" "ServerProtocols" $(MAXIMUM_ALLOWED) ARP_KeyServer
|
|
Ifstr(i) $(ARP_KeyServer) == $(KeyNull)
|
|
Goto ARP_Return
|
|
Endif
|
|
|
|
SetRegValue $(ARP_KeyServer) {$(ARP_Protocol),$(NoTitle),$(!REG_VT_SZ),$(ARP_ServerDll)}
|
|
Ifint $(RegLastError) != $(!REG_ERROR_SUCCESS)
|
|
Goto ARP_Return
|
|
Endif
|
|
|
|
Set RegistryErrorIndex = NO_ERROR
|
|
|
|
ARP_Return = +
|
|
Ifstr(i) $(ARP_KeyServer) != $(KeyNull)
|
|
CloseRegKey $(ARP_KeyServer)
|
|
Endif
|
|
Ifstr(i) $(ARP_KeyRpc) != $(KeyNull)
|
|
CloseRegKey $(ARP_KeyRpc)
|
|
Endif
|
|
Return $(RegistryErrorIndex)
|
|
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: AddMixRpcProtocol
|
|
;
|
|
; PURPOSE: Update the sections of the SOFTWARE\Microsoft\Rpc keys
|
|
; to reflect the presenceof a new protocol in the system.
|
|
; Update if and only if two services exist
|
|
;
|
|
; ARGUMENTS: $0 & $1 The two related services
|
|
; $2 complete RPC protocol string; e.g., "ncacn_ip_tcp"
|
|
; $3 name of client DLL (no path); e.g., "rpclt1.dll"
|
|
; $4 name of server DLL (no path); e.g., "rpclt1.dll"
|
|
;
|
|
; RETURNS: $R0 STATUS_SUCCESSFUL if ok; error otherwise.
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;
|
|
;*************************************************************************
|
|
|
|
;
|
|
; WARNING: If you change the lists below, you will need to modify OemNsvRp.INF lists
|
|
; also. See [UpgradeMapConstants]
|
|
;
|
|
[UpgradeRPCMapConstants]
|
|
; must be changed to rpclt1.dll
|
|
DLLClientList = { "rpcltc3.dll", "rpcltc6.dll", "rpcltc5.dll", "rpcltc7.dll", "rpcdgc3.dll", "rpcltccm.dll", "rpcltc1.dll" }
|
|
|
|
; must be changed to rpclt1.dll
|
|
DLLServerList = { "rpclts3.dll", "rpclts6.dll", "rpclts5.dll", "rpclts7.dll", "rpcdgs3.dll", "rpcltscm.dll", "rpclts1.dll" }
|
|
|
|
[AddMixRpcProtocol]
|
|
set ServiceA = $($0)
|
|
set ServiceB = $($1)
|
|
Set ARP_Protocol = $($2)
|
|
Set ARP_ClientDll = $($3)
|
|
Set ARP_ServerDll = $($4)
|
|
read-syms InitBaseVars
|
|
read-syms UpgradeRPCMapConstants
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" "System\CurrentControlSet\Services\"$(ServiceA) $(MAXIMUM_ALLOWED) KeyServiceA
|
|
OpenRegKey $(!REG_H_LOCAL) "" "System\CurrentControlSet\Services\"$(ServiceB) $(MAXIMUM_ALLOWED) KeyServiceB
|
|
ifstr(i) $(KeyServiceA) != $(KeyNull)
|
|
ifstr(i) $(KeyServiceB) != $(KeyNull)
|
|
;
|
|
; if the request is add a old name, change it the new version
|
|
;
|
|
Ifcontains(i) $(ARP_ClientDll) in $(DLLClientList)
|
|
Debug-Output "UTILITY.INF: AddMixRpcProtocol tried to add old "$(ARP_ClientDll)", changed to rpclt1.dll!"
|
|
set ARP_ClientDll = "rpclt1.dll"
|
|
Endif
|
|
Ifcontains(i) $(ARP_ServerDll) in $(DLLServerList)
|
|
Debug-Output "UTILITY.INF: AddMixRpcProtocol tried to add old "$(ARP_ServerDll)", changed to rpclt1.dll!"
|
|
set ARP_ServerDll = "rpclt1.dll"
|
|
Endif
|
|
|
|
Shell "" AddRpcProtocol $(ARP_Protocol) $(ARP_ClientDll) $(ARP_ServerDll)
|
|
set ReturnCode = $($R0)
|
|
endif
|
|
endif
|
|
|
|
set ReturnCode = NO_ERROR
|
|
|
|
return_AddMixRpcProtocl = +
|
|
return $(ReturnCode)
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: RemoveRpcProtocol
|
|
;
|
|
; PURPOSE: Remove information about an installed RPC protocol.
|
|
;
|
|
; ARGUMENTS: $0 complete RPC protocol string (see [AddRpcProtocol]).
|
|
;
|
|
; RETURNS: $R0 STATUS_SUCCESSFUL if ok; error otherwise.
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;
|
|
;*************************************************************************
|
|
[RemoveRpcProtocol]
|
|
Set RRP_Protocol = $($0)
|
|
read-syms InitBaseVars
|
|
Set RRP_KeyRpc = $(KeyNull)
|
|
Set RRP_KeyRpcServer = $(KeyNull)
|
|
Set RRP_KeyRpcClient = $(KeyNull)
|
|
Set RegistryErrorIndex = UNABLE_ACCESS_SOFTWARE_REG
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" "SOFTWARE\Microsoft\Rpc" $(MAXIMUM_ALLOWED) RRP_KeyRpc
|
|
|
|
Ifstr(i) $(RRP_KeyRpc) == $(KeyNull)
|
|
Goto RRP_Return
|
|
Endif
|
|
|
|
OpenRegKey $(RRP_KeyRpc) "" "ClientProtocols" $(MAXIMUM_ALLOWED) RRP_KeyClient
|
|
Ifstr(i) $(RRP_KeyClient) == $(KeyNull)
|
|
Goto RRP_Return
|
|
Endif
|
|
|
|
OpenRegKey $(RRP_KeyRpc) "" "ServerProtocols" $(MAXIMUM_ALLOWED) RRP_KeyServer
|
|
Ifstr(i) $(RRP_KeyServer) == $(KeyNull)
|
|
Goto RRP_Return
|
|
Endif
|
|
|
|
DeleteRegValue $(RRP_KeyClient) $(RRP_Protocol)
|
|
Ifint $(RegLastError) != $(!REG_ERROR_SUCCESS)
|
|
Goto RRP_Return
|
|
Endif
|
|
|
|
DeleteRegValue $(RRP_KeyServer) $(RRP_Protocol)
|
|
Ifint $(RegLastError) != $(!REG_ERROR_SUCCESS)
|
|
Goto RRP_Return
|
|
Endif
|
|
|
|
Set RegistryErrorIndex = NO_ERROR
|
|
|
|
RRP_Return = +
|
|
Ifstr(i) $(RRP_KeyServer) != $(KeyNull)
|
|
CloseRegKey $(RRP_KeyServer)
|
|
Endif
|
|
Ifstr(i) $(RRP_KeyClient) != $(KeyNull)
|
|
CloseRegKey $(RRP_KeyClient)
|
|
Endif
|
|
Ifstr(i) $(RRP_KeyRpc) != $(KeyNull)
|
|
CloseRegKey $(RRP_KeyRpc)
|
|
Endif
|
|
Return $(RegistryErrorIndex)
|
|
|
|
;*************************************************************************
|
|
; end of section RemoveRpcProtocl
|
|
;*************************************************************************
|
|
|
|
[RemoveClientRpcProtocol]
|
|
Set RRP_Protocol = $($0)
|
|
read-syms InitBaseVars
|
|
Set RRP_KeyRpc = $(KeyNull)
|
|
Set RRP_KeyRpcClient = $(KeyNull)
|
|
Set RegistryErrorIndex = UNABLE_ACCESS_SOFTWARE_REG
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" "SOFTWARE\Microsoft\Rpc" $(MAXIMUM_ALLOWED) RRP_KeyRpc
|
|
|
|
Ifstr(i) $(RRP_KeyRpc) == $(KeyNull)
|
|
Goto RRP_Return
|
|
Endif
|
|
|
|
OpenRegKey $(RRP_KeyRpc) "" "ClientProtocols" $(MAXIMUM_ALLOWED) RRP_KeyClient
|
|
Ifstr(i) $(RRP_KeyClient) == $(KeyNull)
|
|
Goto RRP_Return
|
|
Endif
|
|
|
|
DeleteRegValue $(RRP_KeyClient) $(RRP_Protocol)
|
|
Ifint $(RegLastError) != $(!REG_ERROR_SUCCESS)
|
|
Goto RRP_Return
|
|
Endif
|
|
|
|
Set RegistryErrorIndex = NO_ERROR
|
|
|
|
RRP_Return = +
|
|
Ifstr(i) $(RRP_KeyClient) != $(KeyNull)
|
|
CloseRegKey $(RRP_KeyClient)
|
|
Endif
|
|
Ifstr(i) $(RRP_KeyRpc) != $(KeyNull)
|
|
CloseRegKey $(RRP_KeyRpc)
|
|
Endif
|
|
Return $(RegistryErrorIndex)
|
|
|
|
[RemoveServerRpcProtocol]
|
|
Set RRP_Protocol = $($0)
|
|
read-syms InitBaseVars
|
|
Set RRP_KeyRpc = $(KeyNull)
|
|
Set RRP_KeyRpcServer = $(KeyNull)
|
|
Set RegistryErrorIndex = UNABLE_ACCESS_SOFTWARE_REG
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" "SOFTWARE\Microsoft\Rpc" $(MAXIMUM_ALLOWED) RRP_KeyRpc
|
|
|
|
Ifstr(i) $(RRP_KeyRpc) == $(KeyNull)
|
|
Goto RRP_Return
|
|
Endif
|
|
|
|
OpenRegKey $(RRP_KeyRpc) "" "ServerProtocols" $(MAXIMUM_ALLOWED) RRP_KeyServer
|
|
Ifstr(i) $(RRP_KeyServer) == $(KeyNull)
|
|
Goto RRP_Return
|
|
Endif
|
|
|
|
DeleteRegValue $(RRP_KeyServer) $(RRP_Protocol)
|
|
Ifint $(RegLastError) != $(!REG_ERROR_SUCCESS)
|
|
Goto RRP_Return
|
|
Endif
|
|
|
|
Set RegistryErrorIndex = NO_ERROR
|
|
|
|
RRP_Return = +
|
|
Ifstr(i) $(RRP_KeyServer) != $(KeyNull)
|
|
CloseRegKey $(RRP_KeyServer)
|
|
Endif
|
|
Ifstr(i) $(RRP_KeyRpc) != $(KeyNull)
|
|
CloseRegKey $(RRP_KeyRpc)
|
|
Endif
|
|
Return $(RegistryErrorIndex)
|
|
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: GetInfFileNameFromRegistry
|
|
;
|
|
; PURPOSE: get the inf file name from the product' NetRules section.
|
|
;
|
|
; ARGUMENTS: $0 product key handle
|
|
; (ie, system\software\Microsoft\Lance\CurrentVersion)
|
|
;
|
|
; RETURNS: $R0 Inf file name.
|
|
;
|
|
; REFERENCES: Nothing
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;
|
|
;*************************************************************************
|
|
|
|
[GetInfFileNameFromRegistry]
|
|
read-syms InitBaseVars
|
|
set KeyProduct = $($0)
|
|
set InfName = ""
|
|
|
|
OpenRegKey $(KeyProduct) "" "NetRules" $(!REG_KEY_READ) NetRuleKey
|
|
Ifstr(i) $(NetRuleKey) != $(KeyNull)
|
|
GetRegValue $(NetRuleKey) "InfName" NetRuleInfNameList
|
|
set NetRuleInfName = *($(NetRuleInfNameList), 4)
|
|
Split-String $(NetRuleInfName), "\", FilenameList
|
|
QueryListSize ListSize $(FilenameList)
|
|
set InfName = *($(FilenameList), $(ListSize))
|
|
CloseRegKey $(NetRuleKey)
|
|
endif
|
|
|
|
return $(InfName)
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: ToggleBinding
|
|
;
|
|
; PURPOSE: Take the named binding from the list of "Disabled"
|
|
; bindings and merge it with the active bindings.
|
|
;
|
|
; ARGUMENTS: $0 name of service
|
|
; $1 number of binding
|
|
; $2 "activate" or "disable"
|
|
;
|
|
; RETURNS: $R0 NO_ERROR if OK; RegistryError if not.
|
|
;
|
|
; REFERENCES: None
|
|
;
|
|
; MODIFIES: None
|
|
;
|
|
; NOTES: This routine takes either the given inactive binding
|
|
; and activates it or the given active binding and
|
|
; deactivates it.
|
|
;
|
|
;
|
|
;*************************************************************************
|
|
[ToggleBinding]
|
|
Set SvcName = $($0)
|
|
Set BindNumber = $($1)
|
|
Set Action = $($2)
|
|
Set Status = UNABLE_ACCESS_CONFIGURE_SERVICE
|
|
Set KeySvc = ""
|
|
Set KeyFrom = ""
|
|
Set KeyTo = ""
|
|
|
|
read-syms InitBaseVars
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(ServicesBaseName)"\"$(SvcName) $(MAXIMUM_ALLOWED) KeySvc
|
|
Ifstr(i) $(KeySvc) == $(KeyNull)
|
|
Debug-Output "UTILITY.INF: ToggleBinding: service key open FAILED"
|
|
Goto TB_Return
|
|
Endif
|
|
|
|
Ifstr(i) $(Action) == activate
|
|
Set FromKeyName = "Linkage\Disabled"
|
|
Set ToKeyName = "Linkage"
|
|
Else
|
|
Set FromKeyName = "Linkage"
|
|
Set ToKeyName = "Linkage\Disabled"
|
|
Endif
|
|
|
|
; Open the Linkage and Linkage\Disabled subkeys
|
|
|
|
OpenRegKey $(KeySvc) "" $(FromKeyName) $(MAXIMUM_ALLOWED) KeyFrom
|
|
Ifstr(i) $(KeyFrom) == $(KeyNull)
|
|
Debug-Output "UTILITY.INF: ToggleBinding: from linkage key open FAILED"
|
|
Goto TB_Return
|
|
Endif
|
|
OpenRegKey $(KeySvc) "" $(ToKeyName) $(MAXIMUM_ALLOWED) KeyTo
|
|
Ifstr(i) $(KeyTo) == $(KeyNull)
|
|
Debug-Output "UTILITY.INF: ToggleBinding: to linkage key open FAILED"
|
|
Goto TB_Return
|
|
Endif
|
|
|
|
; Fetch all their values, allowing for complete absence.
|
|
; First, from the "From" key
|
|
|
|
Set FromBindList = {}
|
|
Set FromExportList = {}
|
|
Set FromRouteList = {}
|
|
Set ToBindList = {}
|
|
Set ToExportList = {}
|
|
Set ToRouteList = {}
|
|
Set ErrorTotal = 0
|
|
|
|
Debug-Output "UTILITY.INF: ToggleBinding; fetch all linkage values"
|
|
|
|
GetRegValue $(KeyFrom),"Bind",TempValue
|
|
Ifint $(RegLastError) == $(!REG_ERROR_SUCCESS)
|
|
Set FromBindList = *($(TempValue),4)
|
|
Set-add ErrorTotal = $(ErrorTotal),1
|
|
Endif
|
|
|
|
GetRegValue $(KeyFrom),"Export",TempValue
|
|
Ifint $(RegLastError) == $(!REG_ERROR_SUCCESS)
|
|
Set FromExportList = *($(TempValue),4)
|
|
Set-add ErrorTotal = $(ErrorTotal),1
|
|
Endif
|
|
|
|
GetRegValue $(KeyFrom),"Route",TempValue
|
|
Ifint $(RegLastError) == $(!REG_ERROR_SUCCESS)
|
|
Set FromRouteList = *($(TempValue),4)
|
|
Set-add ErrorTotal = $(ErrorTotal),1
|
|
Endif
|
|
|
|
; Next, from the "To" key
|
|
|
|
GetRegValue $(KeyTo),"Bind",TempValue
|
|
Ifint $(RegLastError) == $(!REG_ERROR_SUCCESS)
|
|
Set ToBindList = *($(TempValue),4)
|
|
Set-add ErrorTotal = $(ErrorTotal),1
|
|
Endif
|
|
|
|
GetRegValue $(KeyTo),"Export",TempValue
|
|
Ifint $(RegLastError) == $(!REG_ERROR_SUCCESS)
|
|
Set ToExportList = *($(TempValue),4)
|
|
Set-add ErrorTotal = $(ErrorTotal),1
|
|
Endif
|
|
|
|
GetRegValue $(KeyTo),"Route",TempValue
|
|
Ifint $(RegLastError) == $(!REG_ERROR_SUCCESS)
|
|
Set ToRouteList = *($(TempValue),4)
|
|
Set-add ErrorTotal = $(ErrorTotal),1
|
|
Endif
|
|
|
|
; We have all the data. Do some sanity checking.
|
|
; Are the lists the same size?
|
|
|
|
Ifint $(ErrorTotal) != 6
|
|
Debug-Output "UTILITY.INF: ToggleBinding; Bind list retreival error, "$(ErrorTotal)
|
|
Endif
|
|
|
|
Debug-Output "UTILITY.INF: ToggleBinding; sanity check results"
|
|
|
|
QueryListSize sz1 $(FromBindList)
|
|
QueryListSize sz2 $(FromExportList)
|
|
QueryListSize sz3 $(FromRouteList)
|
|
Ifint $(sz1) != $(sz2)
|
|
Goto TB_Return
|
|
Endif
|
|
Ifint $(sz1) != $(sz3)
|
|
Goto TB_Return
|
|
Endif
|
|
|
|
QueryListSize sz2 $(ToBindList)
|
|
QueryListSize sz3 $(ToExportList)
|
|
QueryListSize sz4 $(ToRouteList)
|
|
Ifint $(sz2) != $(sz3)
|
|
Goto TB_Return
|
|
Endif
|
|
Ifint $(sz2) != $(sz4)
|
|
Goto TB_Return
|
|
Endif
|
|
|
|
; Does the requested element exist?
|
|
|
|
Debug-Output "UTILITY.INF: ToggleBinding; prepare to move binding"
|
|
|
|
Ifint $(BindNumber) > $(sz1)
|
|
Debug-Output "UTILITY.INF: ToggleBinding; binding to move was invalid"
|
|
Set Status = INVALID_DATA_PASSED
|
|
Endif
|
|
|
|
; We're ready. Move the data around.
|
|
; Extract the element from the "From" lists, append it
|
|
; to the "To" lists...
|
|
|
|
Set FromBindItem = *($(FromBindList),$(BindNumber))
|
|
Set FromRouteItem = *($(FromRouteList),$(BindNumber))
|
|
Set FromExportItem = *($(FromExportList),$(BindNumber))
|
|
|
|
Set ToBindList = >($(ToBindList),$(FromBindItem))
|
|
Set ToRouteList = >($(ToRouteList),$(FromRouteItem))
|
|
Set ToExportList = >($(ToExportList),$(FromExportItem))
|
|
|
|
; Regenerate the "From" lists by iteration.
|
|
|
|
Set NewBind = {}
|
|
Set NewExport = {}
|
|
Set NewRoute = {}
|
|
Set Index = 0
|
|
ForListDo $(FromBindList)
|
|
Set-add Index = $(Index),1
|
|
Ifint $(Index) != $(BindNumber)
|
|
Set NewBind = >($(NewBind),$($))
|
|
Set NewExport = >($(NewExport),*($(FromExportList),$(Index)))
|
|
Set NewRoute = >($(NewRoute),*($(FromRouteList),$(Index)))
|
|
Endif
|
|
EndForListDo
|
|
|
|
; Replace the old values
|
|
|
|
Set FromBindList = $(NewBind)
|
|
Set FromExportList = $(NewExport)
|
|
Set FromRouteList = $(NewRoute)
|
|
|
|
; Update the registry.
|
|
|
|
Set ErrorTotal = 0
|
|
|
|
SetRegValue $(KeyFrom) {Bind,$(NoTitle),$(!REG_VT_MULTI_SZ),$(FromBindList)}
|
|
Ifint $(RegLastError) != $(!REG_ERROR_SUCCESS)
|
|
Set-add ErrorTotal = $(ErrorTotal),1
|
|
Endif
|
|
SetRegValue $(KeyFrom) {Export,$(NoTitle),$(!REG_VT_MULTI_SZ),$(FromExportList)}
|
|
Ifint $(RegLastError) != $(!REG_ERROR_SUCCESS)
|
|
Set-add ErrorTotal = $(ErrorTotal),1
|
|
Endif
|
|
SetRegValue $(KeyFrom) {Route,$(NoTitle),$(!REG_VT_MULTI_SZ),$(FromRouteList)}
|
|
Ifint $(RegLastError) != $(!REG_ERROR_SUCCESS)
|
|
Set-add ErrorTotal = $(ErrorTotal),1
|
|
Endif
|
|
|
|
SetRegValue $(KeyTo) {Bind,$(NoTitle),$(!REG_VT_MULTI_SZ),$(ToBindList)}
|
|
Ifint $(RegLastError) != $(!REG_ERROR_SUCCESS)
|
|
Set-add ErrorTotal = $(ErrorTotal),1
|
|
Endif
|
|
SetRegValue $(KeyTo) {Export,$(NoTitle),$(!REG_VT_MULTI_SZ),$(ToExportList)}
|
|
Ifint $(RegLastError) != $(!REG_ERROR_SUCCESS)
|
|
Set-add ErrorTotal = $(ErrorTotal),1
|
|
Endif
|
|
SetRegValue $(KeyTo) {Route,$(NoTitle),$(!REG_VT_MULTI_SZ),$(ToRouteList)}
|
|
Ifint $(RegLastError) != $(!REG_ERROR_SUCCESS)
|
|
Set-add ErrorTotal = $(ErrorTotal),1
|
|
Endif
|
|
|
|
Debug-Output "UTILITY.INF: ToggleBinding; Registry update error total = "$(ErrorTotal)
|
|
|
|
Ifint $(ErrorTotal) != 0
|
|
Set Status = UNABLE_WRITE_REGISTRY
|
|
Else
|
|
Set Status = NO_ERROR
|
|
Endif
|
|
|
|
TB_Return = +
|
|
Ifstr(i) $(KeyFrom) != $(KeyNull)
|
|
CloseRegKey $(KeyFrom)
|
|
Endif
|
|
Ifstr(i) $(KeyTo) != $(KeyNull)
|
|
CloseRegKey $(KeyTo)
|
|
Endif
|
|
Ifstr(i) $(KeySvc) != $(KeyNull)
|
|
CloseRegKey $(KeySvc)
|
|
Endif
|
|
Return $(Status)
|
|
|
|
;*************************************************************************
|
|
; end of section ToggleBinding
|
|
;*************************************************************************
|
|
|
|
;-------------------------------------------------------------------------
|
|
;
|
|
; ROUTINE: SortListIndex
|
|
;
|
|
; DESCRIPTION: Sort a list into sequence, returning an "index" list, which
|
|
; indicates the sort position of each of the original list
|
|
; elements.
|
|
;
|
|
; INPUTS: $0: List to be sorted
|
|
; $1: TRUE for ascending sort (FALSE otherwise)
|
|
; $2: TRUE for case-insensitive sort (FALSE otherwise)
|
|
;
|
|
; OUTPUTS: $R0: Index list
|
|
;
|
|
; NOTES: Lists of displayable numeric values will automatically
|
|
; be sorted numerically if they are all decimal or hex
|
|
; and the sort is case-insensitive (param $2 FALSE).
|
|
;
|
|
;----------------------------------------------------------------------------
|
|
[SortListIndex]
|
|
Set List = $($0)
|
|
Set BoolAscend = $($1)
|
|
Set BoolCaseSens = $($2)
|
|
|
|
LibraryProcedure IndexList, $(!LIBHANDLE), GenerateSortedIndexList, $(List), $(BoolAscend), $(BoolCaseSens)
|
|
|
|
Return $(IndexList)
|
|
|
|
;-------------------------------------------------------------------------
|
|
;
|
|
; ROUTINE: SortByIndex
|
|
;
|
|
; DESCRIPTION: Sort a list into the sequence given by an "index list".
|
|
;
|
|
; INPUTS: $0: List to be sorted
|
|
; $1: Index list
|
|
;
|
|
; OUTPUTS: $R0: Index list
|
|
;
|
|
;----------------------------------------------------------------------------
|
|
[SortByIndex]
|
|
Set List = $($0)
|
|
Set IndexList = $($1)
|
|
Set NewList = {}
|
|
|
|
ForListDo $(IndexList)
|
|
Set Index = $($)
|
|
Set Item = *($(List),$(Index))
|
|
Set NewList = >($(NewList),$(Item))
|
|
EndForListDo
|
|
|
|
Return $(NewList)
|
|
|
|
;-------------------------------------------------------------------------
|
|
;
|
|
; ROUTINE: SortList
|
|
;
|
|
; DESCRIPTION: Sort a list into sequence, returning a sorted list.
|
|
;
|
|
; INPUTS: $0: List to be sorted
|
|
; $1: TRUE for ascending sort (FALSE otherwise)
|
|
; $2: TRUE for case-sensitive sort (FALSE for case-ins)
|
|
;
|
|
; OUTPUTS: $R0: Sorted list
|
|
;
|
|
; NOTES: Lists of displayable numeric values will automatically
|
|
; be sorted numerically if they are all decimal or hex
|
|
; and the sort is case-insensitive (param $2 FALSE).
|
|
;
|
|
;----------------------------------------------------------------------------
|
|
[SortList]
|
|
Set List = $($0)
|
|
Shell "" SortListIndex $(List) $($1) $($2)
|
|
Set IndexList = $($R0)
|
|
Shell "" SortByIndex $(List) $(IndexList)
|
|
Set ResultList = $($R0)
|
|
|
|
return $(ResultList)
|
|
|
|
;*************************************************************************
|
|
; end of file UTILITY.INF
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: UpdateDetectionDllNames
|
|
;
|
|
; PURPOSE: Search for files of the name ???NCDET.DLL.
|
|
; Update the Registry accordingly.
|
|
;
|
|
;
|
|
; ARGUMENTS: None
|
|
;
|
|
; RETURNS: $R0 STATUS_SUCCESSFUL if Registry updated
|
|
; STATUS_USERCANCEL if no update was required
|
|
; STATUS_FAILED if failed
|
|
;
|
|
; NOTES: This routine searches for all DLLs named ???NCDET.DLL
|
|
; and adds them to a list containing the name of the
|
|
; "standard" detection DLL, MSNCDET.DLL.
|
|
;
|
|
; Netcard detection is stopped and restarted if the
|
|
; Registry is updated.
|
|
;
|
|
; REFERENCES:
|
|
;
|
|
; MODIFIES:
|
|
;
|
|
;*************************************************************************
|
|
[DetectionDllFiles]
|
|
DetectionDllsFound = {} ? $(!LIBHANDLE) FindFileInstances $(!STF_WINDOWSSYSPATH)"\???ncdet.dll"
|
|
|
|
[UpdateDetectionDllNames]
|
|
Set Status = STATUS_FAILED
|
|
read-syms InitBaseVars
|
|
Detect DetectionDllFiles
|
|
Set DllValueName = "NetcardDlls"
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" "System\Setup" $(MAXIMUM_ALLOWED) KeySetup
|
|
Ifstr(i) $(KeySetup) == $(KeyNull)
|
|
Debug-Output "UTILITY.INF: [UpdateDetectionDllNames] cant open System\Setup key"
|
|
Goto UDDN_Return
|
|
Endif
|
|
|
|
; Prefix the list with MSNCDET.DLL
|
|
|
|
Set NewDllList = {"MSNCDET.DLL"}
|
|
ForListDo $(DetectionDllsFound)
|
|
Set NewDllList = >($(NewDllList),$($))
|
|
EndForListDo
|
|
|
|
; Get the old list
|
|
|
|
Set UpdateRequired = 1
|
|
GetRegValue $(KeySetup) $(DllValueName) DllNamesValue
|
|
Ifint $(RegLastError) == $(!REG_ERROR_SUCCESS)
|
|
Set DllNames = *($(DllNamesValue),4)
|
|
Debug-Output "UTILITY.INF: [UpdateDetectionDllNames] DllNames = "$(DllNames)
|
|
Set UpdateRequired = 0
|
|
|
|
; See if all the names are already present
|
|
|
|
ForListDo $(NewDllList)
|
|
Set DllIndex = ~($(DllNames),$($))
|
|
Ifint $(DllIndex) == 0
|
|
Set UpdateRequired = 1
|
|
Endif
|
|
EndForListDo
|
|
Endif
|
|
|
|
Set Status = STATUS_SUCCESSFUL
|
|
|
|
Ifint $(UpdateRequired) == 1
|
|
Debug-Output "UTILITY.INF: [UpdateDetectionDllNames] new DLL names = "$(NewDllList)
|
|
Set ValueInfo = {$(DllValueName), $(NoTitle), $(!REG_VT_MULTI_SZ), $(NewDllList)}
|
|
SetRegValue $(KeySetup) $(ValueInfo)
|
|
Ifint $(RegLastError) != $(!REG_ERROR_SUCCESS)
|
|
Set Status = STATUS_FAILED
|
|
Else
|
|
Shell "NCPARAM.INF" Param_ControlDetection DTEND
|
|
Shell "NCPARAM.INF" Param_ControlDetection DTSTART
|
|
Endif
|
|
Else
|
|
Set Status = STATUS_USERCANCEL
|
|
Endif
|
|
CloseRegKey $(KeySetup)
|
|
|
|
UDDN_Return = +
|
|
Return $(Status)
|
|
|
|
;*************************************************************************
|
|
; end of section UpdateDetectionDllNames
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: CheckIfCopyNecessary
|
|
;
|
|
; PURPOSE: Check a set of files and see if all are present. Used
|
|
; to offer the user a "current files" versus "new files"
|
|
; choice.
|
|
;
|
|
; ARGUMENTS: $0 list of path names corresponding to names
|
|
; given in next parameter
|
|
; $1 nested list of file names; see NOTES below
|
|
;
|
|
; RETURNS: $R0 STATUS_SUCCESSFUL or
|
|
; STATUS_FAILED
|
|
;
|
|
; REFERENCES: nothing
|
|
;
|
|
; MODIFIES: nothing
|
|
;
|
|
; NOTES: Typical values (taken from OEMNSVWK.INF) might be:
|
|
;
|
|
; $0: {$(!STF_WINDOWSSYSPATH),$(!STF_WINDOWSSYSPATH)\drivers}
|
|
; $1: {{"BOWSVC.DLL","WKSSVC.DLL","LMREPL.EXE"},+
|
|
; {"SMBTRSUP.SYS","BROWSER.SYS","RDR.SYS"}}
|
|
;
|
|
;
|
|
;*************************************************************************
|
|
[CheckIfCopyNecessary]
|
|
Set Status = STATUS_SUCCESSFUL
|
|
Set PathList = $($0)
|
|
Set NamesList = $($1)
|
|
|
|
Set Index = 0
|
|
Set Found = 1
|
|
ForListDo $(PathList)
|
|
Set ThisPath = $($)
|
|
Set-add Index = Index,1
|
|
Set NameList = *($(NamesList),$(Index))
|
|
ForListDo $(NameList)
|
|
Set FileToCheck = $(ThisPath)\$($)
|
|
LibraryProcedure FilePresent,$(!LIBHANDLE), CheckFileExistance $(FileToCheck)
|
|
Ifstr(i) $(FilePresent) != "YES"
|
|
Set Found = 0
|
|
Endif
|
|
EndForListDo
|
|
EndForListDo
|
|
|
|
Ifint $(Found) != 1
|
|
Set Status = STATUS_FAILED
|
|
Endif
|
|
|
|
Return $(Status)
|
|
|
|
;*************************************************************************
|
|
; end of section CheckIfCopyNecessary
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: GetBusTypeDialog
|
|
;
|
|
; PURPOSE: Call the GetBusDialog function in ncpa.cpl and
|
|
; get the location of the network card.
|
|
;
|
|
; ARGUMENTS: $0 Card name description
|
|
; $1 Default bus type
|
|
; $2 Default bus number
|
|
;
|
|
; RETURNS: $R0 NO_ERROR
|
|
; $R1 BusType
|
|
; $R2 BusNumber
|
|
; $R3 DlgReturn - "OK" | "CANCEL" if $R0 is NO_ERROR otherwise ""
|
|
;
|
|
; REFERENCES: nothing
|
|
;
|
|
; MODIFIES: nothing
|
|
;
|
|
;*************************************************************************
|
|
|
|
[GetBusTypeDialog]
|
|
set CardName = $($0)
|
|
set BusInterfaceType = $($1)
|
|
set BusNumber = $($2)
|
|
set DlgReturn = ""
|
|
|
|
ifstr(i) $(BusInterfaceType) == ""
|
|
set BusInterfaceType = 1 ; ISA
|
|
endif
|
|
ifstr(i) $(BusNumber) == ""
|
|
set BusNumber = 0 ; Bus 0
|
|
endif
|
|
set FLibraryErrCtl = 1
|
|
LibraryProcedure BusInfo $(!NCPA_HANDLE), GetBusTypeDialog, $(!STF_HWND), $(CardName), $(BusInterfaceType), $(BusNumber)
|
|
set FLibraryErrCtl = 0
|
|
|
|
; return values
|
|
|
|
ifint *($(BusInfo),1) == 0
|
|
set ReturnValue = NO_ERROR
|
|
set BusInterfaceType = *($(BusInfo),2)
|
|
set BusNumber = *($(BusInfo),3)
|
|
set DlgReturn = *($(BusInfo),4)
|
|
else
|
|
set ReturnValue = ERROR
|
|
endif
|
|
|
|
Return $(ReturnValue), $(BusInterfaceType), $(BusNumber), $(DlgReturn)
|
|
|
|
;*************************************************************************
|
|
; end of section GetBusTypeDialog
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: SetMasterComponent
|
|
;
|
|
; PURPOSE: This function is used by components which wish
|
|
; to be automatically removed when another component is
|
|
; remove by the user. It will either add (default)
|
|
; the given component as a dependent or remove it.
|
|
;
|
|
; ARGUMENTS: $0: Vendor name of master component
|
|
; $1: Product name of master component
|
|
; $2: INF file name of dependent (caller) component
|
|
; $3: INF option of dependent (caller) component
|
|
; $4: "ADD" or "" if adding or "REMOVE" if removing
|
|
;
|
|
; RETURNS: $R0: STATUS_SUCCESSFUL if ok, or
|
|
; STATUS_FAILED if failure
|
|
;
|
|
; $R1: Registry error code string if failure;
|
|
; CANNOT_FIND_COMPONENT_SERVICE, etc.
|
|
;
|
|
; NOTES: This function and its companion, RemoveDependentComponents,
|
|
; update and reference values under
|
|
; <Vendor>\<Product>\CurrentVersion:
|
|
;
|
|
; DependentInfNames REG_MULTI_SZ
|
|
; DependentInfOptions REG_MULTI_SZ
|
|
;
|
|
;*************************************************************************
|
|
[SetMasterComponent]
|
|
Read-syms InitBaseVars
|
|
|
|
Set Vendor = $($0)
|
|
Set Product = $($1)
|
|
Set InfName = $($2)
|
|
Set InfOption = $($3)
|
|
Set Adding = 1
|
|
Ifstr(i) $($4) == REMOVE
|
|
Set Adding = 0
|
|
Endif
|
|
Set Status = STATUS_FAILED
|
|
Set Error = ""
|
|
Set InfNamesList = {}
|
|
Set InfOptionsList = {}
|
|
Set InfIndex = 0
|
|
Set NameListSize = 0
|
|
Set OptionListSize = 0
|
|
Set UpdateRequired = 0
|
|
Set MasterKey = ""
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(!NTN_SoftwareBase)"\"$(Vendor)"\"$(Product)"\CurrentVersion" +
|
|
$(MAXIMUM_ALLOWED) MasterKey
|
|
|
|
Ifint $(RegLastError) != $(!REG_ERROR_SUCCESS)
|
|
Set Error = CANNOT_FIND_COMPONENT_SERVICE
|
|
Debug-Output "UTILITY.INF: Cant open master component key: "$(Product)
|
|
Goto SMC_Return
|
|
Endif
|
|
|
|
GetRegValue $(MasterKey) DependentInfNames InfNamesValue
|
|
|
|
Ifint $(RegLastError) == $(!REG_ERROR_SUCCESS)
|
|
Set InfNamesList = *($(InfNamesValue),4)
|
|
Set InfIndex = ~($(InfNamesList),$(InfName))
|
|
QueryListSize NameListSize $(InfNamesList)
|
|
Endif
|
|
|
|
GetRegValue $(MasterKey) DependentInfOptions InfOptionsValue
|
|
Ifint $(RegLastError) == $(!REG_ERROR_SUCCESS)
|
|
Set InfOptionsList = *($(InfOptionsValue),4)
|
|
QueryListSize OptionListSize $(InfOptionsList)
|
|
Endif
|
|
|
|
;
|
|
; Check that the two lists are in sync. Bag out if not.
|
|
;
|
|
Ifint $(NameListSize) != $(OptionListSize)
|
|
Set Error = UNABLE_INSTALL
|
|
Debug-Output "UTILITY.INF: Dependent INF list degenerate: "$(Product)
|
|
Goto SMC_Return
|
|
Endif
|
|
|
|
;
|
|
; If Adding and the INF name is not already present, add it;
|
|
; else if present, remove the names.
|
|
;
|
|
Ifint $(Adding) == 1
|
|
Ifint $(InfIndex) == 0
|
|
Set UpdateRequired = 1
|
|
Set InfNamesList = >($(InfNamesList),$(InfName))
|
|
Set InfOptionsList = >($(InfOptionsList),$(InfOption))
|
|
Endif
|
|
Else
|
|
Ifint $(InfIndex) != 0
|
|
Set UpdateRequired = 1
|
|
Set TlistNames = {}
|
|
Set TlistOptions = {}
|
|
Set Tindex = 0
|
|
|
|
ForListDo $(InfNamesList)
|
|
Set-add Tindex = $(Tindex), 1
|
|
Ifstr(i) $($) != $(InfName)
|
|
Set TlistNames = >($(TlistNames),$($))
|
|
Set TlistOptions = >($(TlistOptions),*($(InfOptionsList),$(Tindex)))
|
|
Endif
|
|
EndForListDo
|
|
|
|
Set InfNamesList = TlistNames
|
|
Set InfOptionsList = TlistOptions
|
|
Endif
|
|
Endif
|
|
|
|
Set Status = STATUS_SUCCESSFUL
|
|
|
|
Ifint $(UpdateRequired) == 0
|
|
Goto SMC_Return
|
|
Endif
|
|
|
|
SetRegValue $(MasterKey) {DependentInfNames,$(NoTitle),$(!REG_VT_MULTI_SZ),$(InfNamesList)}
|
|
Ifint $(RegLastError) != $(!REG_ERROR_SUCCESS)
|
|
Debug-Output "UTILITY.INF: master component value update failed (1)"
|
|
Set Status = UNABLE_WRITE_REGISTRY
|
|
Endif
|
|
SetRegValue $(MasterKey) {DependentInfOptions,$(NoTitle),$(!REG_VT_MULTI_SZ),$(InfOptionsList)}
|
|
Ifint $(RegLastError) != $(!REG_ERROR_SUCCESS)
|
|
Debug-Output "UTILITY.INF: master component value update failed (2)"
|
|
Set Status = UNABLE_WRITE_REGISTRY
|
|
Endif
|
|
|
|
SMC_Return =+
|
|
Ifstr(i) $(MasterKey) != $(KeyNull)
|
|
CloseRegKey $(MasterKey)
|
|
Endif
|
|
|
|
Return $(Status) $(Error)
|
|
|
|
;*************************************************************************
|
|
; end of section SetMasterComponent
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: RemoveDependentComponents
|
|
;
|
|
; PURPOSE: Remove components which are entirely dependent upon
|
|
; the named master component
|
|
;
|
|
; ARGUMENTS: $0: Vendor name of master component
|
|
; $1: Product name of master component
|
|
;
|
|
; RETURNS: $R0: STATUS_SUCCESSFUL if ok, or
|
|
; STATUS_FAILED if failure
|
|
;
|
|
; $R1: Registry error code string if failure;
|
|
; CANNOT_FIND_COMPONENT_SERVICE, etc.
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
[RemoveDependentComponents]
|
|
Read-syms InitBaseVars
|
|
Set Vendor = $($0)
|
|
Set Product = $($1)
|
|
Set Status = STATUS_FAILED
|
|
Set Error = ""
|
|
Set InfNamesList = {}
|
|
Set InfOptionsList = {}
|
|
Set InfIndex = 0
|
|
Set NameListSize = 0
|
|
Set OptionListSize = 0
|
|
Set UpdateRequired = 0
|
|
Set MasterKey = ""
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(!NTN_SoftwareBase)"\"$(Vendor)"\"$(Product)"\CurrentVersion" +
|
|
$(MAXIMUM_ALLOWED) MasterKey
|
|
|
|
Ifint $(RegLastError) != $(!REG_ERROR_SUCCESS)
|
|
Debug-Output "UTILITY.INF: Cant open master component key: "$(Product)
|
|
Set Error = CANNOT_FIND_COMPONENT_SERVICE
|
|
Goto RDC_Return
|
|
Endif
|
|
|
|
GetRegValue $(MasterKey) DependentInfNames InfNamesValue
|
|
|
|
Ifint $(RegLastError) == $(!REG_ERROR_SUCCESS)
|
|
Set InfNamesList = *($(InfNamesValue),4)
|
|
Set InfIndex = ~($(InfNamesList),$(InfName))
|
|
QueryListSize NameListSize $(InfNamesList)
|
|
Endif
|
|
|
|
GetRegValue $(MasterKey) DependentInfOptions InfOptionsValue
|
|
Ifint $(RegLastError) == $(!REG_ERROR_SUCCESS)
|
|
Set InfOptionsList = *($(InfOptionsValue),4)
|
|
QueryListSize OptionListSize $(InfOptionsList)
|
|
Endif
|
|
|
|
;
|
|
; Check that the two lists are in sync. Bag out if not.
|
|
;
|
|
Ifint $(NameListSize) != $(OptionListSize)
|
|
Set Error = UNABLE_INSTALL
|
|
Debug-Output "UTILITY.INF: Dependent INF list degenerate: "$(Product)
|
|
Goto RDC_Return
|
|
Endif
|
|
|
|
;
|
|
; If the list is empty, bag out.
|
|
;
|
|
Ifint $(NameListSize) == 0
|
|
Set Status = STATUS_SUCCESSFUL
|
|
Goto RDC_Return
|
|
Endif
|
|
|
|
;
|
|
; "push" the current global variable values
|
|
;
|
|
Set OldOption = $(!NTN_InfOption)
|
|
Set OldMode = $(!NTN_InstallMode)
|
|
Set OldInf = $(!NTN_Infname)
|
|
|
|
Set !NTN_InstallMode = deinstall
|
|
|
|
;
|
|
; Iterate the list, removing each INF and option pair.
|
|
;
|
|
Set Tindex = 0
|
|
ForListDo $(InfNamesList)
|
|
Set-add Tindex = $(Tindex), 1
|
|
Set !NTN_InfOption = *($(InfOptionsList),$(Tindex))
|
|
Set !NTN_Infname = $($)
|
|
Debug-Output "UTILITY.INF: Removing "$(Product)" dependent: "$(InfName)":"$(InfOption)
|
|
Shell $(!NTN_Infname) InstallOption $(!STF_LANGUAGE) $(!NTN_InfOption) $(!STF_SRCDIR) +
|
|
$(!NtLmAddCopy) $(!NtLmDoCopy) $(!NtLmDoConfig)
|
|
EndForListDo
|
|
|
|
;
|
|
; "pop" the saved global variable values
|
|
;
|
|
Set !NTN_InfOption = $(OldOption)
|
|
Set !NTN_InstallMode = $(OldMode)
|
|
Set !NTN_Infname = $(OldInf)
|
|
|
|
Set Status = STATUS_SUCCESSFUL
|
|
|
|
RDC_Return =+
|
|
Ifstr(i) $(MasterKey) != $(KeyNull)
|
|
CloseRegKey $(MasterKey)
|
|
Endif
|
|
|
|
return $(Status) $(Error)
|
|
|
|
;*************************************************************************
|
|
; end of RemoveDependentComponents
|
|
;*************************************************************************
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: AddDefaultNetCardParameters
|
|
;
|
|
; PURPOSE: Add default parameter to the system
|
|
;
|
|
; ARGUMENTS: $0: Service\netcard\parameter key
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
[AddDefaultNetCardParameters]
|
|
set KeyParameter = $($0)
|
|
ForListDo $(!NetCardParameterName)
|
|
set Name = $($)
|
|
set Value = *($(!NetCardParameterValue), $(#))
|
|
ifstr(i) $(Name) == "NetworkAddress"
|
|
set Type = $(!REG_VT_SZ)
|
|
else
|
|
set Type = $(!REG_VT_DWORD)
|
|
endif
|
|
Debug-Output "Name = "$(Name)
|
|
Debug-Output "Value = "$(Value)
|
|
SetRegValue $(KeyParameter) {$(Name),$(NoTitle),$(Type),$(Value)}
|
|
EndForListDo
|
|
return
|
|
|
|
|
|
;*************************************************************************
|
|
;
|
|
; SECTION: FindNextNetworkCard
|
|
;
|
|
; PURPOSE: Find the next network card registry entry
|
|
;
|
|
; ARGUMENTS: $0: Network Card ID
|
|
; $1: Starting Index, 1 to start at top
|
|
;
|
|
;
|
|
; RETURNS: $R0: RegKeyHandle to Netcard location
|
|
; $R1: Next Index, pass back in to continue search
|
|
;
|
|
; MODIFIES: Nothing
|
|
;
|
|
;*************************************************************************
|
|
[FindNextNetworkCard]
|
|
read-syms InitBaseVars
|
|
|
|
set NetcardName = $($0)
|
|
set iSearch = $($1)
|
|
set KeyNetcard = ""
|
|
|
|
Debug-Output "Utility.Inf: FindNextNetworkCard "$(NetcardName)", "$(iSearch)
|
|
|
|
checknextnetcard = +
|
|
|
|
set KeyName = $(NetworkCardKeyName)"\"$(iSearch)
|
|
|
|
Debug-Output "Utility.Inf: FindNextNetworkCard, checking "$(KeyName)
|
|
|
|
OpenRegKey $(!REG_H_LOCAL) "" $(KeyName) $(MAXIMUM_ALLOWED) KeyNetcard
|
|
set-add iSearch = $(iSearch), 1
|
|
|
|
Ifstr $(KeyNetcard) != $(KeyNull)
|
|
GetRegValue $(KeyNetcard) "ProductName" ValueList
|
|
ifstr(i) $(NetcardName) != *($(ValueList),4)
|
|
CloseRegKey $(KeyNetcard)
|
|
Debug-Output "Utility.Inf: FindNextNetworkCard, its not "*($(ValueList),4)" at "$(iSearch)
|
|
goto checknextnetcard
|
|
endif
|
|
Debug-Output "Utility.Inf: FindNextNetworkCard, Found "*($(ValueList),4)" at "$(iSearch)
|
|
else
|
|
Debug-Output "Utility.Inf: FindNextNetworkCard, Last One "$(iSearch)
|
|
endif
|
|
|
|
Debug-Output "Utility.Inf: FindNextNetworkCard returning "$(KeyNetcard)","$(iSearch)
|
|
return $(KeyNetcard) $(iSearch)
|