DevManView v1.80
Copyright (c) 2009 - 2023 Nir Sofer
Web site: https://www.nirsoft.net
Description
===========
DevManView is an alternative to the standard Device Manager of Windows,
which displays all devices and their properties in flat table, instead of
tree viewer. In addition to displaying the devices of your local
computer, DevManView also allows you view the devices list of another
computer on your network, as long as you have administrator access rights
to this computer.
DevManView can also load the devices list from external instance of
Windows and disable unwanted devices. This feature can be useful if you
have Windows operating system with booting problems, and you want to
disable the problematic device.
System Requirements
===================
DevManView works on any version of Windows, starting from Windows 2000
and up to Windows 11. For x64 version of Windows, you should download the
x64 version of DevManView, because the 32-bit version of DevManView
cannot disable/enable devices on x64 operating system.
Versions History
================
* Version 1.80:
o Starting from this version, DevManView doesn't request to run as
Administrator when your run it.
o Added 'Run As Administrator' option (Ctrl+F11). You need to use
this option if you want to disable/enable/uninstall devices or to
view the install/connect/disconnect time.
o Added /RunAsAdmin command-line option. For using with the
disable/enable command-line options.
o Added 'Black Background' option (Under the View menu). When it's
turned on, the main table is displayed in black background and white
text, instead of default system colors.
o Updated to work properly in high DPI mode.
* Version 1.77:
o Fixed bug:
tag was added to the XML file if the device name
contained new line character.
* Version 1.76:
o Added new quick filter option: Find a string begins with...
* Version 1.75:
o Added option to change the sorting column from the menu (View ->
Sort By). Like the column header click sorting, if you click again
the same sorting menu item, it'll switch between ascending and
descending order. Also, if you hold down the shift key while choosing
the sort menu item, you'll get a secondary sorting.
* Version 1.72:
o Fixed bug with sending the devices information to stdout by
specifying an empty filename (e.g: DevManView.exe /scomma "" | more )
* Version 1.71:
o Added 'Copy Clicked Cell' option to the right-click context menu,
which copies to the clipboard the text of cell that you right-clicked
with the mouse.
* Version 1.70:
o Added new columns: Install Time, First Install Time, Connect
Time, Disconnect Time.
o 'Install Time' and 'First Install Time' fields are available
starting from Windows 7.
o 'Connect Time' and 'Disconnect Time' fields are available only on
Windows 8 and Windows 10.
o These new properties are taken from the
'Properties\{83da6326-97a6-4088-9453-a1923f573b29}' Registry subkey
of every device.
* Version 1.67:
o Added the 'Uninstall Selected Devices' option to the context menu.
* Version 1.66:
o Added 'Class Guid' column.
* Version 1.65:
o Added option to create a shortcut on your desktop to enable,
disable, or disable+enable the selected device (File -> Create
Desktop Shortcut)
o Added 'Automatically start the Remote Registry service' option.
When this option is turned on, DevManView temporarily starts the
Remote Regsitry service on the remote machine in order to get the
devices information from the Registry and then stops or disables (if
it was originally disabled) the service when it finishes.
* Version 1.60:
o Added new option: 'Open Device Properties Window' (F2).
o Added option to create a shortcut to the device properties window
on your desktop ('Create Device Properties Shortcut On Desktop').
* Version 1.56:
o Added /cfg command-line option to start DevManView with the
specified config file.
o When disabling/enabling devices from command-line, DevManView now
returns the error code (instead of 0 in previous versions).
* Version 1.55:
o You can now change the number of milliseconds to wait between
disable and enable actions when using the 'Disable+Enable Selected
Devices' option (or /disable_enable command-line option).
In order to change it - edit the config file (DevManView.cfg) and
change the 'DisableEnableWaitTime' value (The default is 100
milliseconds).
o You can now resize the properties window, and the last
size/position of this window is saved in the .cfg file.
* Version 1.51:
o Added 'Select All' and 'Deselect All' to the 'Column Settings'
window.
* Version 1.50:
o Added 'Quick Filter' feature (View -> Use Quick Filter or
Ctrl+Q). When it's turned on, you can type a string in the text-box
added under the toolbar and DevManView will instantly filter the
devices list, showing only lines that contain the string you typed.
* Version 1.48:
o When you connect a remote computer or external Registry file,
DevManView now displays the computer or directory information in the
window title.
* Version 1.47:
o DevManView now displays an error message when it fails to
disable/enable a device.
* Version 1.46:
o Fixed the problem with 'Put Icon On Tray' option.
* Version 1.45:
o Added 'Show Only Devices With Location String' option.
o Added 'Auto Size Columns On Load' option.
* Version 1.43:
o Added 'Container ID' column.
* Version 1.42:
o Added secondary sorting support: You can now get a secondary
sorting, by holding down the shift key while clicking the column
header. Be aware that you only have to hold down the shift key when
clicking the second/third/fourth column. To sort the first column you
should not hold down the Shift key.
o Fixed to display date/time values according to daylight saving
time settings.
* Version 1.41:
o Added 'Clear Recent Files List' for the 'Recent Disabled Devices
Profile' option.
* Version 1.40:
o Added /use_wildcard command-line option. You can use it with
/disable, /enable, /disable_enable , and /uninstall commmand-line
options to specify wildcard instead of full name, for example:
DevManView.exe /disable "USBSTOR\CdRom&???_*" /use_wildcard
Use it very carefully !!
* Version 1.35:
o Added 'Recent Disabled Devices Profile' submenu, which allows you
to easily load the recent 10 profiles you saved.
* Version 1.30:
o Added 'Save Disabled Devices Profile' and 'Load Disabled Devices
Profile' options. You can now save the list of all devices that are
currently disabled into a simple config file. Later, when you want to
load the same disabled devices configuration, you can load the file
using the 'Load Disabled Devices Profile' option, and then DevManView
will disable all devices found in the file and enable all other
devices that are not stored in the file.
o Added /load_disabled_profile and /save_disabled_profile
command-line options.
o Added 'Auto Size Columns+Headers' option, which allows you to
automatically resize the columns according to the row values and
column headers.
o Fixed issue: Dialog-boxes opened in the wrong monitor, on
multi-monitors system.
* Version 1.27:
o Changed the Registry key that is used to get the value of 'Device
Registry Time 1', under Windows Vista/7/2008. In previous versions,
this field usually displayed the same value for all devices under
Windows Vista/7/2008.
* Version 1.26:
o Added 'Start As Hidden' option. When this option and 'Put Icon On
Tray' option are turned on, the main window of DevManView will be
invisible on start.
* Version 1.25:
o Added 'Put Icon On Tray' option.
* Version 1.23:
o Added a second Device Registry Time value, which usually displays
the installation time of the device.
* Version 1.22:
o Added 'Mark Odd/Even Rows' option, under the View menu. When it's
turned on, the odd and even rows are displayed in different color, to
make it easier to read a single line.
* Version 1.21:
o Added 'Mark Connected Devices' option. When it's turned on,
connected devices are marked with green background color.
* Version 1.20:
o Added 'Open .INF File' option (The .inf file is opened in Notepad)
o Added 'Google Search - Device Name' for searching the device name
in Google.
o Added 'Drive Letter' column, which displays the drive letter for
devices with assigned drive letter.
* Version 1.15:
o Added command-line options to disable, enable, and uninstall a
device (Use them very carefully !!) - /enable , /disable ,
/disable_enable , and /uninstall
* Version 1.12:
o You can now send the devices information to stdout by specifying
an empty filename ("") in the save command-line options. (For
example: DevManView.exe /stext "" > c:\temp\devices.txt)
* Version 1.11:
o Added 'Add Header Line To CSV/Tab-Delimited File' option. When
this option is turned on, the column names are added as the first
line when you export to csv or tab-delimited file.
* Version 1.10:
o Added 'Disable+Enable Selected Devices' option (Disable and then
enable again).
* Version 1.07:
o Fixed issue: removed the wrong encoding from the xml string,
which caused problems to some xml viewers. Also, removed invalid dot
character from xml name of '.inf section'.
o Fixed focus issue after save.
* Version 1.06:
o Fixed bug: When saving the devices list from command-line,
DevManView always saved all devices, without considering the
show/hide settings, like /ShowLegacyDrivers parameter.
* Version 1.05:
o Improved the 'Connected' column.
o Added 'Show Only Connected Devices' option, which allows you to
filter obsolete devices that are not currently connected.
* Version 1.00 - First release.
Using DevManView
================
DevManView doesn't require any installation process or additional dll
files. In order to start using it, simply run the executable file -
DevManView.exe
After running DevManView, the main window displays the list of all
devices found in your system. By default, non-plug and play drivers
(LegacyDriver) are not displayed, but you can add them by selecting the
'Show Non-Plug And Play Drivers' in the Options menu.
You can now select one or more than devices from the list, and then save
their details into text/html/xml/csv file (Ctrl+S) or copy them to the
clipboard (Ctrl+C) and then paste the data to Excel or other spreadsheet
application.
DevManView also allows you to disable, enable, and uninstall the selected
devices. However, you must be very careful when using the
disable/uninstall options, because disabling or uninstalling an essential
device might cause troubles to your operating system.
Connecting a remote computer on your network
============================================
DevManView allows you to connect another computer on your LAN, and view
the devices list in the remote computer. In order to successfully connect
the remote computer, you must have full administrator access to this
computer, and you may need to make a few configuration changes in the
remote computer in order to make it work. For more information, read this
Blog post: How to connect a remote Windows 7/Vista/XP computer with
NirSoft utilities.
After you get full admin rights to the remote computer, you can go to
'Advanced Options' window (F9), choose 'Remote Computer', and type the
computer name (something like \\MyComp or \\192.168.10.20).
When the remote computer is Windows 2000/XP/2003, you can also
disable/enable/uninstall a device in the remote computer. However, this
feature doesn't work on Windows 7/Vista, probably due to security changes
made in these operating systems.
Using DevManView on external instance of Windows
================================================
DevManView allows you to view the devices list stored in the Registry of
another instance of Windows operating system. In order to use this
feature, simply go to Advanced Options (F9), choose 'External Windows
Directory', and then type or choose the right Windows directory.
When you use this feature, you are also allowed to disable/enable the
selected devices. If you use this feature, DevManView write the
disabled/enabled information into the SYSTEM Registry file of the
selected Windows OS, so in the next time that this Windows is loaded, the
device will be disabled/enabled according to what you set with DevManView.
However, it's recommended to use this feature only on emergency cases
(For example, when a system cannot boot properly), and you should also
backup the SYSTEM registry file before making any change on external OS.
Using Another ControlSet
========================
By default, DevManView loads the devices from the default ControlSet,
which is the default ControlSet that is loaded by Windows. However, in
the 'Advanced Options' window, you can choose to view the devices of
'Last Known Good' ControlSet or any other ControlSet by its number. When
you use non-default ControlSet, disabling/enabling a device save the
changes in the Registry, so they'll take effect in the next time that
Windows is loaded with the selected ControlSet.
Command-Line Options
====================
/stext
Save the list of devices into a regular text file.
/stab
Save the list of devices into a tab-delimited text file.
/scomma
Save the list of devices into a comma-delimited text file (csv).
/stabular
Save the list of devices into a tabular text file.
/shtml
Save the list of devices into HTML file (Horizontal).
/sverhtml
Save the list of devices into HTML file (Vertical).
/sxml
Save the list of devices into XML file.
/sort
This command-line option can be used with other save options for sorting
by the desired column. If you don't specify this option, the list is
sorted according to the last sort that you made from the user interface.
The parameter can specify the column index (0 for the first
column, 1 for the second column, and so on) or the name of the column,
like "Device Name" and "Location". You can specify the '~' prefix
character (e.g: "~Device Name") if you want to sort in descending order.
You can put multiple /sort in the command-line if you want to sort by
multiple columns.
Examples:
DevManView.exe /shtml "f:\temp\devices.html" /sort 2 /sort ~1
DevManView.exe /shtml "f:\temp\devices.html" /sort "Service" /sort
"Device Name"
/nosort
When you specify this command-line option, the list will be saved without
any sorting.
/LoadFrom
Specifies the 'Load From' value. 1 = Local Computer, 2 = Remote Computer,
3 = External Path.
/ComputerName
Specifies the remote computer name to load the devices information
(Should be used with /LoadFrom 2)
/WinDir
Specifies the Windows directory path of external instance of Windows.
(Should be used with /LoadFrom 3)
/ControlSet
Specifies the ControlSet number. 0 = Default, 4096 = Last Known Good, All
Others = ControlSet Number.
/ShowLegacyDrivers <0 | 1>
Specifies whether to show legacy drivers. 0 = No, 1 = Yes.
/ShowOnlyConnected <0 | 1>
Specifies whether to show only connected devices. 0 = No, 1 = Yes.
/cfg
Start DevManView with the specified configuration file. For example:
DevManView.exe /cfg "c:\config\dmv.cfg"
DevManView.exe /cfg "%AppData%\DevManView.cfg"
Enable/disable/uninstall a device from command-line
===================================================
You can use the following command-line options to
enable/disable/uninstall a device from command-line. You can specify the
device by its exact name, as appeared in the 'Device Name' column, for
example:
DevManView.exe /RunAsAdmin /disable "WD 2500BMV External USB Device"
You can also specify the value displayed in the Device Instance ID
column, for example:
DevManView.exe /RunAsAdmin /enable
"USBSTOR\Disk&Ven_WD&Prod_2500BMV_External&Rev_1.05\584953930578345789&0"
Use these command-line options very carefully, because
disabling/uninstalling the wrong device may cause severe system problems.
/disable
Disable the specified device.
/enable
Enable the specified device.
/disable_enable
Disable and then enable again the specified device.
/uninstall
Uninstall the specified device.
/use_wildcard
You can use it with /disable, /enable, /disable_enable , and /uninstall
commmand-line options to specify wildcard instead of full name, for
example:
DevManView.exe /disable "USBSTOR\CdRom&???_*" /use_wildcard
You must specify at least 5 characters in the device name wildcard,
otherwise it'll not work.
/save_disabled_profile
Save all devices that are currently disabled into a simple config file.
/load_disabled_profile
Load the config file that you previously saved with
/save_disabled_profile option, disable all devices found in this file,
and enable all other devices that are not stored in this file.
/RunAsAdmin
Run DevManView as Administrator.
Translating DevManView to other languages
=========================================
In order to translate DevManView to other language, follow the
instructions below:
1. Run DevManView with /savelangfile parameter:
DevManView.exe /savelangfile
A file named DevManView_lng.ini will be created in the folder of
DevManView utility.
2. Open the created language file in Notepad or in any other text
editor.
3. Translate all string entries to the desired language. Optionally,
you can also add your name and/or a link to your Web site.
(TranslatorName and TranslatorURL values) If you add this information,
it'll be used in the 'About' window.
4. After you finish the translation, Run DevManView, and all
translated strings will be loaded from the language file.
If you want to run DevManView without the translation, simply rename
the language file, or move it to another folder.
License
=======
This utility is released as freeware. You are allowed to freely
distribute this utility via floppy disk, CD-ROM, Internet, or in any
other way, as long as you don't charge anything for this. If you
distribute this utility, you must include all files in the distribution
package, without any modification !
Disclaimer
==========
The software is provided "AS IS" without any warranty, either expressed
or implied, including, but not limited to, the implied warranties of
merchantability and fitness for a particular purpose. The author will not
be liable for any special, incidental, consequential or indirect damages
due to loss of data or any other reason.
Feedback
========
If you have any problem, suggestion, comment, or you found a bug in my
utility, you can send a message to nirsofer@yahoo.com