diff options
author | Wohlstand <admin@wohlnet.ru> | 2020-09-28 19:35:24 +0300 |
---|---|---|
committer | Wohlstand <admin@wohlnet.ru> | 2020-09-28 19:35:24 +0300 |
commit | 455ac435481558c09ee1824b1e6dcc43f277527d (patch) | |
tree | 641268a2117543cd1a66ec9c4b3e3d790170f22e /utils/winmm_drv/test/test.c | |
parent | 595a9dc35ad1c41dac96d7fd7e3b3c7ccaac9947 (diff) | |
parent | baefee8dbe094a05ae89b0f9b909d19982711dc7 (diff) | |
download | libADLMIDI-455ac435481558c09ee1824b1e6dcc43f277527d.tar.gz libADLMIDI-455ac435481558c09ee1824b1e6dcc43f277527d.tar.bz2 libADLMIDI-455ac435481558c09ee1824b1e6dcc43f277527d.zip |
Merge branch 'master' of github.com:Wohlstand/libADLMIDI
Diffstat (limited to 'utils/winmm_drv/test/test.c')
-rw-r--r-- | utils/winmm_drv/test/test.c | 105 |
1 files changed, 105 insertions, 0 deletions
diff --git a/utils/winmm_drv/test/test.c b/utils/winmm_drv/test/test.c new file mode 100644 index 0000000..f6fd2e9 --- /dev/null +++ b/utils/winmm_drv/test/test.c @@ -0,0 +1,105 @@ +#include <windows.h> +#include <stdio.h> +#include <mmsystem.h> + +typedef DWORD (WINAPI * MessagePtr)(UINT, UINT, DWORD, DWORD, DWORD); + +#ifndef MODM_GETDEVCAPS +#define MODM_GETDEVCAPS 2 +#endif + +LONG testDriver() +{ + HDRVR hdrvr; + DRVCONFIGINFO dci; + LONG lRes; + HMODULE lib; + DWORD modRet; + MIDIOUTCAPSA myCapsA; + MessagePtr modMessagePtr; + + printf("Open...\n"); + // Open the driver (no additional parameters needed this time). + if((hdrvr = OpenDriver(L"adlmididrv.dll", 0, 0)) == 0) + { + printf("!!! Can't open the driver\n"); + return -1; + } + + printf("Send DRV_QUERYCONFIGURE...\n"); + // Make sure driver has a configuration dialog box. + if(SendDriverMessage(hdrvr, DRV_QUERYCONFIGURE, 0, 0) != 0) + { + // Set the DRVCONFIGINFO structure and send the message + dci.dwDCISize = sizeof (dci); + dci.lpszDCISectionName = (LPWSTR)0; + dci.lpszDCIAliasName = (LPWSTR)0; + printf("Send DRV_CONFIGURE...\n"); + lRes = SendDriverMessage(hdrvr, DRV_CONFIGURE, 0, (LPARAM)&dci); + printf("<-- Got answer: %ld)\n", lRes); + } + else + { + printf("<-- No configure\n"); + lRes = DRVCNF_OK; + } + + + printf("Getting library pointer\n"); + if((lib = GetDriverModuleHandle(hdrvr))) + { + printf("Getting modMessage call\n"); + modMessagePtr = (MessagePtr)GetProcAddress(lib, "modMessage"); + if(!modMessagePtr) + { + CloseDriver(hdrvr, 0, 0); + printf("!!! modMessage not found!\n"); + return -1; + } + + printf("Getting capabilities...\n"); + modRet = modMessagePtr(0, MODM_GETDEVCAPS, (DWORD_PTR)NULL, (DWORD_PTR)&myCapsA, sizeof(myCapsA)); + if(modRet != MMSYSERR_NOERROR) + { + CloseDriver(hdrvr, 0, 0); + printf("!!! modMessage returned an error!\n"); + return -1; + } + + printf("<-- %s\n", myCapsA.szPname); + } + else + { + CloseDriver(hdrvr, 0, 0); + printf("!!! Error when getting module handler!\n"); + return -1; + } + + printf("Close...\n"); + // Close the driver (no additional parameters needed this time). + if(FAILED(CloseDriver(hdrvr, 0, 0))) + { + printf("!!! Error when closing\n"); + return -1; + } + + printf("Return...\n"); + + return 0; +} + +int main() +{ + LONG d = testDriver(); + + if(d == 0) + { + printf("TEST = OK\n"); + return 0; + } + else + { + printf("TEST = FAILED\n"); + return 1; + } +} |