mirror of
https://github.com/reactos/reactos.git
synced 2025-04-22 13:10:39 +00:00
add winmm winetest
svn path=/trunk/; revision=43811
This commit is contained in:
parent
41b71cf811
commit
c021918e36
10 changed files with 4121 additions and 3 deletions
|
@ -241,9 +241,10 @@
|
||||||
<directory name="ws2_32">
|
<directory name="ws2_32">
|
||||||
<xi:include href="ws2_32/ws2_32.rbuild" />
|
<xi:include href="ws2_32/ws2_32.rbuild" />
|
||||||
</directory>
|
</directory>
|
||||||
<!--
|
<!--directory name="winetest">
|
||||||
<directory name="winetest">
|
|
||||||
<xi:include href="winetest/winetest.rbuild" />
|
<xi:include href="winetest/winetest.rbuild" />
|
||||||
|
</directory-->
|
||||||
|
<directory name="winmm">
|
||||||
|
<xi:include href="winmm/winmm.rbuild" />
|
||||||
</directory>
|
</directory>
|
||||||
-->
|
|
||||||
</group>
|
</group>
|
||||||
|
|
724
rostests/winetests/winmm/capture.c
Normal file
724
rostests/winetests/winmm/capture.c
Normal file
|
@ -0,0 +1,724 @@
|
||||||
|
/*
|
||||||
|
* Test winmm sound capture in each sound format
|
||||||
|
*
|
||||||
|
* Copyright (c) 2002 Francois Gouget
|
||||||
|
*
|
||||||
|
* 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 <stdarg.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <math.h>
|
||||||
|
|
||||||
|
#include "wine/test.h"
|
||||||
|
#include "windef.h"
|
||||||
|
#include "winbase.h"
|
||||||
|
#include "winnls.h"
|
||||||
|
#include "mmsystem.h"
|
||||||
|
#define NOBITMAP
|
||||||
|
#include "mmreg.h"
|
||||||
|
|
||||||
|
extern GUID KSDATAFORMAT_SUBTYPE_PCM;
|
||||||
|
extern GUID KSDATAFORMAT_SUBTYPE_IEEE_FLOAT;
|
||||||
|
|
||||||
|
#include "winmm_test.h"
|
||||||
|
|
||||||
|
static const char * wave_in_error(MMRESULT error)
|
||||||
|
{
|
||||||
|
static char msg[1024];
|
||||||
|
static char long_msg[1100];
|
||||||
|
MMRESULT rc;
|
||||||
|
|
||||||
|
rc = waveInGetErrorText(error, msg, sizeof(msg));
|
||||||
|
if (rc != MMSYSERR_NOERROR)
|
||||||
|
sprintf(long_msg, "waveInGetErrorText(%x) failed with error %x", error, rc);
|
||||||
|
else
|
||||||
|
sprintf(long_msg, "%s(%s)", mmsys_error(error), msg);
|
||||||
|
return long_msg;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void check_position(int device, HWAVEIN win, DWORD bytes,
|
||||||
|
LPWAVEFORMATEX pwfx )
|
||||||
|
{
|
||||||
|
MMTIME mmtime;
|
||||||
|
DWORD samples;
|
||||||
|
double duration;
|
||||||
|
MMRESULT rc;
|
||||||
|
DWORD returned;
|
||||||
|
|
||||||
|
samples=bytes/(pwfx->wBitsPerSample/8*pwfx->nChannels);
|
||||||
|
duration=((double)samples)/pwfx->nSamplesPerSec;
|
||||||
|
|
||||||
|
mmtime.wType = TIME_BYTES;
|
||||||
|
rc=waveInGetPosition(win, &mmtime, sizeof(mmtime));
|
||||||
|
ok(rc==MMSYSERR_NOERROR,
|
||||||
|
"waveInGetPosition(%s): rc=%s\n",dev_name(device),wave_in_error(rc));
|
||||||
|
if (mmtime.wType != TIME_BYTES && winetest_debug > 1)
|
||||||
|
trace("waveInGetPosition(%s): TIME_BYTES not supported, returned %s\n",
|
||||||
|
dev_name(device),wave_time_format(mmtime.wType));
|
||||||
|
returned = time_to_bytes(&mmtime, pwfx);
|
||||||
|
ok(returned == bytes, "waveInGetPosition(%s): returned %d bytes, "
|
||||||
|
"should be %d\n", dev_name(device), returned, bytes);
|
||||||
|
|
||||||
|
mmtime.wType = TIME_SAMPLES;
|
||||||
|
rc=waveInGetPosition(win, &mmtime, sizeof(mmtime));
|
||||||
|
ok(rc==MMSYSERR_NOERROR,
|
||||||
|
"waveInGetPosition(%s): rc=%s\n",dev_name(device),wave_in_error(rc));
|
||||||
|
if (mmtime.wType != TIME_SAMPLES && winetest_debug > 1)
|
||||||
|
trace("waveInGetPosition(%s): TIME_SAMPLES not supported, "
|
||||||
|
"returned %s\n",dev_name(device),wave_time_format(mmtime.wType));
|
||||||
|
returned = time_to_bytes(&mmtime, pwfx);
|
||||||
|
ok(returned == bytes, "waveInGetPosition(%s): returned %d samples, "
|
||||||
|
"should be %d\n", dev_name(device), bytes_to_samples(returned, pwfx),
|
||||||
|
bytes_to_samples(bytes, pwfx));
|
||||||
|
|
||||||
|
mmtime.wType = TIME_MS;
|
||||||
|
rc=waveInGetPosition(win, &mmtime, sizeof(mmtime));
|
||||||
|
ok(rc==MMSYSERR_NOERROR,
|
||||||
|
"waveInGetPosition(%s): rc=%s\n",dev_name(device),wave_in_error(rc));
|
||||||
|
if (mmtime.wType != TIME_MS && winetest_debug > 1)
|
||||||
|
trace("waveInGetPosition(%s): TIME_MS not supported, returned %s\n",
|
||||||
|
dev_name(device), wave_time_format(mmtime.wType));
|
||||||
|
returned = time_to_bytes(&mmtime, pwfx);
|
||||||
|
ok(returned == bytes, "waveInGetPosition(%s): returned %d ms, "
|
||||||
|
"should be %d\n", dev_name(device), bytes_to_ms(returned, pwfx),
|
||||||
|
bytes_to_ms(bytes, pwfx));
|
||||||
|
|
||||||
|
mmtime.wType = TIME_SMPTE;
|
||||||
|
rc=waveInGetPosition(win, &mmtime, sizeof(mmtime));
|
||||||
|
ok(rc==MMSYSERR_NOERROR,
|
||||||
|
"waveInGetPosition(%s): rc=%s\n",dev_name(device),wave_in_error(rc));
|
||||||
|
if (mmtime.wType != TIME_SMPTE && winetest_debug > 1)
|
||||||
|
trace("waveInGetPosition(%s): TIME_SMPTE not supported, returned %s\n",
|
||||||
|
dev_name(device),wave_time_format(mmtime.wType));
|
||||||
|
returned = time_to_bytes(&mmtime, pwfx);
|
||||||
|
ok(returned == bytes, "waveInGetPosition(%s): SMPTE test failed\n",
|
||||||
|
dev_name(device));
|
||||||
|
|
||||||
|
mmtime.wType = TIME_MIDI;
|
||||||
|
rc=waveInGetPosition(win, &mmtime, sizeof(mmtime));
|
||||||
|
ok(rc==MMSYSERR_NOERROR,
|
||||||
|
"waveInGetPosition(%s): rc=%s\n",dev_name(device),wave_in_error(rc));
|
||||||
|
if (mmtime.wType != TIME_MIDI && winetest_debug > 1)
|
||||||
|
trace("waveInGetPosition(%s): TIME_MIDI not supported, returned %s\n",
|
||||||
|
dev_name(device),wave_time_format(mmtime.wType));
|
||||||
|
returned = time_to_bytes(&mmtime, pwfx);
|
||||||
|
ok(returned == bytes, "waveInGetPosition(%s): MIDI test failed\n",
|
||||||
|
dev_name(device));
|
||||||
|
|
||||||
|
mmtime.wType = TIME_TICKS;
|
||||||
|
rc=waveInGetPosition(win, &mmtime, sizeof(mmtime));
|
||||||
|
ok(rc==MMSYSERR_NOERROR,
|
||||||
|
"waveInGetPosition(%s): rc=%s\n",dev_name(device),wave_in_error(rc));
|
||||||
|
if (mmtime.wType != TIME_TICKS && winetest_debug > 1)
|
||||||
|
trace("waveInGetPosition(%s): TIME_TICKS not supported, returned %s\n",
|
||||||
|
dev_name(device),wave_time_format(mmtime.wType));
|
||||||
|
returned = time_to_bytes(&mmtime, pwfx);
|
||||||
|
ok(returned == bytes, "waveInGetPosition(%s): TICKS test failed\n",
|
||||||
|
dev_name(device));
|
||||||
|
}
|
||||||
|
|
||||||
|
static void wave_in_test_deviceIn(int device, LPWAVEFORMATEX pwfx, DWORD format, DWORD flags, LPWAVEINCAPS pcaps)
|
||||||
|
{
|
||||||
|
HWAVEIN win;
|
||||||
|
HANDLE hevent;
|
||||||
|
WAVEHDR frag;
|
||||||
|
MMRESULT rc;
|
||||||
|
DWORD res;
|
||||||
|
WORD nChannels = pwfx->nChannels;
|
||||||
|
WORD wBitsPerSample = pwfx->wBitsPerSample;
|
||||||
|
DWORD nSamplesPerSec = pwfx->nSamplesPerSec;
|
||||||
|
|
||||||
|
hevent=CreateEvent(NULL,FALSE,FALSE,NULL);
|
||||||
|
ok(hevent!=NULL,"CreateEvent(): error=%d\n",GetLastError());
|
||||||
|
if (hevent==NULL)
|
||||||
|
return;
|
||||||
|
|
||||||
|
win=NULL;
|
||||||
|
rc=waveInOpen(&win,device,pwfx,(DWORD_PTR)hevent,0,CALLBACK_EVENT|flags);
|
||||||
|
/* Note: Win9x doesn't know WAVE_FORMAT_DIRECT */
|
||||||
|
ok(rc==MMSYSERR_NOERROR || rc==MMSYSERR_BADDEVICEID ||
|
||||||
|
rc==MMSYSERR_NOTENABLED || rc==MMSYSERR_NODRIVER ||
|
||||||
|
rc==MMSYSERR_ALLOCATED ||
|
||||||
|
((rc==WAVERR_BADFORMAT || rc==MMSYSERR_NOTSUPPORTED) &&
|
||||||
|
(flags & WAVE_FORMAT_DIRECT) && !(pcaps->dwFormats & format)) ||
|
||||||
|
((rc==WAVERR_BADFORMAT || rc==MMSYSERR_NOTSUPPORTED) &&
|
||||||
|
(!(flags & WAVE_FORMAT_DIRECT) || (flags & WAVE_MAPPED)) &&
|
||||||
|
!(pcaps->dwFormats & format)) ||
|
||||||
|
(rc==MMSYSERR_INVALFLAG && (flags & WAVE_FORMAT_DIRECT)),
|
||||||
|
"waveInOpen(%s): format=%dx%2dx%d flags=%lx(%s) rc=%s\n",
|
||||||
|
dev_name(device),pwfx->nSamplesPerSec,pwfx->wBitsPerSample,
|
||||||
|
pwfx->nChannels,CALLBACK_EVENT|flags,
|
||||||
|
wave_open_flags(CALLBACK_EVENT|flags),wave_in_error(rc));
|
||||||
|
if ((rc==WAVERR_BADFORMAT || rc==MMSYSERR_NOTSUPPORTED) &&
|
||||||
|
(flags & WAVE_FORMAT_DIRECT) && (pcaps->dwFormats & format))
|
||||||
|
trace(" Reason: The device lists this format as supported in it's "
|
||||||
|
"capabilities but opening it failed.\n");
|
||||||
|
if ((rc==WAVERR_BADFORMAT || rc==MMSYSERR_NOTSUPPORTED) &&
|
||||||
|
!(pcaps->dwFormats & format))
|
||||||
|
trace("waveInOpen(%s): format=%dx%2dx%d %s rc=%s failed but format "
|
||||||
|
"not supported so OK.\n",dev_name(device),pwfx->nSamplesPerSec,
|
||||||
|
pwfx->wBitsPerSample,pwfx->nChannels,
|
||||||
|
flags & WAVE_FORMAT_DIRECT ? "flags=WAVE_FORMAT_DIRECT" :
|
||||||
|
flags & WAVE_MAPPED ? "flags=WAVE_MAPPED" : "", mmsys_error(rc));
|
||||||
|
if (rc!=MMSYSERR_NOERROR) {
|
||||||
|
CloseHandle(hevent);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
res=WaitForSingleObject(hevent,1000);
|
||||||
|
ok(res==WAIT_OBJECT_0,"WaitForSingleObject failed for open\n");
|
||||||
|
|
||||||
|
ok(pwfx->nChannels==nChannels &&
|
||||||
|
pwfx->wBitsPerSample==wBitsPerSample &&
|
||||||
|
pwfx->nSamplesPerSec==nSamplesPerSec,
|
||||||
|
"got the wrong format: %dx%2dx%d instead of %dx%2dx%d\n",
|
||||||
|
pwfx->nSamplesPerSec, pwfx->wBitsPerSample,
|
||||||
|
pwfx->nChannels, nSamplesPerSec, wBitsPerSample, nChannels);
|
||||||
|
|
||||||
|
/* Check that the position is 0 at start */
|
||||||
|
check_position(device, win, 0, pwfx);
|
||||||
|
|
||||||
|
frag.lpData=HeapAlloc(GetProcessHeap(), 0, pwfx->nAvgBytesPerSec);
|
||||||
|
frag.dwBufferLength=pwfx->nAvgBytesPerSec;
|
||||||
|
frag.dwBytesRecorded=0;
|
||||||
|
frag.dwUser=0;
|
||||||
|
frag.dwFlags=0;
|
||||||
|
frag.dwLoops=0;
|
||||||
|
frag.lpNext=0;
|
||||||
|
|
||||||
|
rc=waveInPrepareHeader(win, &frag, sizeof(frag));
|
||||||
|
ok(rc==MMSYSERR_NOERROR, "waveInPrepareHeader(%s): rc=%s\n",
|
||||||
|
dev_name(device),wave_in_error(rc));
|
||||||
|
ok(frag.dwFlags&WHDR_PREPARED,"waveInPrepareHeader(%s): prepared flag "
|
||||||
|
"not set\n",dev_name(device));
|
||||||
|
|
||||||
|
if (winetest_interactive && rc==MMSYSERR_NOERROR) {
|
||||||
|
trace("Recording for 1 second at %5dx%2dx%d %s %s\n",
|
||||||
|
pwfx->nSamplesPerSec, pwfx->wBitsPerSample,pwfx->nChannels,
|
||||||
|
get_format_str(pwfx->wFormatTag),
|
||||||
|
flags & WAVE_FORMAT_DIRECT ? "WAVE_FORMAT_DIRECT" :
|
||||||
|
flags & WAVE_MAPPED ? "WAVE_MAPPED" : "");
|
||||||
|
rc=waveInAddBuffer(win, &frag, sizeof(frag));
|
||||||
|
ok(rc==MMSYSERR_NOERROR,"waveInAddBuffer(%s): rc=%s\n",
|
||||||
|
dev_name(device),wave_in_error(rc));
|
||||||
|
|
||||||
|
/* Check that the position is 0 at start */
|
||||||
|
check_position(device, win, 0, pwfx);
|
||||||
|
|
||||||
|
rc=waveInStart(win);
|
||||||
|
ok(rc==MMSYSERR_NOERROR,"waveInStart(%s): rc=%s\n",
|
||||||
|
dev_name(device),wave_in_error(rc));
|
||||||
|
|
||||||
|
res = WaitForSingleObject(hevent,1200);
|
||||||
|
ok(res==WAIT_OBJECT_0,"WaitForSingleObject failed for header\n");
|
||||||
|
ok(frag.dwFlags&WHDR_DONE,"WHDR_DONE not set in frag.dwFlags\n");
|
||||||
|
ok(frag.dwBytesRecorded==pwfx->nAvgBytesPerSec,
|
||||||
|
"frag.dwBytesRecorded=%d, should=%d\n",
|
||||||
|
frag.dwBytesRecorded,pwfx->nAvgBytesPerSec);
|
||||||
|
|
||||||
|
/* stop playing on error */
|
||||||
|
if (res!=WAIT_OBJECT_0) {
|
||||||
|
rc=waveInStop(win);
|
||||||
|
ok(rc==MMSYSERR_NOERROR,
|
||||||
|
"waveInStop(%s): rc=%s\n",dev_name(device),wave_in_error(rc));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
rc=waveInUnprepareHeader(win, &frag, sizeof(frag));
|
||||||
|
ok(rc==MMSYSERR_NOERROR,"waveInUnprepareHeader(%s): rc=%s\n",
|
||||||
|
dev_name(device),wave_in_error(rc));
|
||||||
|
|
||||||
|
rc=waveInClose(win);
|
||||||
|
ok(rc==MMSYSERR_NOERROR,
|
||||||
|
"waveInClose(%s): rc=%s\n",dev_name(device),wave_in_error(rc));
|
||||||
|
res=WaitForSingleObject(hevent,1000);
|
||||||
|
ok(res==WAIT_OBJECT_0,"WaitForSingleObject failed for close\n");
|
||||||
|
|
||||||
|
if (winetest_interactive)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* Now play back what we recorded
|
||||||
|
*/
|
||||||
|
HWAVEOUT wout;
|
||||||
|
|
||||||
|
trace("Playing back recorded sound\n");
|
||||||
|
rc=waveOutOpen(&wout,WAVE_MAPPER,pwfx,(DWORD_PTR)hevent,0,CALLBACK_EVENT);
|
||||||
|
ok(rc==MMSYSERR_NOERROR || rc==MMSYSERR_BADDEVICEID ||
|
||||||
|
rc==MMSYSERR_NOTENABLED || rc==MMSYSERR_NODRIVER ||
|
||||||
|
rc==MMSYSERR_ALLOCATED ||
|
||||||
|
((rc==WAVERR_BADFORMAT || rc==MMSYSERR_NOTSUPPORTED) &&
|
||||||
|
!(pcaps->dwFormats & format)),
|
||||||
|
"waveOutOpen(%s) format=%dx%2dx%d flags=%lx(%s) rc=%s\n",
|
||||||
|
dev_name(device),pwfx->nSamplesPerSec,pwfx->wBitsPerSample,
|
||||||
|
pwfx->nChannels,CALLBACK_EVENT|flags,
|
||||||
|
wave_open_flags(CALLBACK_EVENT),wave_out_error(rc));
|
||||||
|
if (rc==MMSYSERR_NOERROR)
|
||||||
|
{
|
||||||
|
rc=waveOutPrepareHeader(wout, &frag, sizeof(frag));
|
||||||
|
ok(rc==MMSYSERR_NOERROR,"waveOutPrepareHeader(%s): rc=%s\n",
|
||||||
|
dev_name(device),wave_out_error(rc));
|
||||||
|
|
||||||
|
if (rc==MMSYSERR_NOERROR)
|
||||||
|
{
|
||||||
|
WaitForSingleObject(hevent,INFINITE);
|
||||||
|
rc=waveOutWrite(wout, &frag, sizeof(frag));
|
||||||
|
ok(rc==MMSYSERR_NOERROR,"waveOutWrite(%s): rc=%s\n",
|
||||||
|
dev_name(device),wave_out_error(rc));
|
||||||
|
WaitForSingleObject(hevent,INFINITE);
|
||||||
|
|
||||||
|
rc=waveOutUnprepareHeader(wout, &frag, sizeof(frag));
|
||||||
|
ok(rc==MMSYSERR_NOERROR,"waveOutUnprepareHeader(%s): rc=%s\n",
|
||||||
|
dev_name(device),wave_out_error(rc));
|
||||||
|
}
|
||||||
|
rc=waveOutClose(wout);
|
||||||
|
ok(rc==MMSYSERR_NOERROR,"waveOutClose(%s): rc=%s\n",
|
||||||
|
dev_name(device),wave_out_error(rc));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
trace("Unable to play back the recorded sound\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
HeapFree(GetProcessHeap(), 0, frag.lpData);
|
||||||
|
CloseHandle(hevent);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void wave_in_test_device(UINT_PTR device)
|
||||||
|
{
|
||||||
|
WAVEINCAPSA capsA;
|
||||||
|
WAVEINCAPSW capsW;
|
||||||
|
WAVEFORMATEX format,oformat;
|
||||||
|
WAVEFORMATEXTENSIBLE wfex;
|
||||||
|
HWAVEIN win;
|
||||||
|
MMRESULT rc;
|
||||||
|
UINT f;
|
||||||
|
WCHAR * nameW;
|
||||||
|
CHAR * nameA;
|
||||||
|
DWORD size;
|
||||||
|
DWORD dwPageSize;
|
||||||
|
BYTE * twoPages;
|
||||||
|
SYSTEM_INFO sSysInfo;
|
||||||
|
DWORD flOldProtect;
|
||||||
|
BOOL res;
|
||||||
|
|
||||||
|
GetSystemInfo(&sSysInfo);
|
||||||
|
dwPageSize = sSysInfo.dwPageSize;
|
||||||
|
|
||||||
|
rc=waveInGetDevCapsA(device,&capsA,sizeof(capsA));
|
||||||
|
ok(rc==MMSYSERR_NOERROR || rc==MMSYSERR_BADDEVICEID ||
|
||||||
|
rc==MMSYSERR_NODRIVER,
|
||||||
|
"waveInGetDevCapsA(%s): failed to get capabilities: rc=%s\n",
|
||||||
|
dev_name(device),wave_in_error(rc));
|
||||||
|
if (rc==MMSYSERR_BADDEVICEID || rc==MMSYSERR_NODRIVER)
|
||||||
|
return;
|
||||||
|
|
||||||
|
rc=waveInGetDevCapsW(device,&capsW,sizeof(capsW));
|
||||||
|
ok(rc==MMSYSERR_NOERROR || rc==MMSYSERR_NOTSUPPORTED,
|
||||||
|
"waveInGetDevCapsW(%s): MMSYSERR_NOERROR or MMSYSERR_NOTSUPPORTED "
|
||||||
|
"expected, got %s\n",dev_name(device),wave_in_error(rc));
|
||||||
|
|
||||||
|
rc=waveInGetDevCapsA(device,NULL,sizeof(capsA));
|
||||||
|
ok(rc==MMSYSERR_INVALPARAM,
|
||||||
|
"waveInGetDevCapsA(%s): MMSYSERR_INVALPARAM expected, got %s\n",
|
||||||
|
dev_name(device),wave_in_error(rc));
|
||||||
|
|
||||||
|
rc=waveInGetDevCapsW(device,NULL,sizeof(capsW));
|
||||||
|
ok(rc==MMSYSERR_INVALPARAM || rc==MMSYSERR_NOTSUPPORTED,
|
||||||
|
"waveInGetDevCapsW(%s): MMSYSERR_INVALPARAM or MMSYSERR_NOTSUPPORTED "
|
||||||
|
"expected, got %s\n",dev_name(device),wave_in_error(rc));
|
||||||
|
|
||||||
|
if (0)
|
||||||
|
{
|
||||||
|
/* FIXME: this works on windows but crashes wine */
|
||||||
|
rc=waveInGetDevCapsA(device,(LPWAVEINCAPSA)1,sizeof(capsA));
|
||||||
|
ok(rc==MMSYSERR_INVALPARAM,
|
||||||
|
"waveInGetDevCapsA(%s): MMSYSERR_INVALPARAM expected, got %s\n",
|
||||||
|
dev_name(device),wave_in_error(rc));
|
||||||
|
|
||||||
|
rc=waveInGetDevCapsW(device,(LPWAVEINCAPSW)1,sizeof(capsW));
|
||||||
|
ok(rc==MMSYSERR_INVALPARAM || rc==MMSYSERR_NOTSUPPORTED,
|
||||||
|
"waveInGetDevCapsW(%s): MMSYSERR_INVALPARAM or MMSYSERR_NOTSUPPORTED "
|
||||||
|
"expected, got %s\n",dev_name(device),wave_in_error(rc));
|
||||||
|
}
|
||||||
|
|
||||||
|
rc=waveInGetDevCapsA(device,&capsA,4);
|
||||||
|
ok(rc==MMSYSERR_NOERROR,
|
||||||
|
"waveInGetDevCapsA(%s): MMSYSERR_NOERROR expected, got %s\n",
|
||||||
|
dev_name(device),wave_in_error(rc));
|
||||||
|
|
||||||
|
rc=waveInGetDevCapsW(device,&capsW,4);
|
||||||
|
ok(rc==MMSYSERR_NOERROR || rc==MMSYSERR_NOTSUPPORTED ||
|
||||||
|
rc==MMSYSERR_INVALPARAM, /* Vista, W2K8 */
|
||||||
|
"waveInGetDevCapsW(%s): unexpected return value %s\n",
|
||||||
|
dev_name(device),wave_in_error(rc));
|
||||||
|
|
||||||
|
nameA=NULL;
|
||||||
|
rc=waveInMessage((HWAVEIN)device, DRV_QUERYDEVICEINTERFACESIZE,
|
||||||
|
(DWORD_PTR)&size, 0);
|
||||||
|
ok(rc==MMSYSERR_NOERROR || rc==MMSYSERR_INVALPARAM ||
|
||||||
|
rc==MMSYSERR_NOTSUPPORTED,
|
||||||
|
"waveInMessage(%s): failed to get interface size: rc=%s\n",
|
||||||
|
dev_name(device),wave_in_error(rc));
|
||||||
|
if (rc==MMSYSERR_NOERROR) {
|
||||||
|
nameW = HeapAlloc(GetProcessHeap(), 0, size);
|
||||||
|
rc=waveInMessage((HWAVEIN)device, DRV_QUERYDEVICEINTERFACE,
|
||||||
|
(DWORD_PTR)nameW, size);
|
||||||
|
ok(rc==MMSYSERR_NOERROR,"waveInMessage(%s): failed to get interface "
|
||||||
|
"name: rc=%s\n",dev_name(device),wave_in_error(rc));
|
||||||
|
ok(lstrlenW(nameW)+1==size/sizeof(WCHAR),
|
||||||
|
"got an incorrect size %d\n", size);
|
||||||
|
if (rc==MMSYSERR_NOERROR) {
|
||||||
|
nameA = HeapAlloc(GetProcessHeap(), 0, size/sizeof(WCHAR));
|
||||||
|
WideCharToMultiByte(CP_ACP, 0, nameW, size/sizeof(WCHAR),
|
||||||
|
nameA, size/sizeof(WCHAR), NULL, NULL);
|
||||||
|
}
|
||||||
|
HeapFree(GetProcessHeap(), 0, nameW);
|
||||||
|
} else if (rc==MMSYSERR_NOTSUPPORTED) {
|
||||||
|
nameA=HeapAlloc(GetProcessHeap(), 0, sizeof("not supported"));
|
||||||
|
strcpy(nameA, "not supported");
|
||||||
|
}
|
||||||
|
|
||||||
|
trace(" %s: \"%s\" (%s) %d.%d (%d:%d)\n",dev_name(device),capsA.szPname,
|
||||||
|
(nameA?nameA:"failed"),capsA.vDriverVersion >> 8,
|
||||||
|
capsA.vDriverVersion & 0xff,capsA.wMid,capsA.wPid);
|
||||||
|
trace(" channels=%d formats=%05x\n",
|
||||||
|
capsA.wChannels,capsA.dwFormats);
|
||||||
|
|
||||||
|
HeapFree(GetProcessHeap(), 0, nameA);
|
||||||
|
|
||||||
|
for (f=0;f<NB_WIN_FORMATS;f++) {
|
||||||
|
format.wFormatTag=WAVE_FORMAT_PCM;
|
||||||
|
format.nChannels=win_formats[f][3];
|
||||||
|
format.wBitsPerSample=win_formats[f][2];
|
||||||
|
format.nSamplesPerSec=win_formats[f][1];
|
||||||
|
format.nBlockAlign=format.nChannels*format.wBitsPerSample/8;
|
||||||
|
format.nAvgBytesPerSec=format.nSamplesPerSec*format.nBlockAlign;
|
||||||
|
format.cbSize=0;
|
||||||
|
wave_in_test_deviceIn(device,&format,win_formats[f][0],0, &capsA);
|
||||||
|
if (device != WAVE_MAPPER) {
|
||||||
|
wave_in_test_deviceIn(device,&format,win_formats[f][0],
|
||||||
|
WAVE_FORMAT_DIRECT, &capsA);
|
||||||
|
wave_in_test_deviceIn(device,&format,win_formats[f][0],
|
||||||
|
WAVE_MAPPED, &capsA);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Try a PCMWAVEFORMAT aligned next to an unaccessible page for bounds
|
||||||
|
* checking */
|
||||||
|
twoPages = VirtualAlloc(NULL, 2 * dwPageSize, MEM_RESERVE | MEM_COMMIT,
|
||||||
|
PAGE_READWRITE);
|
||||||
|
ok(twoPages!=NULL,"Failed to allocate 2 pages of memory\n");
|
||||||
|
if (twoPages) {
|
||||||
|
res = VirtualProtect(twoPages + dwPageSize, dwPageSize, PAGE_NOACCESS,
|
||||||
|
&flOldProtect);
|
||||||
|
ok(res, "Failed to set memory access on second page\n");
|
||||||
|
if (res) {
|
||||||
|
LPWAVEFORMATEX pwfx = (LPWAVEFORMATEX)(twoPages + dwPageSize -
|
||||||
|
sizeof(PCMWAVEFORMAT));
|
||||||
|
pwfx->wFormatTag=WAVE_FORMAT_PCM;
|
||||||
|
pwfx->nChannels=1;
|
||||||
|
pwfx->wBitsPerSample=8;
|
||||||
|
pwfx->nSamplesPerSec=22050;
|
||||||
|
pwfx->nBlockAlign=pwfx->nChannels*pwfx->wBitsPerSample/8;
|
||||||
|
pwfx->nAvgBytesPerSec=pwfx->nSamplesPerSec*pwfx->nBlockAlign;
|
||||||
|
wave_in_test_deviceIn(device,pwfx,WAVE_FORMAT_2M08,0, &capsA);
|
||||||
|
if (device != WAVE_MAPPER) {
|
||||||
|
wave_in_test_deviceIn(device,pwfx,WAVE_FORMAT_2M08,
|
||||||
|
WAVE_FORMAT_DIRECT, &capsA);
|
||||||
|
wave_in_test_deviceIn(device,pwfx,WAVE_FORMAT_2M08,
|
||||||
|
WAVE_MAPPED, &capsA);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
VirtualFree(twoPages, 2 * dwPageSize, MEM_RELEASE);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Testing invalid format: 2 MHz sample rate */
|
||||||
|
format.wFormatTag=WAVE_FORMAT_PCM;
|
||||||
|
format.nChannels=2;
|
||||||
|
format.wBitsPerSample=16;
|
||||||
|
format.nSamplesPerSec=2000000;
|
||||||
|
format.nBlockAlign=format.nChannels*format.wBitsPerSample/8;
|
||||||
|
format.nAvgBytesPerSec=format.nSamplesPerSec*format.nBlockAlign;
|
||||||
|
format.cbSize=0;
|
||||||
|
oformat=format;
|
||||||
|
rc=waveInOpen(&win,device,&format,0,0,CALLBACK_NULL|WAVE_FORMAT_DIRECT);
|
||||||
|
ok(rc==WAVERR_BADFORMAT || rc==MMSYSERR_INVALFLAG ||
|
||||||
|
rc==MMSYSERR_INVALPARAM,
|
||||||
|
"waveInOpen(%s): opening the device with 2 MHz sample rate should fail: "
|
||||||
|
" rc=%s\n",dev_name(device),wave_in_error(rc));
|
||||||
|
if (rc==MMSYSERR_NOERROR) {
|
||||||
|
trace(" got %dx%2dx%d for %dx%2dx%d\n",
|
||||||
|
format.nSamplesPerSec, format.wBitsPerSample,
|
||||||
|
format.nChannels,
|
||||||
|
oformat.nSamplesPerSec, oformat.wBitsPerSample,
|
||||||
|
oformat.nChannels);
|
||||||
|
waveInClose(win);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* test non PCM formats */
|
||||||
|
format.wFormatTag=WAVE_FORMAT_MULAW;
|
||||||
|
format.nChannels=1;
|
||||||
|
format.wBitsPerSample=8;
|
||||||
|
format.nSamplesPerSec=8000;
|
||||||
|
format.nBlockAlign=format.nChannels*format.wBitsPerSample/8;
|
||||||
|
format.nAvgBytesPerSec=format.nSamplesPerSec*format.nBlockAlign;
|
||||||
|
format.cbSize=0;
|
||||||
|
rc=waveInOpen(&win,device,&format,0,0,CALLBACK_NULL|WAVE_FORMAT_DIRECT);
|
||||||
|
ok(rc==MMSYSERR_NOERROR || rc==WAVERR_BADFORMAT ||
|
||||||
|
rc==MMSYSERR_INVALFLAG || rc==MMSYSERR_INVALPARAM,
|
||||||
|
"waveInOpen(%s): returned: %s\n",dev_name(device),wave_in_error(rc));
|
||||||
|
if (rc==MMSYSERR_NOERROR) {
|
||||||
|
waveInClose(win);
|
||||||
|
wave_in_test_deviceIn(device,&format,0,0,&capsA);
|
||||||
|
} else
|
||||||
|
trace("waveInOpen(%s): WAVE_FORMAT_MULAW not supported\n",
|
||||||
|
dev_name(device));
|
||||||
|
|
||||||
|
format.wFormatTag=WAVE_FORMAT_ADPCM;
|
||||||
|
format.nChannels=2;
|
||||||
|
format.wBitsPerSample=4;
|
||||||
|
format.nSamplesPerSec=22050;
|
||||||
|
format.nBlockAlign=format.nChannels*format.wBitsPerSample/8;
|
||||||
|
format.nAvgBytesPerSec=format.nSamplesPerSec*format.nBlockAlign;
|
||||||
|
format.cbSize=0;
|
||||||
|
rc=waveInOpen(&win,device,&format,0,0,CALLBACK_NULL|WAVE_FORMAT_DIRECT);
|
||||||
|
ok(rc==MMSYSERR_NOERROR || rc==WAVERR_BADFORMAT ||
|
||||||
|
rc==MMSYSERR_INVALFLAG || rc==MMSYSERR_INVALPARAM,
|
||||||
|
"waveInOpen(%s): returned: %s\n",dev_name(device),wave_in_error(rc));
|
||||||
|
if (rc==MMSYSERR_NOERROR) {
|
||||||
|
waveInClose(win);
|
||||||
|
wave_in_test_deviceIn(device,&format,0,0,&capsA);
|
||||||
|
} else
|
||||||
|
trace("waveInOpen(%s): WAVE_FORMAT_ADPCM not supported\n",
|
||||||
|
dev_name(device));
|
||||||
|
|
||||||
|
/* test if WAVEFORMATEXTENSIBLE supported */
|
||||||
|
wfex.Format.wFormatTag=WAVE_FORMAT_EXTENSIBLE;
|
||||||
|
wfex.Format.nChannels=2;
|
||||||
|
wfex.Format.wBitsPerSample=16;
|
||||||
|
wfex.Format.nSamplesPerSec=22050;
|
||||||
|
wfex.Format.nBlockAlign=wfex.Format.nChannels*wfex.Format.wBitsPerSample/8;
|
||||||
|
wfex.Format.nAvgBytesPerSec=wfex.Format.nSamplesPerSec*
|
||||||
|
wfex.Format.nBlockAlign;
|
||||||
|
wfex.Format.cbSize=22;
|
||||||
|
wfex.Samples.wValidBitsPerSample=wfex.Format.wBitsPerSample;
|
||||||
|
wfex.dwChannelMask=SPEAKER_ALL;
|
||||||
|
wfex.SubFormat=KSDATAFORMAT_SUBTYPE_PCM;
|
||||||
|
rc=waveInOpen(&win,device,&wfex.Format,0,0,
|
||||||
|
CALLBACK_NULL|WAVE_FORMAT_DIRECT);
|
||||||
|
ok(rc==MMSYSERR_NOERROR || rc==WAVERR_BADFORMAT ||
|
||||||
|
rc==MMSYSERR_INVALFLAG || rc==MMSYSERR_INVALPARAM,
|
||||||
|
"waveInOpen(%s): returned: %s\n",dev_name(device),wave_in_error(rc));
|
||||||
|
if (rc==MMSYSERR_NOERROR) {
|
||||||
|
waveInClose(win);
|
||||||
|
wave_in_test_deviceIn(device,&wfex.Format,0,0,&capsA);
|
||||||
|
} else
|
||||||
|
trace("waveInOpen(%s): WAVE_FORMAT_EXTENSIBLE not supported\n",
|
||||||
|
dev_name(device));
|
||||||
|
|
||||||
|
/* test if 4 channels supported */
|
||||||
|
wfex.Format.wFormatTag=WAVE_FORMAT_EXTENSIBLE;
|
||||||
|
wfex.Format.nChannels=4;
|
||||||
|
wfex.Format.wBitsPerSample=16;
|
||||||
|
wfex.Format.nSamplesPerSec=22050;
|
||||||
|
wfex.Format.nBlockAlign=wfex.Format.nChannels*wfex.Format.wBitsPerSample/8;
|
||||||
|
wfex.Format.nAvgBytesPerSec=wfex.Format.nSamplesPerSec*
|
||||||
|
wfex.Format.nBlockAlign;
|
||||||
|
wfex.Format.cbSize=22;
|
||||||
|
wfex.Samples.wValidBitsPerSample=wfex.Format.wBitsPerSample;
|
||||||
|
wfex.dwChannelMask=SPEAKER_ALL;
|
||||||
|
wfex.SubFormat=KSDATAFORMAT_SUBTYPE_PCM;
|
||||||
|
rc=waveInOpen(&win,device,&wfex.Format,0,0,
|
||||||
|
CALLBACK_NULL|WAVE_FORMAT_DIRECT);
|
||||||
|
ok(rc==MMSYSERR_NOERROR || rc==WAVERR_BADFORMAT ||
|
||||||
|
rc==MMSYSERR_INVALFLAG || rc==MMSYSERR_INVALPARAM,
|
||||||
|
"waveInOpen(%s): returned: %s\n",dev_name(device),wave_in_error(rc));
|
||||||
|
if (rc==MMSYSERR_NOERROR) {
|
||||||
|
waveInClose(win);
|
||||||
|
wave_in_test_deviceIn(device,&wfex.Format,0,0,&capsA);
|
||||||
|
} else
|
||||||
|
trace("waveInOpen(%s): 4 channels not supported\n",
|
||||||
|
dev_name(device));
|
||||||
|
|
||||||
|
/* test if 6 channels supported */
|
||||||
|
wfex.Format.wFormatTag=WAVE_FORMAT_EXTENSIBLE;
|
||||||
|
wfex.Format.nChannels=6;
|
||||||
|
wfex.Format.wBitsPerSample=16;
|
||||||
|
wfex.Format.nSamplesPerSec=22050;
|
||||||
|
wfex.Format.nBlockAlign=wfex.Format.nChannels*wfex.Format.wBitsPerSample/8;
|
||||||
|
wfex.Format.nAvgBytesPerSec=wfex.Format.nSamplesPerSec*
|
||||||
|
wfex.Format.nBlockAlign;
|
||||||
|
wfex.Format.cbSize=22;
|
||||||
|
wfex.Samples.wValidBitsPerSample=wfex.Format.wBitsPerSample;
|
||||||
|
wfex.dwChannelMask=SPEAKER_ALL;
|
||||||
|
wfex.SubFormat=KSDATAFORMAT_SUBTYPE_PCM;
|
||||||
|
rc=waveInOpen(&win,device,&wfex.Format,0,0,
|
||||||
|
CALLBACK_NULL|WAVE_FORMAT_DIRECT);
|
||||||
|
ok(rc==MMSYSERR_NOERROR || rc==WAVERR_BADFORMAT ||
|
||||||
|
rc==MMSYSERR_INVALFLAG || rc==MMSYSERR_INVALPARAM,
|
||||||
|
"waveInOpen(%s): returned: %s\n",dev_name(device),wave_in_error(rc));
|
||||||
|
if (rc==MMSYSERR_NOERROR) {
|
||||||
|
waveInClose(win);
|
||||||
|
wave_in_test_deviceIn(device,&wfex.Format,0,0,&capsA);
|
||||||
|
} else
|
||||||
|
trace("waveInOpen(%s): 6 channels not supported\n",
|
||||||
|
dev_name(device));
|
||||||
|
|
||||||
|
if (0)
|
||||||
|
{
|
||||||
|
/* FIXME: ALSA doesn't like this */
|
||||||
|
/* test if 24 bit samples supported */
|
||||||
|
wfex.Format.wFormatTag=WAVE_FORMAT_EXTENSIBLE;
|
||||||
|
wfex.Format.nChannels=2;
|
||||||
|
wfex.Format.wBitsPerSample=24;
|
||||||
|
wfex.Format.nSamplesPerSec=22050;
|
||||||
|
wfex.Format.nBlockAlign=wfex.Format.nChannels*wfex.Format.wBitsPerSample/8;
|
||||||
|
wfex.Format.nAvgBytesPerSec=wfex.Format.nSamplesPerSec*
|
||||||
|
wfex.Format.nBlockAlign;
|
||||||
|
wfex.Format.cbSize=22;
|
||||||
|
wfex.Samples.wValidBitsPerSample=wfex.Format.wBitsPerSample;
|
||||||
|
wfex.dwChannelMask=SPEAKER_ALL;
|
||||||
|
wfex.SubFormat=KSDATAFORMAT_SUBTYPE_PCM;
|
||||||
|
rc=waveInOpen(&win,device,&wfex.Format,0,0,
|
||||||
|
CALLBACK_NULL|WAVE_FORMAT_DIRECT);
|
||||||
|
ok(rc==MMSYSERR_NOERROR || rc==WAVERR_BADFORMAT ||
|
||||||
|
rc==MMSYSERR_INVALFLAG || rc==MMSYSERR_INVALPARAM,
|
||||||
|
"waveInOpen(%s): returned: %s\n",dev_name(device),wave_in_error(rc));
|
||||||
|
if (rc==MMSYSERR_NOERROR) {
|
||||||
|
waveInClose(win);
|
||||||
|
wave_in_test_deviceIn(device,&wfex.Format,0,0,&capsA);
|
||||||
|
} else
|
||||||
|
trace("waveInOpen(%s): 24 bit samples not supported\n",
|
||||||
|
dev_name(device));
|
||||||
|
}
|
||||||
|
|
||||||
|
/* test if 32 bit samples supported */
|
||||||
|
wfex.Format.wFormatTag=WAVE_FORMAT_EXTENSIBLE;
|
||||||
|
wfex.Format.nChannels=2;
|
||||||
|
wfex.Format.wBitsPerSample=32;
|
||||||
|
wfex.Format.nSamplesPerSec=22050;
|
||||||
|
wfex.Format.nBlockAlign=wfex.Format.nChannels*wfex.Format.wBitsPerSample/8;
|
||||||
|
wfex.Format.nAvgBytesPerSec=wfex.Format.nSamplesPerSec*
|
||||||
|
wfex.Format.nBlockAlign;
|
||||||
|
wfex.Format.cbSize=22;
|
||||||
|
wfex.Samples.wValidBitsPerSample=wfex.Format.wBitsPerSample;
|
||||||
|
wfex.dwChannelMask=SPEAKER_ALL;
|
||||||
|
wfex.SubFormat=KSDATAFORMAT_SUBTYPE_PCM;
|
||||||
|
rc=waveInOpen(&win,device,&wfex.Format,0,0,
|
||||||
|
CALLBACK_NULL|WAVE_FORMAT_DIRECT);
|
||||||
|
ok(rc==MMSYSERR_NOERROR || rc==WAVERR_BADFORMAT ||
|
||||||
|
rc==MMSYSERR_INVALFLAG || rc==MMSYSERR_INVALPARAM,
|
||||||
|
"waveInOpen(%s): returned: %s\n",dev_name(device),wave_in_error(rc));
|
||||||
|
if (rc==MMSYSERR_NOERROR) {
|
||||||
|
waveInClose(win);
|
||||||
|
wave_in_test_deviceIn(device,&wfex.Format,0,0,&capsA);
|
||||||
|
} else
|
||||||
|
trace("waveInOpen(%s): 32 bit samples not supported\n",
|
||||||
|
dev_name(device));
|
||||||
|
|
||||||
|
/* test if 32 bit float samples supported */
|
||||||
|
wfex.Format.wFormatTag=WAVE_FORMAT_EXTENSIBLE;
|
||||||
|
wfex.Format.nChannels=2;
|
||||||
|
wfex.Format.wBitsPerSample=32;
|
||||||
|
wfex.Format.nSamplesPerSec=22050;
|
||||||
|
wfex.Format.nBlockAlign=wfex.Format.nChannels*wfex.Format.wBitsPerSample/8;
|
||||||
|
wfex.Format.nAvgBytesPerSec=wfex.Format.nSamplesPerSec*
|
||||||
|
wfex.Format.nBlockAlign;
|
||||||
|
wfex.Format.cbSize=22;
|
||||||
|
wfex.Samples.wValidBitsPerSample=wfex.Format.wBitsPerSample;
|
||||||
|
wfex.dwChannelMask=SPEAKER_ALL;
|
||||||
|
wfex.SubFormat=KSDATAFORMAT_SUBTYPE_IEEE_FLOAT;
|
||||||
|
rc=waveInOpen(&win,device,&wfex.Format,0,0,
|
||||||
|
CALLBACK_NULL|WAVE_FORMAT_DIRECT);
|
||||||
|
ok(rc==MMSYSERR_NOERROR || rc==WAVERR_BADFORMAT ||
|
||||||
|
rc==MMSYSERR_INVALFLAG || rc==MMSYSERR_INVALPARAM,
|
||||||
|
"waveInOpen(%s): returned: %s\n",dev_name(device),wave_in_error(rc));
|
||||||
|
if (rc==MMSYSERR_NOERROR) {
|
||||||
|
waveInClose(win);
|
||||||
|
wave_in_test_deviceIn(device,&wfex.Format,0,0,&capsA);
|
||||||
|
} else
|
||||||
|
trace("waveInOpen(%s): 32 bit float samples not supported\n",
|
||||||
|
dev_name(device));
|
||||||
|
}
|
||||||
|
|
||||||
|
static void wave_in_tests(void)
|
||||||
|
{
|
||||||
|
WAVEINCAPSA capsA;
|
||||||
|
WAVEINCAPSW capsW;
|
||||||
|
WAVEFORMATEX format;
|
||||||
|
HWAVEIN win;
|
||||||
|
MMRESULT rc;
|
||||||
|
UINT ndev,d;
|
||||||
|
|
||||||
|
ndev=waveInGetNumDevs();
|
||||||
|
trace("found %d WaveIn devices\n",ndev);
|
||||||
|
|
||||||
|
rc=waveInGetDevCapsA(ndev+1,&capsA,sizeof(capsA));
|
||||||
|
ok(rc==MMSYSERR_BADDEVICEID,
|
||||||
|
"waveInGetDevCapsA(%s): MMSYSERR_BADDEVICEID expected, got %s\n",
|
||||||
|
dev_name(ndev+1),wave_in_error(rc));
|
||||||
|
|
||||||
|
rc=waveInGetDevCapsA(WAVE_MAPPER,&capsA,sizeof(capsA));
|
||||||
|
if (ndev>0)
|
||||||
|
ok(rc==MMSYSERR_NOERROR || rc==MMSYSERR_NODRIVER,
|
||||||
|
"waveInGetDevCapsA(%s): MMSYSERR_NOERROR or MMSYSERR_NODRIVER "
|
||||||
|
"expected, got %s\n",dev_name(WAVE_MAPPER),wave_in_error(rc));
|
||||||
|
else
|
||||||
|
ok(rc==MMSYSERR_BADDEVICEID || rc==MMSYSERR_NODRIVER,
|
||||||
|
"waveInGetDevCapsA(%s): MMSYSERR_BADDEVICEID or MMSYSERR_NODRIVER "
|
||||||
|
"expected, got %s\n",dev_name(WAVE_MAPPER),wave_in_error(rc));
|
||||||
|
|
||||||
|
rc=waveInGetDevCapsW(ndev+1,&capsW,sizeof(capsW));
|
||||||
|
ok(rc==MMSYSERR_BADDEVICEID || rc==MMSYSERR_NOTSUPPORTED,
|
||||||
|
"waveInGetDevCapsW(%s): MMSYSERR_BADDEVICEID or MMSYSERR_NOTSUPPORTED "
|
||||||
|
"expected, got %s\n",dev_name(ndev+1),wave_in_error(rc));
|
||||||
|
|
||||||
|
rc=waveInGetDevCapsW(WAVE_MAPPER,&capsW,sizeof(capsW));
|
||||||
|
if (ndev>0)
|
||||||
|
ok(rc==MMSYSERR_NOERROR || rc==MMSYSERR_NODRIVER ||
|
||||||
|
rc==MMSYSERR_NOTSUPPORTED,
|
||||||
|
"waveInGetDevCapsW(%s): MMSYSERR_NOERROR or MMSYSERR_NODRIVER or "
|
||||||
|
"MMSYSERR_NOTSUPPORTED expected, got %s\n",
|
||||||
|
dev_name(ndev+1),wave_in_error(rc));
|
||||||
|
else
|
||||||
|
ok(rc==MMSYSERR_BADDEVICEID || rc==MMSYSERR_NODRIVER ||
|
||||||
|
rc==MMSYSERR_NOTSUPPORTED,
|
||||||
|
"waveInGetDevCapsW(%s): MMSYSERR_BADDEVICEID or MMSYSERR_NODRIVER or"
|
||||||
|
"MMSYSERR_NOTSUPPORTED expected, got %s\n",
|
||||||
|
dev_name(ndev+1),wave_in_error(rc));
|
||||||
|
|
||||||
|
format.wFormatTag=WAVE_FORMAT_PCM;
|
||||||
|
format.nChannels=2;
|
||||||
|
format.wBitsPerSample=16;
|
||||||
|
format.nSamplesPerSec=44100;
|
||||||
|
format.nBlockAlign=format.nChannels*format.wBitsPerSample/8;
|
||||||
|
format.nAvgBytesPerSec=format.nSamplesPerSec*format.nBlockAlign;
|
||||||
|
format.cbSize=0;
|
||||||
|
rc=waveInOpen(&win,ndev+1,&format,0,0,CALLBACK_NULL);
|
||||||
|
ok(rc==MMSYSERR_BADDEVICEID,
|
||||||
|
"waveInOpen(%s): MMSYSERR_BADDEVICEID expected, got %s\n",
|
||||||
|
dev_name(ndev+1),wave_in_error(rc));
|
||||||
|
|
||||||
|
for (d=0;d<ndev;d++)
|
||||||
|
wave_in_test_device(d);
|
||||||
|
|
||||||
|
if (ndev>0)
|
||||||
|
wave_in_test_device(WAVE_MAPPER);
|
||||||
|
}
|
||||||
|
|
||||||
|
START_TEST(capture)
|
||||||
|
{
|
||||||
|
wave_in_tests();
|
||||||
|
}
|
70
rostests/winetests/winmm/mci.c
Normal file
70
rostests/winetests/winmm/mci.c
Normal file
|
@ -0,0 +1,70 @@
|
||||||
|
/*
|
||||||
|
* 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";
|
||||||
|
const char command_sysinfo[] = "sysinfo waveaudio quantity open";
|
||||||
|
MSG msg;
|
||||||
|
char buf[1024];
|
||||||
|
HWND hwnd;
|
||||||
|
|
||||||
|
hwnd = CreateWindowExA(0, "static", "winmm test", WS_POPUP, 0,0,100,100,
|
||||||
|
0, 0, 0, NULL);
|
||||||
|
|
||||||
|
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, hwnd);
|
||||||
|
ok(!err,"mciSendString(%s, NULL, 0 , NULL) returned error: %d\n", command_close_my, err);
|
||||||
|
|
||||||
|
ok(PeekMessageA( &msg, hwnd, 0, 0, PM_REMOVE ), "PeekMessage should succeed\n");
|
||||||
|
ok(msg.hwnd == hwnd, "Didn't get the handle to our test window\n");
|
||||||
|
ok(msg.message == MM_MCINOTIFY, "got %04x instead of MM_MCINOTIFY\n", msg.message);
|
||||||
|
ok(msg.wParam == MCI_NOTIFY_SUCCESSFUL, "got %08lx 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);
|
||||||
|
|
||||||
|
memset(buf, 0, sizeof(buf));
|
||||||
|
err = mciSendString(command_close_all, buf, sizeof(buf), hwnd);
|
||||||
|
todo_wine ok(!err,"mciSendString(%s, buf, sizeof(buf) , NULL) returned error: %d\n", command_close_all, err);
|
||||||
|
ok(buf[0] == 0, "mciSendString(%s, buf, sizeof(buf) , NULL) changed output buffer: %s\n", command_close_all, buf);
|
||||||
|
|
||||||
|
memset(buf, 0, sizeof(buf));
|
||||||
|
err = mciSendString(command_sysinfo, buf, sizeof(buf), NULL);
|
||||||
|
ok(!err,"mciSendString(%s, buf, sizeof(buf) , NULL) returned error: %d\n", command_sysinfo, err);
|
||||||
|
todo_wine ok(buf[0] == '0' && buf[1] == 0, "mciSendString(%s, buf, sizeof(buf) , NULL), expected output buffer '0', got: '%s'\n", command_sysinfo, buf);
|
||||||
|
|
||||||
|
err = mciSendCommand(MCI_ALL_DEVICE_ID, MCI_CLOSE, MCI_NOTIFY, 0);
|
||||||
|
todo_wine ok(err == MCIERR_INVALID_DEVICE_ID ||
|
||||||
|
broken(!err), /* Win9x and WinMe */
|
||||||
|
"mciSendCommand(MCI_ALL_DEVICE_ID, MCI_CLOSE, MCI_NOTIFY, NULL) returned %d instead of %d\n",
|
||||||
|
err, MCIERR_INVALID_DEVICE_ID);
|
||||||
|
|
||||||
|
DestroyWindow(hwnd);
|
||||||
|
}
|
1065
rostests/winetests/winmm/mixer.c
Normal file
1065
rostests/winetests/winmm/mixer.c
Normal file
File diff suppressed because it is too large
Load diff
453
rostests/winetests/winmm/mmio.c
Normal file
453
rostests/winetests/winmm/mmio.c
Normal file
|
@ -0,0 +1,453 @@
|
||||||
|
/*
|
||||||
|
* Unit tests for mmio APIs
|
||||||
|
*
|
||||||
|
* Copyright 2005 Dmitry Timoshkov
|
||||||
|
*
|
||||||
|
* 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 <assert.h>
|
||||||
|
#include <stdarg.h>
|
||||||
|
|
||||||
|
#include "windef.h"
|
||||||
|
#include "winbase.h"
|
||||||
|
#include "wingdi.h"
|
||||||
|
#include "mmsystem.h"
|
||||||
|
#include "vfw.h"
|
||||||
|
#include "wine/test.h"
|
||||||
|
|
||||||
|
static DWORD RIFF_buf[] =
|
||||||
|
{
|
||||||
|
FOURCC_RIFF, 32*sizeof(DWORD), mmioFOURCC('A','V','I',' '),
|
||||||
|
FOURCC_LIST, 29*sizeof(DWORD), listtypeAVIHEADER, ckidAVIMAINHDR,
|
||||||
|
sizeof(MainAVIHeader), 0xdeadbeef, 0xdeadbeef, 0xdeadbeef,
|
||||||
|
0xdeadbeef, 0xdeadbeef, 0xdeadbeef,0xdeadbeef,
|
||||||
|
0xdeadbeef, 0xdeadbeef, 0xdeadbeef,0xdeadbeef,
|
||||||
|
0xdeadbeef, 0xdeadbeef, 0xdeadbeef,
|
||||||
|
FOURCC_LIST, 10*sizeof(DWORD),listtypeSTREAMHEADER, ckidSTREAMHEADER,
|
||||||
|
7*sizeof(DWORD), streamtypeVIDEO, 0xdeadbeef, 0xdeadbeef,
|
||||||
|
0xdeadbeef, 0xdeadbeef, 0xdeadbeef, 0xdeadbeef,
|
||||||
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
||||||
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
||||||
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
||||||
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
|
||||||
|
};
|
||||||
|
|
||||||
|
static void test_mmioDescend(char *fname)
|
||||||
|
{
|
||||||
|
MMRESULT ret;
|
||||||
|
HMMIO hmmio;
|
||||||
|
MMIOINFO mmio;
|
||||||
|
MMCKINFO ckRiff, ckList, ck;
|
||||||
|
|
||||||
|
memset(&mmio, 0, sizeof(mmio));
|
||||||
|
mmio.fccIOProc = fname ? FOURCC_DOS : FOURCC_MEM;
|
||||||
|
mmio.cchBuffer = sizeof(RIFF_buf);
|
||||||
|
mmio.pchBuffer = (char *)RIFF_buf;
|
||||||
|
hmmio = mmioOpen(fname, &mmio, MMIO_READ);
|
||||||
|
if (fname && !hmmio)
|
||||||
|
{
|
||||||
|
skip("%s file is missing, skipping the test\n", fname);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
ok(hmmio != 0, "mmioOpen error %u\n", mmio.wErrorRet);
|
||||||
|
|
||||||
|
/* first normal RIFF AVI parsing */
|
||||||
|
ret = mmioDescend(hmmio, &ckRiff, NULL, 0);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioDescend error %u\n", ret);
|
||||||
|
ok(ckRiff.ckid == FOURCC_RIFF, "wrong ckid: %04x\n", ckRiff.ckid);
|
||||||
|
ok(ckRiff.fccType == formtypeAVI, "wrong fccType: %04x\n", ckRiff.fccType);
|
||||||
|
trace("ckid %4.4s cksize %04x fccType %4.4s off %04x flags %04x\n",
|
||||||
|
(LPCSTR)&ckRiff.ckid, ckRiff.cksize, (LPCSTR)&ckRiff.fccType,
|
||||||
|
ckRiff.dwDataOffset, ckRiff.dwFlags);
|
||||||
|
|
||||||
|
ret = mmioDescend(hmmio, &ckList, &ckRiff, 0);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioDescend error %u\n", ret);
|
||||||
|
ok(ckList.ckid == FOURCC_LIST, "wrong ckid: %04x\n", ckList.ckid);
|
||||||
|
ok(ckList.fccType == listtypeAVIHEADER, "wrong fccType: %04x\n", ckList.fccType);
|
||||||
|
trace("ckid %4.4s cksize %04x fccType %4.4s off %04x flags %04x\n",
|
||||||
|
(LPCSTR)&ckList.ckid, ckList.cksize, (LPCSTR)&ckList.fccType,
|
||||||
|
ckList.dwDataOffset, ckList.dwFlags);
|
||||||
|
|
||||||
|
ret = mmioDescend(hmmio, &ck, &ckList, 0);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioDescend error %u\n", ret);
|
||||||
|
ok(ck.ckid == ckidAVIMAINHDR, "wrong ckid: %04x\n", ck.ckid);
|
||||||
|
ok(ck.fccType == 0, "wrong fccType: %04x\n", ck.fccType);
|
||||||
|
trace("ckid %4.4s cksize %04x fccType %4.4s off %04x flags %04x\n",
|
||||||
|
(LPCSTR)&ck.ckid, ck.cksize, (LPCSTR)&ck.fccType,
|
||||||
|
ck.dwDataOffset, ck.dwFlags);
|
||||||
|
|
||||||
|
/* Skip chunk data */
|
||||||
|
mmioSeek(hmmio, ck.cksize, SEEK_CUR);
|
||||||
|
|
||||||
|
ret = mmioDescend(hmmio, &ckList, &ckList, 0);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioDescend error %u\n", ret);
|
||||||
|
ok(ckList.ckid == FOURCC_LIST, "wrong ckid: %04x\n", ckList.ckid);
|
||||||
|
ok(ckList.fccType == listtypeSTREAMHEADER, "wrong fccType: %04x\n", ckList.fccType);
|
||||||
|
trace("ckid %4.4s cksize %04x fccType %4.4s off %04x flags %04x\n",
|
||||||
|
(LPCSTR)&ckList.ckid, ckList.cksize, (LPCSTR)&ckList.fccType,
|
||||||
|
ckList.dwDataOffset, ckList.dwFlags);
|
||||||
|
|
||||||
|
ret = mmioDescend(hmmio, &ck, &ckList, 0);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioDescend error %u\n", ret);
|
||||||
|
ok(ck.ckid == ckidSTREAMHEADER, "wrong ckid: %04x\n", ck.ckid);
|
||||||
|
ok(ck.fccType == 0, "wrong fccType: %04x\n", ck.fccType);
|
||||||
|
trace("ckid %4.4s cksize %04x fccType %4.4s off %04x flags %04x\n",
|
||||||
|
(LPCSTR)&ck.ckid, ck.cksize, (LPCSTR)&ck.fccType,
|
||||||
|
ck.dwDataOffset, ck.dwFlags);
|
||||||
|
|
||||||
|
/* test various mmioDescend flags */
|
||||||
|
|
||||||
|
mmioSeek(hmmio, 0, SEEK_SET);
|
||||||
|
memset(&ck, 0x66, sizeof(ck));
|
||||||
|
ret = mmioDescend(hmmio, &ck, NULL, MMIO_FINDRIFF);
|
||||||
|
ok(ret == MMIOERR_CHUNKNOTFOUND ||
|
||||||
|
ret == MMIOERR_INVALIDFILE, "mmioDescend returned %u\n", ret);
|
||||||
|
|
||||||
|
mmioSeek(hmmio, 0, SEEK_SET);
|
||||||
|
memset(&ck, 0x66, sizeof(ck));
|
||||||
|
ck.ckid = 0;
|
||||||
|
ret = mmioDescend(hmmio, &ck, NULL, MMIO_FINDRIFF);
|
||||||
|
ok(ret == MMIOERR_CHUNKNOTFOUND ||
|
||||||
|
ret == MMIOERR_INVALIDFILE, "mmioDescend returned %u\n", ret);
|
||||||
|
|
||||||
|
mmioSeek(hmmio, 0, SEEK_SET);
|
||||||
|
memset(&ck, 0x66, sizeof(ck));
|
||||||
|
ck.fccType = 0;
|
||||||
|
ret = mmioDescend(hmmio, &ck, NULL, MMIO_FINDRIFF);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioDescend error %u\n", ret);
|
||||||
|
ok(ck.ckid == FOURCC_RIFF, "wrong ckid: %04x\n", ck.ckid);
|
||||||
|
ok(ck.fccType == formtypeAVI, "wrong fccType: %04x\n", ck.fccType);
|
||||||
|
|
||||||
|
mmioSeek(hmmio, 0, SEEK_SET);
|
||||||
|
memset(&ck, 0x66, sizeof(ck));
|
||||||
|
ret = mmioDescend(hmmio, &ck, NULL, 0);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioDescend error %u\n", ret);
|
||||||
|
ok(ck.ckid == FOURCC_RIFF, "wrong ckid: %04x\n", ck.ckid);
|
||||||
|
ok(ck.fccType == formtypeAVI, "wrong fccType: %04x\n", ck.fccType);
|
||||||
|
|
||||||
|
/* do NOT seek, use current file position */
|
||||||
|
memset(&ck, 0x66, sizeof(ck));
|
||||||
|
ck.fccType = 0;
|
||||||
|
ret = mmioDescend(hmmio, &ck, NULL, MMIO_FINDLIST);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioDescend error %u\n", ret);
|
||||||
|
ok(ck.ckid == FOURCC_LIST, "wrong ckid: %04x\n", ck.ckid);
|
||||||
|
ok(ck.fccType == listtypeAVIHEADER, "wrong fccType: %04x\n", ck.fccType);
|
||||||
|
|
||||||
|
mmioSeek(hmmio, 0, SEEK_SET);
|
||||||
|
memset(&ck, 0x66, sizeof(ck));
|
||||||
|
ck.ckid = 0;
|
||||||
|
ck.fccType = listtypeAVIHEADER;
|
||||||
|
ret = mmioDescend(hmmio, &ck, NULL, MMIO_FINDCHUNK);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioDescend error %u\n", ret);
|
||||||
|
ok(ck.ckid == FOURCC_RIFF, "wrong ckid: %04x\n", ck.ckid);
|
||||||
|
ok(ck.fccType == formtypeAVI, "wrong fccType: %04x\n", ck.fccType);
|
||||||
|
|
||||||
|
/* do NOT seek, use current file position */
|
||||||
|
memset(&ck, 0x66, sizeof(ck));
|
||||||
|
ck.ckid = FOURCC_LIST;
|
||||||
|
ret = mmioDescend(hmmio, &ck, NULL, MMIO_FINDCHUNK);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioDescend error %u\n", ret);
|
||||||
|
ok(ck.ckid == FOURCC_LIST, "wrong ckid: %04x\n", ck.ckid);
|
||||||
|
ok(ck.fccType == listtypeAVIHEADER, "wrong fccType: %04x\n", ck.fccType);
|
||||||
|
|
||||||
|
mmioSeek(hmmio, 0, SEEK_SET);
|
||||||
|
memset(&ck, 0x66, sizeof(ck));
|
||||||
|
ck.ckid = FOURCC_RIFF;
|
||||||
|
ret = mmioDescend(hmmio, &ck, NULL, MMIO_FINDCHUNK);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioDescend error %u\n", ret);
|
||||||
|
ok(ck.ckid == FOURCC_RIFF, "wrong ckid: %04x\n", ck.ckid);
|
||||||
|
ok(ck.fccType == formtypeAVI, "wrong fccType: %04x\n", ck.fccType);
|
||||||
|
|
||||||
|
/* do NOT seek, use current file position */
|
||||||
|
memset(&ckList, 0x66, sizeof(ckList));
|
||||||
|
ckList.ckid = 0;
|
||||||
|
ret = mmioDescend(hmmio, &ckList, &ck, MMIO_FINDCHUNK);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioDescend error %u\n", ret);
|
||||||
|
ok(ckList.ckid == FOURCC_LIST, "wrong ckid: %04x\n", ckList.ckid);
|
||||||
|
ok(ckList.fccType == listtypeAVIHEADER, "wrong fccType: %04x\n", ckList.fccType);
|
||||||
|
|
||||||
|
mmioSeek(hmmio, 0, SEEK_SET);
|
||||||
|
memset(&ck, 0x66, sizeof(ck));
|
||||||
|
ret = mmioDescend(hmmio, &ck, NULL, MMIO_FINDCHUNK);
|
||||||
|
ok(ret == MMIOERR_CHUNKNOTFOUND ||
|
||||||
|
ret == MMIOERR_INVALIDFILE, "mmioDescend returned %u\n", ret);
|
||||||
|
ok(ck.ckid != 0x66666666, "wrong ckid: %04x\n", ck.ckid);
|
||||||
|
ok(ck.fccType != 0x66666666, "wrong fccType: %04x\n", ck.fccType);
|
||||||
|
ok(ck.dwDataOffset != 0x66666666, "wrong dwDataOffset: %04x\n", ck.dwDataOffset);
|
||||||
|
|
||||||
|
mmioSeek(hmmio, 0, SEEK_SET);
|
||||||
|
memset(&ck, 0x66, sizeof(ck));
|
||||||
|
ret = mmioDescend(hmmio, &ck, NULL, MMIO_FINDRIFF);
|
||||||
|
ok(ret == MMIOERR_CHUNKNOTFOUND ||
|
||||||
|
ret == MMIOERR_INVALIDFILE, "mmioDescend returned %u\n", ret);
|
||||||
|
|
||||||
|
mmioClose(hmmio, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void test_mmioOpen(char *fname)
|
||||||
|
{
|
||||||
|
char buf[256];
|
||||||
|
MMRESULT ret;
|
||||||
|
HMMIO hmmio;
|
||||||
|
MMIOINFO mmio;
|
||||||
|
|
||||||
|
memset(&mmio, 0, sizeof(mmio));
|
||||||
|
mmio.fccIOProc = fname ? FOURCC_DOS : FOURCC_MEM;
|
||||||
|
mmio.cchBuffer = sizeof(buf);
|
||||||
|
mmio.pchBuffer = buf;
|
||||||
|
hmmio = mmioOpen(fname, &mmio, MMIO_READ);
|
||||||
|
if (fname && !hmmio)
|
||||||
|
{
|
||||||
|
skip("%s file is missing, skipping the test\n", fname);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
ok(hmmio != 0, "mmioOpen error %u\n", mmio.wErrorRet);
|
||||||
|
|
||||||
|
memset(&mmio, 0, sizeof(mmio));
|
||||||
|
ret = mmioGetInfo(hmmio, &mmio, 0);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioGetInfo error %u\n", ret);
|
||||||
|
ok(mmio.dwFlags == MMIO_READ, "expected MMIO_READ, got %x\n", mmio.dwFlags);
|
||||||
|
ok(mmio.wErrorRet == MMSYSERR_NOERROR, "expected MMSYSERR_NOERROR, got %u\n", mmio.wErrorRet);
|
||||||
|
ok(mmio.fccIOProc == (fname ? FOURCC_DOS : FOURCC_MEM), "got %4.4s\n", (LPCSTR)&mmio.fccIOProc);
|
||||||
|
ok(mmio.cchBuffer == sizeof(buf), "got %u\n", mmio.cchBuffer);
|
||||||
|
ok(mmio.pchBuffer == buf, "expected %p, got %p\n", buf, mmio.pchBuffer);
|
||||||
|
|
||||||
|
mmioClose(hmmio, 0);
|
||||||
|
|
||||||
|
memset(&mmio, 0, sizeof(mmio));
|
||||||
|
mmio.fccIOProc = fname ? FOURCC_DOS : FOURCC_MEM;
|
||||||
|
mmio.cchBuffer = 0;
|
||||||
|
mmio.pchBuffer = buf;
|
||||||
|
hmmio = mmioOpen(fname, &mmio, MMIO_READ);
|
||||||
|
ok(hmmio != 0, "mmioOpen error %u\n", mmio.wErrorRet);
|
||||||
|
|
||||||
|
memset(&mmio, 0, sizeof(mmio));
|
||||||
|
ret = mmioGetInfo(hmmio, &mmio, 0);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioGetInfo error %u\n", ret);
|
||||||
|
ok(mmio.dwFlags == MMIO_READ, "expected MMIO_READ, got %x\n", mmio.dwFlags);
|
||||||
|
ok(mmio.wErrorRet == MMSYSERR_NOERROR, "expected MMSYSERR_NOERROR, got %u\n", mmio.wErrorRet);
|
||||||
|
ok(mmio.fccIOProc == (fname ? FOURCC_DOS : FOURCC_MEM), "got %4.4s\n", (LPCSTR)&mmio.fccIOProc);
|
||||||
|
ok(mmio.cchBuffer == 0, "expected 0, got %u\n", mmio.cchBuffer);
|
||||||
|
ok(mmio.pchBuffer == buf, "expected %p, got %p\n", buf, mmio.pchBuffer);
|
||||||
|
|
||||||
|
mmioClose(hmmio, 0);
|
||||||
|
|
||||||
|
memset(&mmio, 0, sizeof(mmio));
|
||||||
|
mmio.fccIOProc = fname ? FOURCC_DOS : FOURCC_MEM;
|
||||||
|
mmio.cchBuffer = 0;
|
||||||
|
mmio.pchBuffer = NULL;
|
||||||
|
hmmio = mmioOpen(fname, &mmio, MMIO_READ);
|
||||||
|
ok(hmmio != 0, "mmioOpen error %u\n", mmio.wErrorRet);
|
||||||
|
|
||||||
|
memset(&mmio, 0, sizeof(mmio));
|
||||||
|
ret = mmioGetInfo(hmmio, &mmio, 0);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioGetInfo error %u\n", ret);
|
||||||
|
ok(mmio.dwFlags == MMIO_READ, "expected MMIO_READ, got %x\n", mmio.dwFlags);
|
||||||
|
ok(mmio.wErrorRet == MMSYSERR_NOERROR, "expected MMSYSERR_NOERROR, got %u\n", mmio.wErrorRet);
|
||||||
|
ok(mmio.fccIOProc == (fname ? FOURCC_DOS : FOURCC_MEM), "got %4.4s\n", (LPCSTR)&mmio.fccIOProc);
|
||||||
|
ok(mmio.cchBuffer == 0, "expected 0, got %u\n", mmio.cchBuffer);
|
||||||
|
ok(mmio.pchBuffer == NULL, "expected NULL\n");
|
||||||
|
|
||||||
|
mmioClose(hmmio, 0);
|
||||||
|
|
||||||
|
memset(&mmio, 0, sizeof(mmio));
|
||||||
|
mmio.fccIOProc = fname ? FOURCC_DOS : FOURCC_MEM;
|
||||||
|
mmio.cchBuffer = 256;
|
||||||
|
mmio.pchBuffer = NULL;
|
||||||
|
hmmio = mmioOpen(fname, &mmio, MMIO_READ);
|
||||||
|
ok(hmmio != 0, "mmioOpen error %u\n", mmio.wErrorRet);
|
||||||
|
|
||||||
|
memset(&mmio, 0, sizeof(mmio));
|
||||||
|
ret = mmioGetInfo(hmmio, &mmio, 0);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioGetInfo error %u\n", ret);
|
||||||
|
ok(mmio.dwFlags == (MMIO_READ|MMIO_ALLOCBUF), "expected MMIO_READ|MMIO_ALLOCBUF, got %x\n", mmio.dwFlags);
|
||||||
|
ok(mmio.wErrorRet == MMSYSERR_NOERROR, "expected MMSYSERR_NOERROR, got %u\n", mmio.wErrorRet);
|
||||||
|
ok(mmio.fccIOProc == (fname ? FOURCC_DOS : FOURCC_MEM), "got %4.4s\n", (LPCSTR)&mmio.fccIOProc);
|
||||||
|
ok(mmio.cchBuffer == 256, "expected 256, got %u\n", mmio.cchBuffer);
|
||||||
|
ok(mmio.pchBuffer != NULL, "expected not NULL\n");
|
||||||
|
|
||||||
|
mmioClose(hmmio, 0);
|
||||||
|
|
||||||
|
memset(&mmio, 0, sizeof(mmio));
|
||||||
|
mmio.fccIOProc = fname ? FOURCC_DOS : FOURCC_MEM;
|
||||||
|
mmio.cchBuffer = sizeof(buf);
|
||||||
|
mmio.pchBuffer = buf;
|
||||||
|
hmmio = mmioOpen(fname, &mmio, MMIO_READ | MMIO_ALLOCBUF);
|
||||||
|
ok(hmmio != 0, "mmioOpen error %u\n", mmio.wErrorRet);
|
||||||
|
|
||||||
|
memset(&mmio, 0, sizeof(mmio));
|
||||||
|
ret = mmioGetInfo(hmmio, &mmio, 0);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioGetInfo error %u\n", ret);
|
||||||
|
ok(mmio.dwFlags == MMIO_READ, "expected MMIO_READ, got %x\n", mmio.dwFlags);
|
||||||
|
ok(mmio.wErrorRet == MMSYSERR_NOERROR, "expected MMSYSERR_NOERROR, got %u\n", mmio.wErrorRet);
|
||||||
|
ok(mmio.fccIOProc == (fname ? FOURCC_DOS : FOURCC_MEM), "got %4.4s\n", (LPCSTR)&mmio.fccIOProc);
|
||||||
|
ok(mmio.cchBuffer == sizeof(buf), "got %u\n", mmio.cchBuffer);
|
||||||
|
ok(mmio.pchBuffer == buf, "expected %p, got %p\n", buf, mmio.pchBuffer);
|
||||||
|
|
||||||
|
mmioClose(hmmio, 0);
|
||||||
|
|
||||||
|
memset(&mmio, 0, sizeof(mmio));
|
||||||
|
mmio.fccIOProc = fname ? FOURCC_DOS : FOURCC_MEM;
|
||||||
|
mmio.cchBuffer = 0;
|
||||||
|
mmio.pchBuffer = NULL;
|
||||||
|
hmmio = mmioOpen(fname, &mmio, MMIO_READ | MMIO_ALLOCBUF);
|
||||||
|
ok(hmmio != 0, "mmioOpen error %u\n", mmio.wErrorRet);
|
||||||
|
|
||||||
|
memset(&mmio, 0, sizeof(mmio));
|
||||||
|
ret = mmioGetInfo(hmmio, &mmio, 0);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioGetInfo error %u\n", ret);
|
||||||
|
ok(mmio.dwFlags == (MMIO_READ|MMIO_ALLOCBUF), "expected MMIO_READ|MMIO_ALLOCBUF, got %x\n", mmio.dwFlags);
|
||||||
|
ok(mmio.wErrorRet == MMSYSERR_NOERROR, "expected MMSYSERR_NOERROR, got %u\n", mmio.wErrorRet);
|
||||||
|
ok(mmio.fccIOProc == (fname ? FOURCC_DOS : FOURCC_MEM), "got %4.4s\n", (LPCSTR)&mmio.fccIOProc);
|
||||||
|
ok(mmio.cchBuffer == MMIO_DEFAULTBUFFER, "expected MMIO_DEFAULTBUFFER, got %u\n", mmio.cchBuffer);
|
||||||
|
ok(mmio.pchBuffer != NULL, "expected not NULL\n");
|
||||||
|
|
||||||
|
mmioClose(hmmio, 0);
|
||||||
|
|
||||||
|
memset(&mmio, 0, sizeof(mmio));
|
||||||
|
mmio.fccIOProc = fname ? FOURCC_DOS : FOURCC_MEM;
|
||||||
|
mmio.cchBuffer = 256;
|
||||||
|
mmio.pchBuffer = NULL;
|
||||||
|
hmmio = mmioOpen(fname, &mmio, MMIO_READ | MMIO_ALLOCBUF);
|
||||||
|
ok(hmmio != 0, "mmioOpen error %u\n", mmio.wErrorRet);
|
||||||
|
|
||||||
|
memset(&mmio, 0, sizeof(mmio));
|
||||||
|
ret = mmioGetInfo(hmmio, &mmio, 0);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioGetInfo error %u\n", ret);
|
||||||
|
ok(mmio.dwFlags == (MMIO_READ|MMIO_ALLOCBUF), "expected MMIO_READ|MMIO_ALLOCBUF, got %x\n", mmio.dwFlags);
|
||||||
|
ok(mmio.wErrorRet == MMSYSERR_NOERROR, "expected MMSYSERR_NOERROR, got %u\n", mmio.wErrorRet);
|
||||||
|
ok(mmio.fccIOProc == (fname ? FOURCC_DOS : FOURCC_MEM), "got %4.4s\n", (LPCSTR)&mmio.fccIOProc);
|
||||||
|
ok(mmio.cchBuffer == 256, "expected 256, got %u\n", mmio.cchBuffer);
|
||||||
|
ok(mmio.pchBuffer != NULL, "expected not NULL\n");
|
||||||
|
|
||||||
|
mmioClose(hmmio, 0);
|
||||||
|
|
||||||
|
memset(&mmio, 0, sizeof(mmio));
|
||||||
|
mmio.fccIOProc = fname ? FOURCC_DOS : FOURCC_MEM;
|
||||||
|
mmio.cchBuffer = 0;
|
||||||
|
mmio.pchBuffer = buf;
|
||||||
|
hmmio = mmioOpen(fname, &mmio, MMIO_READ | MMIO_ALLOCBUF);
|
||||||
|
if (!hmmio && mmio.wErrorRet == ERROR_BAD_FORMAT)
|
||||||
|
{
|
||||||
|
/* Seen on Win9x, WinMe but also XP-SP1 */
|
||||||
|
skip("Some Windows versions don't like a 0 size and a given buffer\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
ok(hmmio != 0, "mmioOpen error %u\n", mmio.wErrorRet);
|
||||||
|
|
||||||
|
memset(&mmio, 0, sizeof(mmio));
|
||||||
|
ret = mmioGetInfo(hmmio, &mmio, 0);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioGetInfo error %u\n", ret);
|
||||||
|
ok(mmio.dwFlags == MMIO_READ, "expected MMIO_READ, got %x\n", mmio.dwFlags);
|
||||||
|
ok(mmio.wErrorRet == MMSYSERR_NOERROR, "expected MMSYSERR_NOERROR, got %u\n", mmio.wErrorRet);
|
||||||
|
ok(mmio.fccIOProc == (fname ? FOURCC_DOS : FOURCC_MEM), "got %4.4s\n", (LPCSTR)&mmio.fccIOProc);
|
||||||
|
ok(mmio.cchBuffer == MMIO_DEFAULTBUFFER, "expected MMIO_DEFAULTBUFFER, got %u\n", mmio.cchBuffer);
|
||||||
|
ok(mmio.pchBuffer == buf, "expected %p, got %p\n", buf, mmio.pchBuffer);
|
||||||
|
|
||||||
|
mmioClose(hmmio, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void test_mmioSetBuffer(char *fname)
|
||||||
|
{
|
||||||
|
char buf[256];
|
||||||
|
MMRESULT ret;
|
||||||
|
HMMIO hmmio;
|
||||||
|
MMIOINFO mmio;
|
||||||
|
|
||||||
|
memset(&mmio, 0, sizeof(mmio));
|
||||||
|
mmio.fccIOProc = fname ? FOURCC_DOS : FOURCC_MEM;
|
||||||
|
mmio.cchBuffer = sizeof(buf);
|
||||||
|
mmio.pchBuffer = buf;
|
||||||
|
hmmio = mmioOpen(fname, &mmio, MMIO_READ);
|
||||||
|
if (fname && !hmmio)
|
||||||
|
{
|
||||||
|
skip("%s file is missing, skipping the test\n", fname);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
ok(hmmio != 0, "mmioOpen error %u\n", mmio.wErrorRet);
|
||||||
|
|
||||||
|
memset(&mmio, 0, sizeof(mmio));
|
||||||
|
ret = mmioGetInfo(hmmio, &mmio, 0);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioGetInfo error %u\n", ret);
|
||||||
|
ok(mmio.dwFlags == MMIO_READ, "expected MMIO_READ, got %x\n", mmio.dwFlags);
|
||||||
|
ok(mmio.wErrorRet == MMSYSERR_NOERROR, "expected MMSYSERR_NOERROR, got %u\n", mmio.wErrorRet);
|
||||||
|
ok(mmio.fccIOProc == (fname ? FOURCC_DOS : FOURCC_MEM), "got %4.4s\n", (LPCSTR)&mmio.fccIOProc);
|
||||||
|
ok(mmio.cchBuffer == sizeof(buf), "got %u\n", mmio.cchBuffer);
|
||||||
|
ok(mmio.pchBuffer == buf, "expected %p, got %p\n", buf, mmio.pchBuffer);
|
||||||
|
|
||||||
|
ret = mmioSetBuffer(hmmio, NULL, 0, 0);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioSetBuffer error %u\n", ret);
|
||||||
|
|
||||||
|
memset(&mmio, 0, sizeof(mmio));
|
||||||
|
ret = mmioGetInfo(hmmio, &mmio, 0);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioGetInfo error %u\n", ret);
|
||||||
|
ok(mmio.dwFlags == MMIO_READ, "expected MMIO_READ, got %x\n", mmio.dwFlags);
|
||||||
|
ok(mmio.wErrorRet == MMSYSERR_NOERROR, "expected MMSYSERR_NOERROR, got %u\n", mmio.wErrorRet);
|
||||||
|
ok(mmio.fccIOProc == (fname ? FOURCC_DOS : FOURCC_MEM), "got %4.4s\n", (LPCSTR)&mmio.fccIOProc);
|
||||||
|
ok(mmio.cchBuffer == 0, "got not 0\n");
|
||||||
|
ok(mmio.pchBuffer == NULL, "got not NULL buf\n");
|
||||||
|
|
||||||
|
ret = mmioSetBuffer(hmmio, NULL, 0, MMIO_ALLOCBUF);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioSetBuffer error %u\n", ret);
|
||||||
|
|
||||||
|
memset(&mmio, 0, sizeof(mmio));
|
||||||
|
ret = mmioGetInfo(hmmio, &mmio, 0);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioGetInfo error %u\n", ret);
|
||||||
|
ok(mmio.dwFlags == MMIO_READ, "expected MMIO_READ, got %x\n", mmio.dwFlags);
|
||||||
|
ok(mmio.wErrorRet == MMSYSERR_NOERROR, "expected MMSYSERR_NOERROR, got %u\n", mmio.wErrorRet);
|
||||||
|
ok(mmio.fccIOProc == (fname ? FOURCC_DOS : FOURCC_MEM), "got %4.4s\n", (LPCSTR)&mmio.fccIOProc);
|
||||||
|
ok(mmio.cchBuffer == 0, "got not 0\n");
|
||||||
|
ok(mmio.pchBuffer == NULL, "got not NULL buf\n");
|
||||||
|
|
||||||
|
ret = mmioSetBuffer(hmmio, buf, 0, MMIO_ALLOCBUF);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioSetBuffer error %u\n", ret);
|
||||||
|
|
||||||
|
memset(&mmio, 0, sizeof(mmio));
|
||||||
|
ret = mmioGetInfo(hmmio, &mmio, 0);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioGetInfo error %u\n", ret);
|
||||||
|
ok(mmio.dwFlags == MMIO_READ, "expected MMIO_READ, got %x\n", mmio.dwFlags);
|
||||||
|
ok(mmio.wErrorRet == MMSYSERR_NOERROR, "expected MMSYSERR_NOERROR, got %u\n", mmio.wErrorRet);
|
||||||
|
ok(mmio.fccIOProc == (fname ? FOURCC_DOS : FOURCC_MEM), "got %4.4s\n", (LPCSTR)&mmio.fccIOProc);
|
||||||
|
ok(mmio.cchBuffer == 0, "got not 0\n");
|
||||||
|
ok(mmio.pchBuffer == buf, "expected %p, got %p\n", buf, mmio.pchBuffer);
|
||||||
|
|
||||||
|
ret = mmioSetBuffer(hmmio, NULL, 256, MMIO_WRITE|MMIO_ALLOCBUF);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioSetBuffer error %u\n", ret);
|
||||||
|
|
||||||
|
memset(&mmio, 0, sizeof(mmio));
|
||||||
|
ret = mmioGetInfo(hmmio, &mmio, 0);
|
||||||
|
ok(ret == MMSYSERR_NOERROR, "mmioGetInfo error %u\n", ret);
|
||||||
|
ok(mmio.dwFlags == (MMIO_READ|MMIO_ALLOCBUF), "expected MMIO_READ|MMIO_ALLOCBUF, got %x\n", mmio.dwFlags);
|
||||||
|
ok(mmio.wErrorRet == MMSYSERR_NOERROR, "expected MMSYSERR_NOERROR, got %u\n", mmio.wErrorRet);
|
||||||
|
ok(mmio.fccIOProc == (fname ? FOURCC_DOS : FOURCC_MEM), "got %4.4s\n", (LPCSTR)&mmio.fccIOProc);
|
||||||
|
ok(mmio.cchBuffer == 256, "got %u\n", mmio.cchBuffer);
|
||||||
|
ok(mmio.pchBuffer != NULL, "expected not NULL\n");
|
||||||
|
ok(mmio.pchBuffer != buf, "expected != buf\n");
|
||||||
|
|
||||||
|
mmioClose(hmmio, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
START_TEST(mmio)
|
||||||
|
{
|
||||||
|
char fname[] = "msrle.avi";
|
||||||
|
|
||||||
|
test_mmioDescend(NULL);
|
||||||
|
test_mmioDescend(fname);
|
||||||
|
test_mmioOpen(NULL);
|
||||||
|
test_mmioOpen(fname);
|
||||||
|
test_mmioSetBuffer(NULL);
|
||||||
|
test_mmioSetBuffer(fname);
|
||||||
|
}
|
25
rostests/winetests/winmm/testlist.c
Normal file
25
rostests/winetests/winmm/testlist.c
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
/* Automatically generated file; DO NOT EDIT!! */
|
||||||
|
|
||||||
|
#define WIN32_LEAN_AND_MEAN
|
||||||
|
#include <windows.h>
|
||||||
|
|
||||||
|
#define STANDALONE
|
||||||
|
#include "wine/test.h"
|
||||||
|
|
||||||
|
extern void func_capture(void);
|
||||||
|
extern void func_mci(void);
|
||||||
|
extern void func_mixer(void);
|
||||||
|
extern void func_mmio(void);
|
||||||
|
extern void func_timer(void);
|
||||||
|
extern void func_wave(void);
|
||||||
|
|
||||||
|
const struct test winetest_testlist[] =
|
||||||
|
{
|
||||||
|
{ "capture", func_capture },
|
||||||
|
{ "mci", func_mci },
|
||||||
|
{ "mixer", func_mixer },
|
||||||
|
{ "mmio", func_mmio },
|
||||||
|
{ "timer", func_timer },
|
||||||
|
{ "wave", func_wave },
|
||||||
|
{ 0, 0 }
|
||||||
|
};
|
218
rostests/winetests/winmm/timer.c
Normal file
218
rostests/winetests/winmm/timer.c
Normal file
|
@ -0,0 +1,218 @@
|
||||||
|
/*
|
||||||
|
* Test winmm timer
|
||||||
|
*
|
||||||
|
* Copyright (c) 2005 Robert Reif
|
||||||
|
*
|
||||||
|
* 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 <stdarg.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <math.h>
|
||||||
|
|
||||||
|
#include "wine/test.h"
|
||||||
|
#include "windef.h"
|
||||||
|
#include "winbase.h"
|
||||||
|
#include "winnls.h"
|
||||||
|
#include "mmsystem.h"
|
||||||
|
#define NOBITMAP
|
||||||
|
#include "mmreg.h"
|
||||||
|
|
||||||
|
#include "winmm_test.h"
|
||||||
|
|
||||||
|
static TIMECAPS tc;
|
||||||
|
|
||||||
|
static void test_timeGetDevCaps(void)
|
||||||
|
{
|
||||||
|
MMRESULT rc;
|
||||||
|
|
||||||
|
rc = timeGetDevCaps(&tc, 0);
|
||||||
|
ok(rc == TIMERR_NOCANDO || rc == MMSYSERR_INVALPARAM,
|
||||||
|
"timeGetDevCaps() returned %s, should have returned TIMERR_NOCANDO "
|
||||||
|
"or MMSYSERR_INVALPARAM\n", mmsys_error(rc));
|
||||||
|
|
||||||
|
rc = timeGetDevCaps(0, sizeof(tc));
|
||||||
|
ok(rc == TIMERR_NOCANDO || rc == TIMERR_STRUCT,
|
||||||
|
"timeGetDevCaps() returned %s, should have returned TIMERR_NOCANDO "
|
||||||
|
"or TIMERR_STRUCT\n", mmsys_error(rc));
|
||||||
|
|
||||||
|
rc = timeGetDevCaps(0, 0);
|
||||||
|
ok(rc == TIMERR_NOCANDO || rc == MMSYSERR_INVALPARAM,
|
||||||
|
"timeGetDevCaps() returned %s, should have returned TIMERR_NOCANDO "
|
||||||
|
"or MMSYSERR_INVALPARAM\n", mmsys_error(rc));
|
||||||
|
|
||||||
|
rc = timeGetDevCaps(&tc, sizeof(tc));
|
||||||
|
ok(rc == TIMERR_NOERROR, "timeGetDevCaps() returned %s, "
|
||||||
|
"should have returned TIMERR_NOERROR\n", mmsys_error(rc));
|
||||||
|
|
||||||
|
if (rc == TIMERR_NOERROR)
|
||||||
|
trace("wPeriodMin = %u, wPeriodMax = %u\n",
|
||||||
|
tc.wPeriodMin, tc.wPeriodMax);
|
||||||
|
}
|
||||||
|
|
||||||
|
#define NUM_SAMPLES 100
|
||||||
|
|
||||||
|
static DWORD count = 0;
|
||||||
|
static DWORD times[NUM_SAMPLES];
|
||||||
|
|
||||||
|
static void CALLBACK testTimeProc(UINT uID, UINT uMsg, DWORD_PTR dwUser,
|
||||||
|
DWORD_PTR dw1, DWORD_PTR dw2)
|
||||||
|
{
|
||||||
|
if (count < NUM_SAMPLES)
|
||||||
|
times[count++] = timeGetTime();
|
||||||
|
}
|
||||||
|
|
||||||
|
static void test_timer(UINT period, UINT resolution)
|
||||||
|
{
|
||||||
|
MMRESULT rc;
|
||||||
|
UINT i, id, delta;
|
||||||
|
DWORD dwMin = 0xffffffff, dwMax = 0;
|
||||||
|
double sum = 0.0;
|
||||||
|
double deviation = 0.0;
|
||||||
|
|
||||||
|
count = 0;
|
||||||
|
|
||||||
|
for (i = 0; i < NUM_SAMPLES; i++)
|
||||||
|
times[i] = 0;
|
||||||
|
|
||||||
|
rc = timeBeginPeriod(period);
|
||||||
|
ok(rc == TIMERR_NOERROR, "timeBeginPeriod(%u) returned %s, "
|
||||||
|
"should have returned TIMERR_NOERROR\n", period, mmsys_error(rc));
|
||||||
|
if (rc != TIMERR_NOERROR)
|
||||||
|
return;
|
||||||
|
|
||||||
|
id = timeSetEvent(period, resolution, testTimeProc, 0, TIME_PERIODIC);
|
||||||
|
ok(id != 0, "timeSetEvent(%u, %u, %p, 0, TIME_PERIODIC) returned %d, "
|
||||||
|
"should have returned id > 0\n", period, resolution, testTimeProc, id);
|
||||||
|
if (id == 0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
Sleep((NUM_SAMPLES * period) + (2 * period));
|
||||||
|
|
||||||
|
rc = timeEndPeriod(period);
|
||||||
|
ok(rc == TIMERR_NOERROR, "timeEndPeriod(%u) returned %s, "
|
||||||
|
"should have returned TIMERR_NOERROR\n", period, mmsys_error(rc));
|
||||||
|
if (rc != TIMERR_NOERROR)
|
||||||
|
return;
|
||||||
|
|
||||||
|
rc = timeKillEvent(id);
|
||||||
|
ok(rc == TIMERR_NOERROR, "timeKillEvent(%u) returned %s, "
|
||||||
|
"should have returned TIMERR_NOERROR\n", id, mmsys_error(rc));
|
||||||
|
|
||||||
|
trace("period = %u, resolution = %u\n", period, resolution);
|
||||||
|
|
||||||
|
for (i = 0; i < count; i++)
|
||||||
|
{
|
||||||
|
if (i == 0)
|
||||||
|
{
|
||||||
|
if (winetest_debug > 1)
|
||||||
|
trace("time[%d] = %u\n", i, times[i]);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
delta = times[i] - times[i - 1];
|
||||||
|
|
||||||
|
if (winetest_debug > 1)
|
||||||
|
trace("time[%d] = %u delta = %d\n", i, times[i], delta);
|
||||||
|
|
||||||
|
sum += delta;
|
||||||
|
deviation += ((delta - period) * (delta - period));
|
||||||
|
|
||||||
|
if (delta < dwMin)
|
||||||
|
dwMin = delta;
|
||||||
|
|
||||||
|
if (delta > dwMax)
|
||||||
|
dwMax = delta;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
trace("min = %u, max = %u, average = %f, standard deviation = %f\n",
|
||||||
|
dwMin, dwMax, sum / (count - 1), sqrt(deviation / (count - 2)));
|
||||||
|
}
|
||||||
|
|
||||||
|
static const char * get_priority(int priority)
|
||||||
|
{
|
||||||
|
static char tmp[32];
|
||||||
|
#define STR(x) case x: return #x
|
||||||
|
switch(priority) {
|
||||||
|
STR(THREAD_PRIORITY_LOWEST);
|
||||||
|
STR(THREAD_PRIORITY_BELOW_NORMAL);
|
||||||
|
STR(THREAD_PRIORITY_NORMAL);
|
||||||
|
STR(THREAD_PRIORITY_HIGHEST);
|
||||||
|
STR(THREAD_PRIORITY_ABOVE_NORMAL);
|
||||||
|
STR(THREAD_PRIORITY_TIME_CRITICAL);
|
||||||
|
STR(THREAD_PRIORITY_IDLE);
|
||||||
|
}
|
||||||
|
sprintf(tmp, "UNKNOWN(%d)", priority);
|
||||||
|
return tmp;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int priority = 0;
|
||||||
|
static BOOL fired = FALSE;
|
||||||
|
|
||||||
|
static void CALLBACK priorityTimeProc(UINT uID, UINT uMsg, DWORD_PTR dwUser,
|
||||||
|
DWORD_PTR dw1, DWORD_PTR dw2)
|
||||||
|
{
|
||||||
|
priority = GetThreadPriority(GetCurrentThread());
|
||||||
|
ok(priority!=THREAD_PRIORITY_ERROR_RETURN, "GetThreadPriority() failed, GetLastError() = %u\n", GetLastError());
|
||||||
|
fired = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void test_priority(void)
|
||||||
|
{
|
||||||
|
UINT id;
|
||||||
|
|
||||||
|
id = timeSetEvent(100, 100, priorityTimeProc, 0, TIME_ONESHOT);
|
||||||
|
ok(id != 0, "timeSetEvent(100, 100, %p, 0, TIME_ONESHOT) returned %d, "
|
||||||
|
"should have returned id > 0\n", priorityTimeProc, id);
|
||||||
|
if (id == 0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
Sleep(200);
|
||||||
|
|
||||||
|
ok(fired == TRUE, "Callback not called\n");
|
||||||
|
if (fired)
|
||||||
|
{
|
||||||
|
ok(priority == THREAD_PRIORITY_TIME_CRITICAL,
|
||||||
|
"thread priority is %s, should be THREAD_PRIORITY_TIME_CRITICAL\n",
|
||||||
|
get_priority(priority));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
START_TEST(timer)
|
||||||
|
{
|
||||||
|
test_timeGetDevCaps();
|
||||||
|
|
||||||
|
if (tc.wPeriodMin <= 1) {
|
||||||
|
test_timer(1, 0);
|
||||||
|
test_timer(1, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (tc.wPeriodMin <= 10) {
|
||||||
|
test_timer(10, 0);
|
||||||
|
test_timer(10, 1);
|
||||||
|
test_timer(10, 10);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (tc.wPeriodMin <= 20) {
|
||||||
|
test_timer(20, 0);
|
||||||
|
test_timer(20, 1);
|
||||||
|
test_timer(20, 10);
|
||||||
|
test_timer(20, 20);
|
||||||
|
}
|
||||||
|
|
||||||
|
test_priority();
|
||||||
|
}
|
1465
rostests/winetests/winmm/wave.c
Normal file
1465
rostests/winetests/winmm/wave.c
Normal file
File diff suppressed because it is too large
Load diff
16
rostests/winetests/winmm/winmm.rbuild
Normal file
16
rostests/winetests/winmm/winmm.rbuild
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
<?xml version="1.0"?>
|
||||||
|
<module name="winmm_winetest" type="win32cui" installbase="bin" installname="winmm_winetest.exe" allowwarnings="true">
|
||||||
|
<include base="winmm_winetest">.</include>
|
||||||
|
<define name="__ROS_LONG64__" />
|
||||||
|
<library>dxguid</library>
|
||||||
|
<library>winmm</library>
|
||||||
|
<library>user32</library>
|
||||||
|
<library>kernel32</library>
|
||||||
|
<file>capture.c</file>
|
||||||
|
<file>mci.c</file>
|
||||||
|
<file>mixer.c</file>
|
||||||
|
<file>mmio.c</file>
|
||||||
|
<file>timer.c</file>
|
||||||
|
<file>wave.c</file>
|
||||||
|
<file>testlist.c</file>
|
||||||
|
</module>
|
81
rostests/winetests/winmm/winmm_test.h
Normal file
81
rostests/winetests/winmm/winmm_test.h
Normal file
|
@ -0,0 +1,81 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2002 Francois Gouget
|
||||||
|
*
|
||||||
|
* 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
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef WAVE_FORMAT_48M08
|
||||||
|
#define WAVE_FORMAT_48M08 0x00001000 /* 48 kHz, Mono, 8-bit */
|
||||||
|
#define WAVE_FORMAT_48S08 0x00002000 /* 48 kHz, Stereo, 8-bit */
|
||||||
|
#define WAVE_FORMAT_48M16 0x00004000 /* 48 kHz, Mono, 16-bit */
|
||||||
|
#define WAVE_FORMAT_48S16 0x00008000 /* 48 kHz, Stereo, 16-bit */
|
||||||
|
#define WAVE_FORMAT_96M08 0x00010000 /* 96 kHz, Mono, 8-bit */
|
||||||
|
#define WAVE_FORMAT_96S08 0x00020000 /* 96 kHz, Stereo, 8-bit */
|
||||||
|
#define WAVE_FORMAT_96M16 0x00040000 /* 96 kHz, Mono, 16-bit */
|
||||||
|
#define WAVE_FORMAT_96S16 0x00080000 /* 96 kHz, Stereo, 16-bit */
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef DRV_QUERYDEVICEINTERFACE
|
||||||
|
#define DRV_QUERYDEVICEINTERFACE (DRV_RESERVED + 12)
|
||||||
|
#endif
|
||||||
|
#ifndef DRV_QUERYDEVICEINTERFACESIZE
|
||||||
|
#define DRV_QUERYDEVICEINTERFACESIZE (DRV_RESERVED + 13)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static const unsigned int win_formats[][4] = {
|
||||||
|
{0, 8000, 8, 1},
|
||||||
|
{0, 8000, 8, 2},
|
||||||
|
{0, 8000, 16, 1},
|
||||||
|
{0, 8000, 16, 2},
|
||||||
|
{WAVE_FORMAT_1M08, 11025, 8, 1},
|
||||||
|
{WAVE_FORMAT_1S08, 11025, 8, 2},
|
||||||
|
{WAVE_FORMAT_1M16, 11025, 16, 1},
|
||||||
|
{WAVE_FORMAT_1S16, 11025, 16, 2},
|
||||||
|
{0, 12000, 8, 1},
|
||||||
|
{0, 12000, 8, 2},
|
||||||
|
{0, 12000, 16, 1},
|
||||||
|
{0, 12000, 16, 2},
|
||||||
|
{0, 16000, 8, 1},
|
||||||
|
{0, 16000, 8, 2},
|
||||||
|
{0, 16000, 16, 1},
|
||||||
|
{0, 16000, 16, 2},
|
||||||
|
{WAVE_FORMAT_2M08, 22050, 8, 1},
|
||||||
|
{WAVE_FORMAT_2S08, 22050, 8, 2},
|
||||||
|
{WAVE_FORMAT_2M16, 22050, 16, 1},
|
||||||
|
{WAVE_FORMAT_2S16, 22050, 16, 2},
|
||||||
|
{WAVE_FORMAT_4M08, 44100, 8, 1},
|
||||||
|
{WAVE_FORMAT_4S08, 44100, 8, 2},
|
||||||
|
{WAVE_FORMAT_4M16, 44100, 16, 1},
|
||||||
|
{WAVE_FORMAT_4S16, 44100, 16, 2},
|
||||||
|
{WAVE_FORMAT_48M08, 48000, 8, 1},
|
||||||
|
{WAVE_FORMAT_48S08, 48000, 8, 2},
|
||||||
|
{WAVE_FORMAT_48M16, 48000, 16, 1},
|
||||||
|
{WAVE_FORMAT_48S16, 48000, 16, 2},
|
||||||
|
{WAVE_FORMAT_96M08, 96000, 8, 1},
|
||||||
|
{WAVE_FORMAT_96S08, 96000, 8, 2},
|
||||||
|
{WAVE_FORMAT_96M16, 96000, 16, 1},
|
||||||
|
{WAVE_FORMAT_96S16, 96000, 16, 2}
|
||||||
|
};
|
||||||
|
#define NB_WIN_FORMATS (sizeof(win_formats)/sizeof(*win_formats))
|
||||||
|
|
||||||
|
extern const char* dev_name(int);
|
||||||
|
extern const char* wave_open_flags(DWORD);
|
||||||
|
extern const char* mmsys_error(MMRESULT);
|
||||||
|
extern const char* wave_out_error(MMRESULT);
|
||||||
|
extern const char* get_format_str(WORD format);
|
||||||
|
extern const char* wave_time_format(UINT type);
|
||||||
|
extern DWORD bytes_to_samples(DWORD bytes, LPWAVEFORMATEX pwfx);
|
||||||
|
extern DWORD bytes_to_ms(DWORD bytes, LPWAVEFORMATEX pwfx);
|
||||||
|
extern DWORD time_to_bytes(LPMMTIME mmtime, LPWAVEFORMATEX pwfx);
|
Loading…
Reference in a new issue