aboutsummaryrefslogtreecommitdiff
path: root/utils/winmm_drv/test/test.c
diff options
context:
space:
mode:
authorWohlstand <admin@wohlnet.ru>2020-09-28 19:35:24 +0300
committerWohlstand <admin@wohlnet.ru>2020-09-28 19:35:24 +0300
commit455ac435481558c09ee1824b1e6dcc43f277527d (patch)
tree641268a2117543cd1a66ec9c4b3e3d790170f22e /utils/winmm_drv/test/test.c
parent595a9dc35ad1c41dac96d7fd7e3b3c7ccaac9947 (diff)
parentbaefee8dbe094a05ae89b0f9b909d19982711dc7 (diff)
downloadlibADLMIDI-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.c105
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;
+ }
+}