From 65324dec076d1f4947fbd0a61d1d3e48b67260c5 Mon Sep 17 00:00:00 2001 From: Mike Kuznetsov Date: Mon, 23 Mar 2020 14:01:22 -0500 Subject: [PATCH 1/2] Removed Kernel32 library use. "As Tested" on-site and "approved" version. --- bin/purejavahidapi-src.jar | Bin 73551 -> 73505 bytes bin/purejavahidapi.jar | Bin 131902 -> 131803 bytes src/purejavahidapi/windows/HidDevice.java | 70 ++++++++++++---------- 3 files changed, 39 insertions(+), 31 deletions(-) diff --git a/bin/purejavahidapi-src.jar b/bin/purejavahidapi-src.jar index 6be2c2fe8658db39151684c5a50f519007d405f4..597d3e01072baf874aaaab745c047722dd4d31f7 100644 GIT binary patch delta 3734 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 diff --git a/bin/purejavahidapi.jar b/bin/purejavahidapi.jar index 8cc869e3f95c6946517f8979f9578b17053d6163..c93572b433a84dc718713df37cc4db687776c70a 100644 GIT binary patch delta 4689 zcmY+Hc|26#`@mgOF_b0B5;Gx#kv;pasO(}w)~t!_I~io(v&^-xp|WJ(N+P?+5|SaZ zXV2KT-!%EXKCkcn)_h69aZVWj z4G^yu2T~B{{<_)`1keXi|NXVE9rq%mAR_976A>Z60egTE^cMx7XkK%>$1X0_`cOlI z-RGw#{hK#7NtNg&m9GcTOI{D!d?^NPwXbKI?UVyT&9HGK-u`w=_meU|sk{7Kt+DDU z#nd>(=8s)ncf12cHP&tvq# z@BGo9M2;lVg;PRgGU%cy7c#$A5(wY^hL-PS=)z_N9s8aZ-{n04E73C4(oqloU6)_5vx#gBQ8$rsU2~&8;cw?D`S(!6Opl4a!E}NjTS@Ips-fsEDtT)rpSP ziK_c?J=H$>dGu1VsPE#Z(eoQ7T{uz8855OF(FeXN5lu^S3dOd|cp7ukldv6t^j6F5dn6DP}0K z16zD<&}MvIV*2c#I0F_%mRQP!*=>1_EV%lEd=#S1jVy_~N->8lkWu8K^aR7GAcOSn z4Me*{Rk(HoH9MB^zU9!t{bx#PF^bhX#g-ygcM>X7FwSo|ny~Q>mku$xxTE z(yNU|FYOh~Em%{YbXi1W5<*7eBW&j_1T&}v4|kz2Cvy(44-nHpIcBs?5VQT{s4qv7)qScTlNGV}pZ|Mn|=d@&ft(!P+t`tZH}H!-M*f2+?Sc zCGH^Uk}7&XWH?c>FWK8lj9Ex+;(B6~;9z&F-giA0lKH-V*GHrD0kW(scHy?|Ix6;2 zOBh7^g|GB9FA6XsP&d#;TBsy{`$^=@C5`rr2_A;l>&bnoH%VoT<^Z9TZuspEo>FG@ z0uEf?tH%Win@rB+X4C9HhHO@&ve!-PCzyrI=2_4R8lUIrz0C%ApCd$aLZiDZ#u3}O zn=*lwLJY%DOW*o%?Yq_A;zW2KRiJW^!8O!|G@BM7bYhGaZeB{F)R24p=JuT$8YL-ycXC#Jr(H+rO-peMfwstuFA?^K+Do%RnO(GDk*LC) zWMy>l`4qPJbXFZ<+D?al)s85xWlVmfw-V0TP^0qFYF&kyTj5aGt!Yg3aBP_^v-;1X z!b{R0(Iz)UGDlkJM-0SXr;X|OAg%axHmN^k4{psYOg+WV26cAWNzJ}S`!obCf(_5AXHI;-f(YBWk?%fyKkr9AGB$E#`DZNkA9Y@qn=sbB}+MefGzkXAXPfJnkz}NNRhPGDukS1 zKlrA+lKA@}&A4=Z`yr=mtuo0{T!gjdvd`<=`RW$?yxjdQn{_hzZDS_M-n&asY0LKb zm8tH$tC^43Y(@~;4J;A958H+m3L_g(66l*^Yt8x}zcHGvF1@i+5dA{z{r=06Ucm?= zwX2{Nut@fPHmL9@t;SG6DIZ2wl^Q}E29g|w3Kw<6U#!j3;-Vk`!~ zB-`+~>4+9445-$pg-GN4l9U$f6!MT6rr&TtgGs)?hp8MAoxvyA+cZeU`?@yq-_dsp zxC#dE+hpX{DMQ6SXJ?1TBW1!h-X!Ky{_z7a1yKqG%KE8~VQw{<^n)~SXlBBP-uDiz z^w;PYhp`(-R3s!w6om$HXJo|6$~uW%9d&uZI-}2}?z0$0B-0Ag!O(DH(=GkSPXRhx z(Lwmmn`Onz!LV6c^8_ey&Ve#@IJ(S5nJ7{oon(Cd6Yu z+uJig7C%X_{7!w5+Vhe$G$QEbjBe7+V4ro{*r50A&TQsb@sY-M;z+}2h%;ixly}m( z-&KUEJP?;H?Ed^!-OxPbxMi)}$F*|8qHacC+qtbgMD6w@(-8UXdj@O^{B!7Z-BQe! znr@$}*qw!!JC#t|r6}0yplUSLgw%Ii6t%qJ53YSxQv@D`L!-{;+(NLd847s|s zwr_FjysE9zSMqPd+yc>A#+UByJvX&UbdX!13yL13!IXqt)m?myaJ@M=>ho3aw4dnl zZjwJ~L{4+*!QA$<5s1Xyw;UpE52x4C(q~;}%WZ_6^NhLMmCM*IN?&rhciNE0hP(^V zN4`%A!w9U7hQ46vC}8edKm*4&of76sZNo+2(h9N8cE;_7l5dI85t>I zH(GXr+?53zp}kD=>{zor{x4Bd$t{Z8^%b4`wNA+ijCO|J^xmKz+RKrv z;_b85tzyoSidW^o(QHZ+2XKcU#SUCIlbrMM=d&ewvD)pnG;de^lW6}_e4&EEmIfg^c*Q#;nj>B{v%7#4 z&OIB~$hBM0Gv}UifbC{|)9!sOwC`1fB_hwZq|k{cT%897M_U9`ap7)S-%V?2AN!Lu znnMAlC+gN@g$LB3Sbqi-dta!0_?*$Y_&{FDVwiGqwdq}rQ=%$}O@*gihmtVV&@|2-m*f)Iwn>5{$@}<+1 zs35H#W^go?8$;jwRPVo>X?$m2s^%6+y2@*M3X$gwCtf-dO<^S^YxDj-P!x$Fs#M%F z4J>=McXZy)`toQk5~wvdk<(Y0@-OV3X_~h4ljqO=5OQrni`n$MI+g{l+BJ6jvd+hV%f6mI7T^Vq|^N7dd^fHS*C6rz{`@Gok;7uF8LZ& zmcjV5g$6B^=&5^0r*6a;VXK+j$w%S#NB%m8?8p_8T7MefqZ9E&Bf0Ug(=|n=qj*!< z#Ls?gx-u7bGN-ZZlRc;eH)#72;zhHid_7ubFbvWMzy6>D9@8yu|6ve zcb{IMsaa+V)Ftf{xbZ@z&VyoDB}_-`qu14>cfUAmP44oQ`G1Uep-6KNo-t5al#PtT z(QSO}>8PC-rO>-pYbasOS4D|!K3yKWcVXcnhGGu$(WNhSd^IYwCvR&+46gS{fERT9 z$%HjPPs-@J*r#OVYa(kt1c$DZdE1+oo|tA9srI*_1Ky7~CUF_z!mbF?+>Y@d(yu(H z;tmwLbsjEEA-SYJ_pth0le}^i=hi|w&Vg?IgL|(oP~yDH+{z!Bm!h;kK3}||i28HE z?sn97s@RaurK;%B9m)6S?D<3~dZ)Qr4EWMKHSW=BM`Xsmw%~jh+gtI5t15`b#Z!rQ z7VUd7(AxC) z66)PZr>RSV`7Uw0vEQ!gleRBBJtpN#s~d(bnNp)qClwad0-mB%V(WMB`*ve+jZ6rv zA>6dd*C4?Ipk#XMu0$zT^gYwSNbRG44_d1YQ6jLvDavCa4l9P%y-hdy6hzJ)T3*?Z z0c{Ga6q$x0dd!+jP8J8q`^UI7VuI2mlOMIZI=Boihjpo`i||d+9**TL@K}40yR+JB z>uBb3W6cM%Y7!IST=$%pNsIi1oY8`_q0oJ!x^wWrBlQz9zrf`ZLq0v(7fpeq{L}fn z&bh;VZb7izJVRM|jiCh6DR_z!4|l(;z&5(3`?Re4w4&Q1|JC3+(ccRv7_bH~*4l^y z=b{N$Owg$n5G7nZYl~X}0j_^?dKGv;@xRwjP<{=tfGmmt;D8!%4Z{Ik0K3+JTaY6O zfl4o0>bNkMhUxs5G2Q!K$2h|F)C=<^AG{P-hALQI?gQxqU8g!t-(lg|MD%>NIeikNBu delta 4844 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 LHf^LYS7iSISO)6A diff --git a/src/purejavahidapi/windows/HidDevice.java b/src/purejavahidapi/windows/HidDevice.java index b4a7bae..a527c65 100644 --- a/src/purejavahidapi/windows/HidDevice.java +++ b/src/purejavahidapi/windows/HidDevice.java @@ -48,7 +48,6 @@ import com.sun.jna.NativeLong; import com.sun.jna.Pointer; -import com.sun.jna.platform.win32.Kernel32; import com.sun.jna.platform.win32.WinBase.*; import com.sun.jna.platform.win32.WinNT.HANDLE; @@ -92,13 +91,13 @@ public class HidDevice extends purejavahidapi.HidDevice { HIDP_PREPARSED_DATA[] ppd = new HIDP_PREPARSED_DATA[1]; res = HidD_GetPreparsedData(handle, ppd); if (!res) { - Kernel32.INSTANCE.CloseHandle(handle); + CloseHandle(handle); return; } HIDP_CAPS caps = new HIDP_CAPS(); int nt_res = HidP_GetCaps(ppd[0], caps); if (nt_res != HIDP_STATUS_SUCCESS) { - Kernel32.INSTANCE.CloseHandle(handle); + CloseHandle(handle); return; } m_OutputReportLength = caps.OutputReportByteLength; @@ -137,7 +136,7 @@ public void run() { m_ForceControlOutput = System.getProperty("purejavahidapi.forceControlOutput") != null; // bManualReset parameter has to be set to true to work with WaitForSingleObject - m_OutputReportOverlapped.hEvent = Kernel32.INSTANCE.CreateEvent(null, true, false, null); + m_OutputReportOverlapped.hEvent = CreateEvent(null, true, false, null); } @Override @@ -151,8 +150,8 @@ synchronized public void close() { m_Thread.interrupt(); m_SyncShutdown.waitAndSync(); } - Kernel32.INSTANCE.CloseHandle(m_OutputReportOverlapped.hEvent); - Kernel32.INSTANCE.CloseHandle(m_Handle); + CloseHandle(m_OutputReportOverlapped.hEvent); + CloseHandle(m_Handle); m_Backend.removeDevice(m_HidDeviceInfo.getDeviceId()); m_Open = false; } @@ -165,13 +164,13 @@ synchronized public int setOutputReport(byte reportID, byte[] data, int length) throw new IllegalArgumentException("this device supports no output reports"); // In Windows writeFile() to HID device data has to be preceded with the report // number, regardless - Arrays.fill(m_OutputReportArray, (byte)0); - m_OutputReportArray[0] = reportID; - System.arraycopy(data, 0, m_OutputReportArray, 1, length); - + m_OutputReportMemory.write(0, new byte[] { + reportID + }, 0, 1); + m_OutputReportMemory.write(1, data, 0, length); if (!m_ForceControlOutput) { - Kernel32.INSTANCE.ResetEvent(m_OutputReportOverlapped.hEvent); + ResetEvent(m_OutputReportOverlapped.hEvent); m_OutputReportOverlapped.Internal = null; m_OutputReportOverlapped.InternalHigh = null; m_OutputReportOverlapped.Offset = 0; @@ -179,16 +178,23 @@ synchronized public int setOutputReport(byte reportID, byte[] data, int length) // In windows always attempt to write as many bytes as there are in the longest // report plus one for the report number (even if zero ie not used) - if (!Kernel32.INSTANCE.WriteFile(m_Handle, m_OutputReportArray, m_OutputReportLength, null, m_OutputReportOverlapped)) { - if (Kernel32.INSTANCE.GetLastError() != ERROR_IO_PENDING) { + if (!WriteFile(m_Handle, m_OutputReportMemory, m_OutputReportLength, null, m_OutputReportOverlapped)) { + if (GetLastError() != ERROR_IO_PENDING) { // WriteFile() failed. Return error. // register_error(dev, "WriteFile"); + System.err.println("WriteFile failed with GetLastError()==" + GetLastError()); return -1; } } - if (WAIT_OBJECT_0 != Kernel32.INSTANCE.WaitForSingleObject(m_OutputReportOverlapped.hEvent, 1000)) { - return -2; + if (WAIT_OBJECT_0 != WaitForSingleObject(m_OutputReportOverlapped.hEvent, 1000)) { + // This could be an overkill and not needed. When there is a chance need to be tested without this block + m_OutputReportOverlapped.read(); + + if (WAIT_OBJECT_0 != WaitForSingleObject(m_OutputReportOverlapped.hEvent, 1000)) { + System.err.println("WaitForSingleObject failed with GetLastError()==" + GetLastError()); + return -2; + } } // Update structure from native code @@ -197,16 +203,12 @@ synchronized public int setOutputReport(byte reportID, byte[] data, int length) if (!GetOverlappedResult(m_Handle, m_OutputReportOverlapped, m_OutputReportBytesWritten, false/* don't need to wait */)) { // The Write operation failed. // register_error(dev, "WriteFile"); + System.err.println("GetOverlappedResult failed with GetLastError()==" + GetLastError()); return -3; } return m_OutputReportBytesWritten[0] - 1; } else { - m_OutputReportMemory.write(0, new byte[] { - reportID - }, 0, 1); - m_OutputReportMemory.write(1, data, 0, length); - if (!HidD_SetOutputReport(m_Handle, m_OutputReportMemory.getByteArray(0, length + 1), length + 1)) { // HidD_SetOutputReport() failed. Return error. // register_error(dev, "HidD_SetOutputReport"); @@ -257,7 +259,7 @@ synchronized public int getFeatureReport(byte[] data, int length) { Pointer buffer = new Memory(data.length); if (!DeviceIoControl(m_Handle, IOCTL_HID_GET_FEATURE, buffer, length, buffer, length, bytes, ol)) { // System.out.println(GetLastError()); - if (Kernel32.INSTANCE.GetLastError() != ERROR_IO_PENDING) + if (GetLastError() != ERROR_IO_PENDING) return -1; } @@ -274,11 +276,11 @@ private void runReadOnBackground() { int[] numBytesRead = { 0 }; OVERLAPPED overlapped = new OVERLAPPED(); - overlapped.hEvent = Kernel32.INSTANCE.CreateEvent(null, true, true, null); + overlapped.hEvent = CreateEvent(null, true, true, null); Memory readBuffer = new Memory(m_InputReportLength); while (!m_StopThread) { - Kernel32.INSTANCE.ResetEvent(overlapped.hEvent); + ResetEvent(overlapped.hEvent); numBytesRead[0] = 0; overlapped.Internal = null; overlapped.InternalHigh = null; @@ -291,33 +293,35 @@ private void runReadOnBackground() { // is always preceded with the report number (even if not used in // case of which it is zero) if (!ReadFile(m_Handle, readBuffer, m_InputReportLength, numBytesRead, overlapped)) { - if (Kernel32.INSTANCE.GetLastError() == ERROR_DEVICE_NOT_CONNECTED) + if (GetLastError() == ERROR_DEVICE_NOT_CONNECTED) break; // early exit if the device disappears - if (Kernel32.INSTANCE.GetLastError() != ERROR_IO_PENDING) { + if (GetLastError() != ERROR_IO_PENDING) { CancelIo(m_Handle); - System.err.println("ReadFile failed with GetLastError()==" + Kernel32.INSTANCE.GetLastError()); + System.err.println("ReadFile failed with GetLastError()==" + GetLastError()); + //Log("runReadOnBackground ReadFile error"); } if (WAIT_OBJECT_0 != WaitForSingleObject(overlapped.hEvent, INFINITE)) { - System.err.println("WaitForSingleObject failed with GetLastError()==" + Kernel32.INSTANCE.GetLastError()); + System.err.println("WaitForSingleObject failed with GetLastError()==" + GetLastError()); + //Log("runReadOnBackground WaitForSingleObject error"); } // Update structure from native code overlapped.read(); if (!GetOverlappedResult(m_Handle, overlapped, numBytesRead, false/* don't need to wait */)) { - if (Kernel32.INSTANCE.GetLastError() == ERROR_DEVICE_NOT_CONNECTED) + if (GetLastError() == ERROR_DEVICE_NOT_CONNECTED) break; // early exit if the device disappears - if (m_StopThread && Kernel32.INSTANCE.GetLastError() == ERROR_OPERATION_ABORTED) + if (m_StopThread && GetLastError() == ERROR_OPERATION_ABORTED) break; // on close - System.err.println("GetOverlappedResult failed with GetLastError()==" + Kernel32.INSTANCE.GetLastError()); + System.err.println("GetOverlappedResult failed with GetLastError()==" + GetLastError()); } } processInputReport(readBuffer, numBytesRead[0]); } - Kernel32.INSTANCE.CloseHandle(overlapped.hEvent); + CloseHandle(overlapped.hEvent); m_SyncShutdown.waitAndSync(); } @@ -327,10 +331,14 @@ private void processInputReport(Memory readBuffer, int numBytesRead) { int len = numBytesRead - 1; byte[] inputReport = new byte[len]; readBuffer.read(1, inputReport, 0, len); + //Log("HB: " + inputReport[1]); if (m_InputReportListener != null) { m_InputReportListener.onInputReport(this, reportID, inputReport, len); } } + else { + //Log("processInputReport error 1"); + } } private void Log(String sMessage) { From 547272f06d4bddeb8b14b1f68bc1047c6aa56c6c Mon Sep 17 00:00:00 2001 From: Mike Kuznetsov Date: Thu, 26 Mar 2020 16:25:24 -0500 Subject: [PATCH 2/2] Removing empty block --- src/purejavahidapi/windows/HidDevice.java | 3 --- 1 file changed, 3 deletions(-) diff --git a/src/purejavahidapi/windows/HidDevice.java b/src/purejavahidapi/windows/HidDevice.java index a527c65..ff97cae 100644 --- a/src/purejavahidapi/windows/HidDevice.java +++ b/src/purejavahidapi/windows/HidDevice.java @@ -336,9 +336,6 @@ private void processInputReport(Memory readBuffer, int numBytesRead) { m_InputReportListener.onInputReport(this, reportID, inputReport, len); } } - else { - //Log("processInputReport error 1"); - } } private void Log(String sMessage) {