]> git.proxmox.com Git - mirror_edk2.git/commit
EmbeddedPkg/Universal/MmcDxe: "fix" CloseProtocol() call in BindingStop()
authorLaszlo Ersek <lersek@redhat.com>
Fri, 6 Sep 2019 23:43:28 +0000 (01:43 +0200)
committerLaszlo Ersek <lersek@redhat.com>
Wed, 9 Oct 2019 07:40:09 +0000 (09:40 +0200)
commite1b59e085a430674fc5f31be276432d18cab63b4
treed8b981569acb528197485fffc01b4c9e2ac1a12a
parent7b6ceb4d3b4678a9e76a3ff881b25d5e68c4439c
EmbeddedPkg/Universal/MmcDxe: "fix" CloseProtocol() call in BindingStop()

The 3rd and 4th parameters of the CloseProtocol() call are wrong.

Given that we're not dissociating a child controller from a parent
controller (= closing a BY_CHILD_CONTROLLER open), but closing a BY_DRIVER
open, the 4th parameter (ControllerHandle) should equal the 1st parameter
(Handle).

It's unclear why this code hasn't crashed before.

Note that the patch doesn't fix the underlying driver model bug. I don't
understand what the loop in MmcDriverBindingStop() attempts to do. Is this
driver supposed to be a bus driver? It seems to create new handles, and to
append device path nodes. But it doesn't set up proper parent/child
protocol opens, and it doesn't close them.

Cc: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Cc: Leif Lindholm <leif.lindholm@linaro.org>
Signed-off-by: Laszlo Ersek <lersek@redhat.com>
Acked-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
EmbeddedPkg/Universal/MmcDxe/Mmc.c