Windows System Software -- Consulting, Training, Development -- Unique Expertise, Guaranteed Results

Home NTDEV

Before Posting...

Please check out the Community Guidelines in the Announcements and Administration Category.

More Info on Driver Writing and Debugging


The free OSR Learning Library has more than 50 articles on a wide variety of topics about writing and debugging device drivers and Minifilters. From introductory level to advanced. All the articles have been recently reviewed and updated, and are written using the clear and definitive style you've come to expect from OSR over the years.


Check out The OSR Learning Library at: https://www.osr.com/osr-learning-library/


[Q] How does IoRemoveLock protect thread that does the final unlock?

OSR_Community_UserOSR_Community_User Member Posts: 110,217
I have an issue I don't understand about using Plug and Play "remove locks".

Assume the Configuration Manager, running on some thread (let's call it
Thread A), has called into a driver for IRP_MN_REMOVE_DEVICE processing and
is currently blocked inside IoReleaseRemoveLockAndWait(), pending the final
release of the remove lock.

Futher assume there's only one outstanding remove lock left due to some
other thread (let's call it Thread B) having called into the driver for a
synchronously processed IRP for which the processing is not yet finished.

When processing of the synchronous IRP is complete (and if no additional
references occur in the meantime of course) and Thread B finally calls
IoReleaseRemoveLock() on its way out of the IRP dispatch routine, is there
not a chance that Thread A will wake up and unload driver before Thread B
can return all way out of the driver's code?

Or, does the fact the Thread B has called the driver incur an additional
reference somwhere that I'm not aware of (that isn't released until Thread B
has fully returned from the driver call)?

- Matt
Sign In or Register to comment.

Howdy, Stranger!

It looks like you're new here. Sign in or register to get started.

Upcoming OSR Seminars
OSR has suspended in-person seminars due to the Covid-19 outbreak. But, don't miss your training! Attend via the internet instead!
Writing WDF Drivers 12 September 2022 Live, Online
Internals & Software Drivers 23 October 2022 Live, Online
Kernel Debugging 14 November 2022 Live, Online
Developing Minifilters 5 December 2022 Live, Online