[UMPNPMGR][USETUP] Fix the way device-install events are queued and dequeued. Fixes... 3248/head
authorHermès Bélusca-Maïto <hermes.belusca-maito@reactos.org>
Mon, 28 Sep 2020 20:38:55 +0000 (22:38 +0200)
committerHermès Bélusca-Maïto <hermes.belusca-maito@reactos.org>
Wed, 30 Sep 2020 23:52:09 +0000 (01:52 +0200)
commitffc96d26ec297a6f9feec7c1e526efefa08809e0
treec3fa93d0829271a03ab1ea6f78d3fd4618e2e7ce
parent828a65f470ec5b1504b0776bac182d051b855473
[UMPNPMGR][USETUP] Fix the way device-install events are queued and dequeued. Fixes CORE-16103.

Dedicated to the hard work of Joachim Henze! xD

This reverts part of commit 043a98dd (see also commit b2aeafca).

Contrary to what I assumed in commit 043a98dd (and was also assumed in
the older commit b2aeafca), we cannot use the singled-linked lists to
queue and dequeue the PnP device-install events, because:

- the events must be treated from the oldest to the newest ones, for
  consistency, otherwise this creates problems, as shown by e.g. CORE-16103;

- the system singled-linked lists only offer access to the top of the
  list (like a stack) instead of to both the top and the bottom of the
  list, as would be required for a queue. Using the SLISTs would mean
  that only the newest-received events would be treated first, while the
  oldest (which were the first received) events would be treated last,
  and this is wrong.

Therefore one must use e.g. the standard doubly-linked list. Also, using
locked operations (insertion & removal) on the list of device-install
events is necessary, because these operations are done concurrently by
two different threads: PnpEventThread() and DeviceInstallThread().
Since the interlocked linked list functions are not available in user-mode,
we need to use instead locking access through e.g. a mutex.
base/services/umpnpmgr/install.c
base/services/umpnpmgr/precomp.h
base/services/umpnpmgr/umpnpmgr.c
base/setup/usetup/devinst.c