Microsoft Knowledge Base Email Alertz

Applications or services that call the CVdsService::Reenumerate function may receive incorrect results in Windows Server 2008 and in Windows Vista SP1

Search KbAlertz

Advanced Search

Receive Microsoft Knowledge Base articles by E-Mail?

Every night we scan the Microsoft Knowledge Base. If technologies you're interested in are updated, we'll send you an e-mail. You only get one e-mail a day, and only when new articles are added.

Click here to create a
FREE account
Already have an account?
[Click here to Login]











Microsoft Knowledge Base Article

This article contents is Microsoft Copyrighted material.
©2005-©2007 Microsoft Corporation. All rights reserved. Terms of Use | Trademarks

Article ID: 950851 - Last Review: October 8, 2011 - Revision: 2.0

Applications or services that call the "CVdsService::Reenumerate" function may receive incorrect results in Windows Server 2008 and in Windows Vista SP1

Hotfix download is availableHotfix Download Available
View and request hotfix downloads

On This Page

SYMPTOMS

In Windows Server 2008 and in Windows Vista Service Pack 1 (SP1), applications or services that call the CVdsService::Reenumerate function to rescan logical unit number (LUN) objects may receive incorrect results.

For example, an application breaks a LUN object mirror, masks one plex, and then unmasks the plex to another computer. After the application performs the unmasking action, the application calls the CVdsService::Reenumerate function to rescan LUN objects. Because of this issue, the plex does not appear on the expected computer, and an exception occurs.

CAUSE

If the storport and SCSIport drivers receive two LUN object rescan calls within 30 seconds, the drivers skip the second rescan call. When the rescan call is skipped, the problem that is mentioned in the "Symptoms" section may occur.

RESOLUTION

To resolve this problem, install the following hotfix. This hotfix adds a delay of 45 seconds in the CVdsService::Reenumerate function to make sure that each re-enumeration call triggers a storage rescan.

Hotfix information

A supported hotfix is available from Microsoft. However, this hotfix is intended to correct only the problem that is described in this article. Apply this hotfix only to systems that are experiencing the problem described in this article. This hotfix might receive additional testing. Therefore, if you are not severely affected by this problem, we recommend that you wait for the next software update that contains this hotfix.

If the hotfix is available for download, there is a "Hotfix download available" section at the top of this Knowledge Base article. If this section does not appear, contact Microsoft Customer Service and Support to obtain the hotfix.

Note If additional issues occur or if any troubleshooting is required, you might have to create a separate service request. The usual support costs will apply to additional support questions and issues that do not qualify for this specific hotfix. For a complete list of Microsoft Customer Service and Support telephone numbers or to create a separate service request, visit the following Microsoft Web site:
http://support.microsoft.com/contactus/?ws=support (http://support.microsoft.com/contactus/?ws=support)
Note The "Hotfix download available" form displays the languages for which the hotfix is available. If you do not see your language, it is because a hotfix is not available for that language.

Important Windows Vista and Windows Server 2008 hotfixes are included in the same packages. However, only one of these products may be listed on the “Hotfix Request” page. To request the hotfix package that applies to both Windows Vista and Windows Server 2008, just select the product that is listed on the page.

Prerequisites

To apply this hotfix on a Windows Server 2008-based computer, no prerequisites are required.

