diff --git a/src/Thunks/UIAutomationCore.hpp b/src/Thunks/UIAutomationCore.hpp index 5903b37..b4e190d 100644 --- a/src/Thunks/UIAutomationCore.hpp +++ b/src/Thunks/UIAutomationCore.hpp @@ -83,7 +83,7 @@ namespace YY::Thunks // 最低受支持的服务器 Windows Server 2003[桌面应用 | UWP 应用] __DEFINE_THUNK( uiautomationcore, - 16, + 40, HRESULT, WINAPI, UiaRaiseAutomationPropertyChangedEvent, diff --git a/src/Thunks/WinUsb.hpp b/src/Thunks/WinUsb.hpp index 2a0c46a..7b3c6e3 100644 --- a/src/Thunks/WinUsb.hpp +++ b/src/Thunks/WinUsb.hpp @@ -163,7 +163,7 @@ namespace YY::Thunks // 最低受支持XP,但是XP需要打补丁,Vista开始直接内置 __DEFINE_THUNK( winusb, - 24, + 8, BOOL, __stdcall, WinUsb_ResetPipe, @@ -211,7 +211,7 @@ namespace YY::Thunks // 最低受支持XP,但是XP需要打补丁,Vista开始直接内置 __DEFINE_THUNK( winusb, - 8, + 24, BOOL, __stdcall, WinUsb_WritePipe, diff --git a/src/Thunks/bcrypt.hpp b/src/Thunks/bcrypt.hpp index 7740510..a0c647e 100644 --- a/src/Thunks/bcrypt.hpp +++ b/src/Thunks/bcrypt.hpp @@ -2139,7 +2139,7 @@ namespace YY::Thunks // 最低受支持的服务器 Windows Server 2008 R2[桌面应用 | UWP 应用] __DEFINE_THUNK( bcrypt, - 40, + 20, NTSTATUS, WINAPI, BCryptDeriveKeyCapi, diff --git a/src/Thunks/mfplat.hpp b/src/Thunks/mfplat.hpp index 286b658..d508390 100644 --- a/src/Thunks/mfplat.hpp +++ b/src/Thunks/mfplat.hpp @@ -384,7 +384,7 @@ namespace YY::Thunks // Windows XP SP2需要安装补丁 __DEFINE_THUNK( mfplat, - 12, + 4, HRESULT, STDAPICALLTYPE, MFCreateSample, @@ -602,7 +602,7 @@ namespace YY::Thunks // Minimum supported server Windows Server 2008 R2[desktop apps | UWP apps] __DEFINE_THUNK( mfplat, - 24, + 36, HRESULT, STDAPICALLTYPE, MFTEnumEx, diff --git a/src/Thunks/netapi32.hpp b/src/Thunks/netapi32.hpp index 78235ad..a8000af 100644 --- a/src/Thunks/netapi32.hpp +++ b/src/Thunks/netapi32.hpp @@ -38,7 +38,7 @@ namespace YY::Thunks // 最低受支持的服务器 Windows Server 2016[仅限桌面应用] __DEFINE_THUNK( netapi32, - 8, + 4, VOID, NET_API_FUNCTION, NetFreeAadJoinInformation, diff --git a/src/YY-Thunks.UnitTest/YY-Thunks.UnitTest.cpp b/src/YY-Thunks.UnitTest/YY-Thunks.UnitTest.cpp index e7846e1..3f7d89f 100644 --- a/src/YY-Thunks.UnitTest/YY-Thunks.UnitTest.cpp +++ b/src/YY-Thunks.UnitTest/YY-Thunks.UnitTest.cpp @@ -427,7 +427,14 @@ __declspec(selectany) __declspec(allocate("TMP$__a")) LPCSTR FirstFunctionName[1 __declspec(selectany) __declspec(allocate("TMP$__z")) LPCSTR LastFunctionName[1] = {}; -#define __DEFINE_THUNK(_MODULE, _SIZE, _RETURN_, _CONVENTION_, _FUNCTION, ...) \ +#if defined(_X86_) +#define __DETECT_IAT_SYMBOL(_FUNCTION, _SIZE) __pragma(comment(linker, "/export:_"#_FUNCTION"@"#_SIZE)) +#else +#define __DETECT_IAT_SYMBOL(_FUNCTION, _SIZE) +#endif + +#define __DEFINE_THUNK(_MODULE, _SIZE, _RETURN_, _CONVENTION_, _FUNCTION, ...) \ + __DETECT_IAT_SYMBOL(_FUNCTION, _SIZE) \ __if_exists(YY::Thunks::TopFix::_FUNCTION) {decltype(YY::Thunks::TopFix::_FUNCTION)* _CRT_CONCATENATE(FunctionInclude, _FUNCTION) = &YY::Thunks::TopFix::_FUNCTION;} \ __if_not_exists(YY::Thunks::TopFix::_FUNCTION){decltype(::_FUNCTION)* _CRT_CONCATENATE(FunctionInclude, _FUNCTION) = &::_FUNCTION;} \ __declspec(allocate("TMP$__a")) LPCSTR _CRT_CONCATENATE(FunctionName, _FUNCTION) = #_FUNCTION; \