Microsoft KB Archive/173039

{|
 * width="100%"|

RUNONCE Key Is Processed Immediately When RUNDLL32 Is Called

 * }

-

The information in this article applies to:


 * Microsoft Windows NT Workstation version 4.0
 * Microsoft Windows NT Server version 4.0
 * Microsoft Windows 95
 * Microsoft Windows 2000 Professional
 * Microsoft Windows 2000 Server
 * Microsoft Windows 2000 Advanced Server

-

SUMMARY
If you place items in the RUNONCE key so that they will run the next time you log on, they will run as soon as Rundll32.exe is run, whether or not logging on is in progress. This is a design feature of Rundll32.exe for Windows NT 4.0 Server and Workstation.

This feature can cause problems, however, during an unattended installation of Windows NT version 4.0 using the Cmdlines.txt option. This article discusses these possible problems and some ways to avoid them.

MORE INFORMATION
To produce the desired results from the RUNONCE key, it is very important not to add any values to it before running Rundll32.exe options. This includes using a Windows 95-style .inf to add the RUNONCE registry values.

You can re-create and examine the effects of launching Rundll32.exe when there is a RUNONCE value ready to run by using the following steps:

 Create a directory called Test.  Using Notepad.exe, enter the following lines, and then save as Runonce.reg in the Test directory:

     REGEDIT4

[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion \RunOnce] "doit"="c:\\test\\test.cmd"   Using Notepad.exe, enter the following lines, and then save as Cmdlines.cmd in the Test directory:

     @ECHO OFF REGEDIT.EXE /s RUNONCE.REG rundll32 setupapi,InstallHinfSection DefaultInstall 128 .\test.INF   Using Notepad.exe, enter the following lines, and then save as Test.cmd in the Test directory:

     @echo off ECHO HELLO WORLD PAUSE   Using Notepad.exe, enter the following lines, and then save as Test.inf in the Test directory:

     [Version] Signature = "$Windows NT$"

[DefaultInstall] AddReg = AddReg DelReg = DelReg UpdateInis = UpdateInis

[AddReg] [DelReg] [UpdateInis]  From an MS-DOS prompt, run Cmdlines.cmd; you will see that the file Test.cmd runs.</li></ol>

The following example shows the file Cmdlines.txt located in the $OEM$ directory of a Windows NT Deployment share, with the proper order to run Rundll32.exe and a Regedit script for Runonce. Optimally, it would be best to run all Rundll32.exe statements before running Regedit scripts.

<pre class="FIXEDTEXT">  [Commands] "rundll32 setupapi,InstallHinfSection DefaultInstall 128 .\test.INF" "REGEDIT.EXE /s .\RUNONCE.REG"

For additional information on Windows NT 4.0 deployment and unattended installation, download the Windows NT 4.0 Deployment Guide from the following web site:

http://www.microsoft.com/ntworkstation/info/deployguide.htm

NOTE: The deployment guide is valid for both Windows NT Workstation and Windows NT Server.

Additional query words:

Keywords : kbsetup ntsetup ntreskit NTSrvWkst

Version : WINDOWS:2000,95; winnt:4.0

Platform : WINDOWS winnt

Issue type : kbprb

Technology :