To apply this hotfix on a Windows Vista-based computer, you must have Windows Vista SP1 installed. For more information about Windows Vista service packs, click the following article number to view the article in the Microsoft Knowledge Base:
935791  (http://kbalertz.com/Feedback.aspx?kbNumber=935791/ ) How to obtain the latest Windows Vista service pack

Restart requirement

You must restart the computer after you apply this hotfix.

Hotfix replacement information

This hotfix does not replace any other hotfixes.

File information

The English version of this hotfix has the file attributes (or later file attributes) that are listed in the following table. The dates and times for these files are listed in Coordinated Universal Time (UTC). When you view the file information, it is converted to local time. To find the difference between UTC and local time, use the Time Zone tab in the Date and Time item in Control Panel.

Windows Vista and Windows Server 2008 file information notes

The MANIFEST (.manifest) files and MUM (.mum) files that are installed for each environment are listed separately. MUM and MANIFEST files and their associated security catalog (.cat) files are critical to maintaining the state of the updated component. The security catalog files are signed with a Microsoft digital signature. The attributes of these files are not listed.
All supported x86-based versions of Windows Server 2008 and of Windows Vista
Collapse this tableExpand this table
File nameFile versionFile sizeDateTimePlatform
Vds.exe6.0.6001.22240382,97609-Aug-200803:30x86
Vdsldr.exe6.0.6001.2224019,96809-Aug-200803:30x86
Vdsutil.dll6.0.6001.22240128,00009-Aug-200803:30x86
Vds_ps.dll6.0.6001.2224037,88809-Aug-200803:30x86
All supported x64-based versions of Windows Server 2008 and of Windows Vista
Collapse this tableExpand this table
File nameFile versionFile sizeDateTimePlatformService branch
Vds.exe6.0.6001.22240453,12009-Aug-200804:07x64Not applicable
Vdsldr.exe6.0.6001.2224022,52809-Aug-200804:07x64Not applicable
Vdsutil.dll6.0.6001.22240157,69609-Aug-200804:08x64Not applicable
Vds_ps.dll6.0.6001.2224097,28009-Aug-200804:08x64Not applicable
Vdsldr.exe6.0.6001.2224019,96809-Aug-200803:30x86WOW
Vdsutil.dll6.0.6001.22240128,00009-Aug-200803:30x86WOW
Vds_ps.dll6.0.6001.2224037,88809-Aug-200803:30x86WOW
All supported IA-64-based versions of Windows Server 2008
Collapse this tableExpand this table
File nameFile versionFile sizeDateTimePlatformService branch
Vds.exe6.0.6001.22240846,33609-Aug-200803:51IA-64Not applicable
Vdsldr.exe6.0.6001.2224049,15209-Aug-200803:51IA-64Not applicable
Vdsutil.dll6.0.6001.22240338,43209-Aug-200804:02IA-64Not applicable
Vds_ps.dll6.0.6001.22240109,05609-Aug-200804:02IA-64Not applicable
Vdsldr.exe6.0.6001.2224019,96809-Aug-200803:30x86WOW
Vdsutil.dll6.0.6001.22240128,00009-Aug-200803:30x86WOW
Vds_ps.dll6.0.6001.2224037,88809-Aug-200803:30x86WOW

STATUS

Microsoft has confirmed that this is a problem in the Microsoft products that are listed in the "Applies to" section.

MORE INFORMATION

Important This section, method, or task contains steps that tell you how to modify the registry. However, serious problems might occur if you modify the registry incorrectly. Therefore, make sure that you follow these steps carefully. For added protection, back up the registry before you modify it. Then, you can restore the registry if a problem occurs. For more information about how to back up and restore the registry, click the following article number to view the article in the Microsoft Knowledge Base:
322756  (http://kbalertz.com/Feedback.aspx?kbNumber=322756/ ) How to back up and restore the registry in Windows
Some applications that require Virtual Disk Service (VDS) calls to be completed quickly may be severely affected by this 45-second delay. To work around this issue, you can modify the appropriate registry entry to disable the delay. To do this, follow these steps:
  1. Click Start, type regedit in the Start search box, and then press ENTER.

    If you are prompted for an administrator password or for confirmation, type the password, or provide confirmation.
  2. Locate and then click the following registry subkey:
    HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\VDS
  3. On the Edit menu, point to New, and then click DWORD (32-bit) Value.
  4. Type DisableReenumDelay, and then press ENTER.
  5. Right-click DisableReenumDelay, and then click Modify.
  6. In the Value data box, type 1, and then click OK.
  7. Exit Registry Editor.
The value of the registry entry is read when the service is loaded. Therefore, you must restart VDS to make the value active.

You cannot disable the delay on a per-application basis. You can disable the delay only system-wide. After you disable the delay, disk changes may not be found by re-enumerate calls. Therefore, applications that rely on VDS notifications to find new disks may not receive these notifications. Some applications may not work correctly if they do not receive notifications of disk arrivals or of disk removals. Therefore, if this is a concern for you, make sure that you do not disable the delay.

If an application can recognize the disks that are supposed to be available, the application may be able to work around these lost notifications by verifying whether a disk is detected. For example, when an application masks or unmasks a LUN object, the application may recognize the disks that should be available. Therefore, we recommend that you use this hotfix only when the following conditions are true:
  • The applications that use VDS can work around the lost notifications.
  • No other applications use VDS to find disk arrivals and disk removals.
For more information, click the following article numbers to view the articles in the Microsoft Knowledge Base:
949002  (http://kbalertz.com/Feedback.aspx?kbNumber=949002/ ) A 45-second delay occurs when a Windows Server 2003-based computer runs disk re-enumeration operations after you install hotfix 935949 or a later version of Virtual Disk Service (Vds.exe)
935949  (http://kbalertz.com/Feedback.aspx?kbNumber=935949/ ) The Virtual Disk Service (VDS) in Windows Server 2003 does not return port-specific identifiers for a storage device
For more information about LUN objects, visit the following Microsoft Developer Network (MSDN) Web site:
http://msdn.microsoft.com/en-us/library/aa383041(VS.85).aspx (http://msdn.microsoft.com/en-us/library/aa383041(VS.85).aspx)

Additional file information for Windows Server 2008 and for Windows Vista

Additional files for all supported x86-based versions of Windows Server 2008 and of Windows Vista
Collapse this tableExpand this table
File nameFile versionFile sizeDateTimePlatform
Package_for_kb950851_client_1~31bf3856ad364e35~x86~~6.0.6.0.mumNot applicable1,36709-Aug-200811:55Not applicable
Package_for_kb950851_client~31bf3856ad364e35~x86~~6.0.6.0.mumNot applicable1,43109-Aug-200811:55Not applicable
Package_for_kb950851_sc_0~31bf3856ad364e35~x86~~6.0.6.0.mumNot applicable1,42109-Aug-200811:55Not applicable
Package_for_kb950851_sc~31bf3856ad364e35~x86~~6.0.6.0.mumNot applicable1,42309-Aug-200811:55Not applicable
Package_for_kb950851_server_0~31bf3856ad364e35~x86~~6.0.6.0.mumNot applicable1,42509-Aug-200811:55Not applicable
Package_for_kb950851_server~31bf3856ad364e35~x86~~6.0.6.0.mumNot applicable1,43109-Aug-200811:55Not applicable
Package_for_kb950851_winpesrv_0~31bf3856ad364e35~x86~~6.0.6.0.mumNot applicable1,42209-Aug-200811:55Not applicable
Package_for_kb950851_winpesrv~31bf3856ad364e35~x86~~6.0.6.0.mumNot applicable1,42909-Aug-200811:55Not applicable
X86_microsoft-windows-virtualdiskservice_31bf3856ad364e35_6.0.6001.22240_none_6b4931a113eca8ee.manifestNot applicable99,98409-Aug-200804:14Not applicable
Additional files for all supported x64-based versions of Windows Server 2008 and of Windows Vista
Collapse this tableExpand this table
File nameFile versionFile sizeDateTimePlatform
Amd64_microsoft-windows-virtualdiskservice_31bf3856ad364e35_6.0.6001.22240_none_c767cd24cc4a1a24.manifestNot applicable100,04809-Aug-200804:53Not applicable
Package_for_kb950851_client_1~31bf3856ad364e35~amd64~~6.0.6.0.mumNot applicable1,37509-Aug-200811:55Not applicable
Package_for_kb950851_client~31bf3856ad364e35~amd64~~6.0.6.0.mumNot applicable1,43909-Aug-200811:55Not applicable
Package_for_kb950851_sc_0~31bf3856ad364e35~amd64~~6.0.6.0.mumNot applicable1,42909-Aug-200811:55Not applicable
Package_for_kb950851_sc~31bf3856ad364e35~amd64~~6.0.6.0.mumNot applicable1,43109-Aug-200811:55Not applicable
Package_for_kb950851_server_0~31bf3856ad364e35~amd64~~6.0.6.0.mumNot applicable1,43309-Aug-200811:55Not applicable
Package_for_kb950851_server~31bf3856ad364e35~amd64~~6.0.6.0.mumNot applicable1,43909-Aug-200811:55Not applicable
Package_for_kb950851_winpesrv_0~31bf3856ad364e35~amd64~~6.0.6.0.mumNot applicable1,43009-Aug-200811:55Not applicable
Package_for_kb950851_winpesrv~31bf3856ad364e35~amd64~~6.0.6.0.mumNot applicable1,43709-Aug-200811:55Not applicable
Wow64_microsoft-windows-virtualdiskservice_31bf3856ad364e35_6.0.6001.22240_none_d1bc777700aadc1f.manifestNot applicable98,69909-Aug-200803:55Not applicable
Additional files for all supported IA-64-based versions of Windows Server 2008
Collapse this tableExpand this table
File nameFile versionFile sizeDateTimePlatform
Ia64_microsoft-windows-virtualdiskservice_31bf3856ad364e35_6.0.6001.22240_none_6b4ad59713eab1ea.manifestNot applicable100,01209-Aug-200804:52Not applicable
Package_for_kb950851_sc_0~31bf3856ad364e35~ia64~~6.0.6.0.mumNot applicable1,42509-Aug-200811:55Not applicable
Package_for_kb950851_sc~31bf3856ad364e35~ia64~~6.0.6.0.mumNot applicable1,42609-Aug-200811:55Not applicable
Package_for_kb950851_server_0~31bf3856ad364e35~ia64~~6.0.6.0.mumNot applicable1,42909-Aug-200811:55Not applicable
Package_for_kb950851_server~31bf3856ad364e35~ia64~~6.0.6.0.mumNot applicable1,43409-Aug-200811:55Not applicable
Package_for_kb950851_winpesrv_0~31bf3856ad364e35~ia64~~6.0.6.0.mumNot applicable1,42609-Aug-200811:55Not applicable
Package_for_kb950851_winpesrv~31bf3856ad364e35~ia64~~6.0.6.0.mumNot applicable1,43309-Aug-200811:55Not applicable
Wow64_microsoft-windows-virtualdiskservice_31bf3856ad364e35_6.0.6001.22240_none_d1bc777700aadc1f.manifestNot applicable98,69909-Aug-200803:55Not applicable

APPLIES TO
  • Windows Server 2008 Standard
  • Windows Server 2008 Enterprise
  • Windows Server 2008 Datacenter
  • Windows Server 2008 Standard without Hyper-V
  • Windows Server 2008 Enterprise without Hyper-V
  • Windows Server 2008 Datacenter without Hyper-V
  • Windows Server 2008 for Itanium-Based Systems
  • Windows Vista Business
  • Windows Vista Enterprise
  • Windows Vista Home Basic
  • Windows Vista Home Premium
  • Windows Vista Ultimate
  • Windows Vista Business 64-bit Edition
  • Windows Vista Enterprise 64-bit Edition
  • Windows Vista Home Basic 64-bit Edition
  • Windows Vista Home Premium 64-bit Edition
  • Windows Vista Ultimate 64-bit Edition
Keywords: 
kbautohotfix kbexpertiseinter kbfix kbbug kbsurveynew kbqfe KB950851
       

Community Feedback System

Very often, it takes hours to solve a problem. Very often, you've looked high and low, and have tried a lot of solutions. When you finally found it, chances are, it was because someone else helped you. Here's your chance to give back. Use our community feedback tool to let others know what worked for you and what didn't.

Please also understand that the community feedback system is not warranted to be correct, it's simply a system that we've built to let people try and help each other. If something in a feedback response doesn't make sense to you, or you're not comfortable making changes that the feedback talks about (like registry edits), please consult a professional.

Thank you for using kbAlertz.com Feedback System.

-- Scott Cate