winmm: Prevent NULL dereference in MCI_Close and add testcase for it.
This commit is contained in:
parent
0ad5638bf1
commit
6698e9e0b0
|
@ -1797,8 +1797,9 @@ static DWORD MCI_Close(UINT16 wDevID, DWORD dwParam, LPMCI_GENERIC_PARMS lpParms
|
|||
MCI_UnLoadMciDriver(wmd);
|
||||
|
||||
if (dwParam & MCI_NOTIFY)
|
||||
mciDriverNotify((HWND)lpParms->dwCallback, wDevID,
|
||||
(dwRet == 0) ? MCI_NOTIFY_SUCCESSFUL : MCI_NOTIFY_FAILURE);
|
||||
mciDriverNotify(lpParms ? (HWND)lpParms->dwCallback : 0,
|
||||
wDevID,
|
||||
dwRet ? MCI_NOTIFY_FAILURE : MCI_NOTIFY_SUCCESSFUL);
|
||||
|
||||
return dwRet;
|
||||
}
|
||||
|
|
|
@ -7,6 +7,7 @@ IMPORTS = winmm user32 kernel32
|
|||
|
||||
CTESTS = \
|
||||
capture.c \
|
||||
mci.c \
|
||||
mixer.c \
|
||||
mmio.c \
|
||||
timer.c \
|
||||
|
|
|
@ -0,0 +1,51 @@
|
|||
/*
|
||||
* Test winmm mci
|
||||
*
|
||||
* Copyright 2006 Jan Zerebecki
|
||||
*
|
||||
* This library is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU Lesser General Public
|
||||
* License as published by the Free Software Foundation; either
|
||||
* version 2.1 of the License, or (at your option) any later version.
|
||||
*
|
||||
* This library is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public
|
||||
* License along with this library; if not, write to the Free Software
|
||||
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
|
||||
*/
|
||||
|
||||
#include "wine/test.h"
|
||||
#include "winuser.h"
|
||||
#include "mmsystem.h"
|
||||
|
||||
START_TEST(mci)
|
||||
{
|
||||
int err;
|
||||
const char command_open[] = "open new type waveaudio alias mysound";
|
||||
const char command_close_my[] = "close mysound notify";
|
||||
const char command_close_all[] = "close all notify";
|
||||
MSG msg;
|
||||
|
||||
err = mciSendString(command_open, NULL, 0, NULL);
|
||||
ok(!err,"mciSendString(%s, NULL, 0 , NULL) returned error: %d\n", command_open, err);
|
||||
|
||||
err = mciSendString(command_close_my, NULL, 0, NULL);
|
||||
ok(!err,"mciSendString(%s, NULL, 0 , NULL) returned error: %d\n", command_close_my, err);
|
||||
|
||||
ok(PeekMessageW( &msg, (HWND)-1, 0, 0, PM_REMOVE ), "PeekMessage should succeed\n");
|
||||
ok(msg.hwnd == NULL, "got %p instead of NULL\n", msg.hwnd);
|
||||
ok(msg.message == MM_MCINOTIFY, "got %04x instead of MM_MCINOTIFY\n", msg.message);
|
||||
ok(msg.wParam == MCI_NOTIFY_SUCCESSFUL, "got %08x instead of MCI_NOTIFY_SUCCESSFUL\n", msg.wParam);
|
||||
|
||||
err = mciSendString(command_close_all, NULL, 0, NULL);
|
||||
todo_wine ok(!err,"mciSendString(%s, NULL, 0 , NULL) returned error: %d\n", command_close_all, err);
|
||||
|
||||
err = mciSendCommand(MCI_ALL_DEVICE_ID, MCI_CLOSE, MCI_NOTIFY, 0);
|
||||
todo_wine ok(err == MCIERR_INVALID_DEVICE_ID,
|
||||
"mciSendCommand(MCI_ALL_DEVICE_ID, MCI_CLOSE, MCI_NOTIFY, NULL) returned %d instead of %d\n",
|
||||
err, MCIERR_INVALID_DEVICE_ID);
|
||||
}
|
Loading…
Reference in New Issue