青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

我住包子山

this->blog.MoveTo("blog.baozishan.in")

LPC 的一個示例(Ntdll Port API test)

之前小小學了一點win32 LPC的知識,這個samplewine ref的一個test,感覺已經很全面。
今天還找來了兩本關于Ntdll方面的電子書,Windows_2000_Native_API_Reference
Undocumented Windows 2000 Secrets..都是英文書,慢慢啃。
  1 /* Unit test suite for Ntdll Port API functions
  2  *
  3  * Copyright 2006 James Hawkins
  4  *
  5  * This library is free software; you can redistribute it and/or
  6  * modify it under the terms of the GNU Lesser General Public
  7  * License as published by the Free Software Foundation; either
  8  * version 2.1 of the License, or (at your option) any later version.
  9  *
 10  * This library is distributed in the hope that it will be useful,
 11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 13  * Lesser General Public License for more details.
 14  *
 15  * You should have received a copy of the GNU Lesser General Public
 16  * License along with this library; if not, write to the Free Software
 17  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
 18  */
 19 
 20 #include <stdio.h>
 21 #include <stdarg.h>
 22 
 23 #include "24 #define WIN32_NO_STATUS
 25 #include "26 #include "27 #include "28 #include "29 #include "30 #include "31 #include "32 
 33 #ifndef __WINE_WINTERNL_H
 34 
 35 typedef struct _CLIENT_ID
 36 {
 37    HANDLE UniqueProcess;
 38    HANDLE UniqueThread;
 39 } CLIENT_ID, *PCLIENT_ID;
 40 
 41 typedef struct _LPC_SECTION_WRITE
 42 {
 43   ULONG Length;
 44   HANDLE SectionHandle;
 45   ULONG SectionOffset;
 46   ULONG ViewSize;
 47   PVOID ViewBase;
 48   PVOID TargetViewBase;
 49 } LPC_SECTION_WRITE, *PLPC_SECTION_WRITE;
 50 
 51 typedef struct _LPC_SECTION_READ
 52 {
 53   ULONG Length;
 54   ULONG ViewSize;
 55   PVOID ViewBase;
 56 } LPC_SECTION_READ, *PLPC_SECTION_READ;
 57 
 58 typedef struct _LPC_MESSAGE
 59 {
 60   USHORT DataSize;
 61   USHORT MessageSize;
 62   USHORT MessageType;
 63   USHORT VirtualRangesOffset;
 64   CLIENT_ID ClientId;
 65   ULONG MessageId;
 66   ULONG SectionSize;
 67   UCHAR Data[ANYSIZE_ARRAY];
 68 } LPC_MESSAGE, *PLPC_MESSAGE;
 69 
 70 #endif
 71 
 72 /* Types of LPC messages */
 73 #define UNUSED_MSG_TYPE                 0
 74 #define LPC_REQUEST                     1
 75 #define LPC_REPLY                       2
 76 #define LPC_DATAGRAM                    3
 77 #define LPC_LOST_REPLY                  4
 78 #define LPC_PORT_CLOSED                 5
 79 #define LPC_CLIENT_DIED                 6
 80 #define LPC_EXCEPTION                   7
 81 #define LPC_DEBUG_EVENT                 8
 82 #define LPC_ERROR_EVENT                 9
 83 #define LPC_CONNECTION_REQUEST         10
 84 
 85 static const WCHAR PORTNAME[] = {'\\','M','y','P','o','r','t',0};
 86 
 87 #define REQUEST1    "Request1"
 88 #define REQUEST2    "Request2"
 89 #define REPLY       "Reply"
 90 
 91 #define MAX_MESSAGE_LEN    30
 92 
 93 UNICODE_STRING  port;
 94 static char     selfname[MAX_PATH];
 95 static int      myARGC;
 96 static char**   myARGV;
 97 
 98 /* Function pointers for ntdll calls */
 99 static HMODULE hntdll = 0;
100 static NTSTATUS (WINAPI *pNtCompleteConnectPort)(HANDLE);
101 static NTSTATUS (WINAPI *pNtAcceptConnectPort)(PHANDLE,ULONG,PLPC_MESSAGE,ULONG,
102                                                ULONG,PLPC_SECTION_READ);
103 static NTSTATUS (WINAPI *pNtReplyPort)(HANDLE,PLPC_MESSAGE);
104 static NTSTATUS (WINAPI *pNtReplyWaitReceivePort)(PHANDLE,PULONG,PLPC_MESSAGE,
105                                                   PLPC_MESSAGE);
106 static NTSTATUS (WINAPI *pNtCreatePort)(PHANDLE,POBJECT_ATTRIBUTES,ULONG,ULONG,ULONG);
107 static NTSTATUS (WINAPI *pNtRequestWaitReplyPort)(HANDLE,PLPC_MESSAGE,PLPC_MESSAGE);
108 static NTSTATUS (WINAPI *pNtRequestPort)(HANDLE,PLPC_MESSAGE);
109 static NTSTATUS (WINAPI *pNtRegisterThreadTerminatePort)(HANDLE);
110 static NTSTATUS (WINAPI *pNtConnectPort)(PHANDLE,PUNICODE_STRING,
111                                          PSECURITY_QUALITY_OF_SERVICE,
112                                          PLPC_SECTION_WRITE,PLPC_SECTION_READ,
113                                          PVOID,PVOID,PULONG);
114 static NTSTATUS (WINAPI *pRtlInitUnicodeString)(PUNICODE_STRING,LPCWSTR);
115 static NTSTATUS (WINAPI *pNtWaitForSingleObject)(HANDLE,BOOLEAN,PLARGE_INTEGER);
116 
117 static BOOL init_function_ptrs(void)
118 {
119     hntdll = );
120 
121     if (hntdll)
122     {
123         pNtCompleteConnectPort = (void *)GetProcAddress(hntdll, "NtCompleteConnectPort");
124         pNtAcceptConnectPort = (void *)GetProcAddress(hntdll, "NtAcceptConnectPort");
125         pNtReplyPort = (void *)GetProcAddress(hntdll, "NtReplyPort");
126         pNtReplyWaitReceivePort = (void *)GetProcAddress(hntdll, "NtReplyWaitReceivePort");
127         pNtCreatePort = (void *)GetProcAddress(hntdll, "NtCreatePort");
128         pNtRequestWaitReplyPort = (void *)GetProcAddress(hntdll, "NtRequestWaitReplyPort");
129         pNtRequestPort = (void *)GetProcAddress(hntdll, "NtRequestPort");
130         pNtRegisterThreadTerminatePort = (void *)GetProcAddress(hntdll, "NtRegisterThreadTerminatePort");
131         pNtConnectPort = (void *)GetProcAddress(hntdll, "NtConnectPort");
132         pRtlInitUnicodeString = (void *)GetProcAddress(hntdll, "RtlInitUnicodeString");
133         pNtWaitForSingleObject = (void *)GetProcAddress(hntdll, "NtWaitForSingleObject");
134     }
135 
136     if (!pNtCompleteConnectPort || !pNtAcceptConnectPort ||
137         !pNtReplyWaitReceivePort || !pNtCreatePort || !pNtRequestWaitReplyPort ||
138         !pNtRequestPort || !pNtRegisterThreadTerminatePort ||
139         !pNtConnectPort || !pRtlInitUnicodeString)
140     {
141         return FALSE;
142     }
143 
144     return TRUE;
145 }
146 
147 static void ProcessConnectionRequest(PLPC_MESSAGE LpcMessage, PHANDLE pAcceptPortHandle)
148 {
149     NTSTATUS status;
150 
151     ok(LpcMessage->MessageType == LPC_CONNECTION_REQUEST,
152        "Expected LPC_CONNECTION_REQUEST, got %d\n", LpcMessage->MessageType);
153     ok(!*LpcMessage->Data, "Expected empty string!\n");
154 
155     status = pNtAcceptConnectPort(pAcceptPortHandle, 0, LpcMessage, 1, 0, NULL);
156     ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %d\n", status);
157     
158     status = pNtCompleteConnectPort(*pAcceptPortHandle);
159     ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %d\n", status);
160 }
161 
162 static void ProcessLpcRequest(HANDLE PortHandle, PLPC_MESSAGE LpcMessage)
163 {
164     NTSTATUS status;
165 
166     ok(LpcMessage->MessageType == LPC_REQUEST,
167        "Expected LPC_REQUEST, got %d\n", LpcMessage->MessageType);
168     ok(!lstrcmp((LPSTR)LpcMessage->Data, REQUEST2),
169        "Expected %s, got %s\n", REQUEST2, LpcMessage->Data);
170 
171     lstrcpy((LPSTR)LpcMessage->Data, REPLY);
172 
173     status = pNtReplyPort(PortHandle, LpcMessage);
174     ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %d\n", status);
175     ok(LpcMessage->MessageType == LPC_REQUEST,
176        "Expected LPC_REQUEST, got %d\n", LpcMessage->MessageType);
177     ok(!lstrcmp((LPSTR)LpcMessage->Data, REPLY),
178        "Expected %s, got %s\n", REPLY, LpcMessage->Data);
179 }
180 
181 static DWORD WINAPI test_ports_client(LPVOID arg)
182 {
183     SECURITY_QUALITY_OF_SERVICE sqos;
184     LPC_MESSAGE *LpcMessage, *out;
185     HANDLE PortHandle;
186     ULONG len, size;
187     NTSTATUS status;
188 
189     sqos.Length = sizeof(SECURITY_QUALITY_OF_SERVICE);
190     sqos.ImpersonationLevel = SecurityImpersonation;
191     sqos.ContextTrackingMode = SECURITY_STATIC_TRACKING;
192     sqos.EffectiveOnly = TRUE;
193 
194     status = pNtConnectPort(&PortHandle, &port, &sqos, 0, 0, &len, NULL, NULL);
195     todo_wine ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %d\n", status);
196     if (status != STATUS_SUCCESS) return 1;
197 
198     status = pNtRegisterThreadTerminatePort(PortHandle);
199     ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %d\n", status);
200 
201     size = FIELD_OFFSET(LPC_MESSAGE, Data) + MAX_MESSAGE_LEN;
202     LpcMessage = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, size);
203     out = HeapAlloc(GetProcessHeap(), 0, size);
204 
205     LpcMessage->DataSize = lstrlen(REQUEST1) + 1;
206     LpcMessage->MessageSize = FIELD_OFFSET(LPC_MESSAGE, Data) + LpcMessage->DataSize;
207     lstrcpy((LPSTR)LpcMessage->Data, REQUEST1);
208 
209     status = pNtRequestPort(PortHandle, LpcMessage);
210     ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %d\n", status);
211     ok(LpcMessage->MessageType == 0, "Expected 0, got %d\n", LpcMessage->MessageType);
212     ok(!lstrcmp((LPSTR)LpcMessage->Data, REQUEST1),
213        "Expected %s, got %s\n", REQUEST1, LpcMessage->Data);
214 
215     /* Fill in the message */
216     memset(LpcMessage, 0, size);
217     LpcMessage->DataSize = lstrlen(REQUEST2) + 1;
218     LpcMessage->MessageSize = FIELD_OFFSET(LPC_MESSAGE, Data) + LpcMessage->DataSize;
219     lstrcpy((LPSTR)LpcMessage->Data, REQUEST2);
220 
221     /* Send the message and wait for the reply */
222     status = pNtRequestWaitReplyPort(PortHandle, LpcMessage, out);
223     ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %d\n", status);
224     ok(!lstrcmp((LPSTR)out->Data, REPLY), "Expected %s, got %s\n", REPLY, out->Data);
225     ok(out->MessageType == LPC_REPLY, "Expected LPC_REPLY, got %d\n", out->MessageType);
226 
227     return 0;
228 }
229 
230 static void test_ports_server(void)
231 {
232     OBJECT_ATTRIBUTES obj;
233     HANDLE PortHandle;
234     HANDLE AcceptPortHandle;
235     PLPC_MESSAGE LpcMessage;
236     ULONG size;
237     NTSTATUS status;
238     BOOL done = FALSE;
239 
240     pRtlInitUnicodeString(&port, PORTNAME);
241 
242     memset(&obj, 0, sizeof(OBJECT_ATTRIBUTES));
243     obj.Length = sizeof(OBJECT_ATTRIBUTES);
244     obj.ObjectName = &port;
245 
246     status = pNtCreatePort(&PortHandle, &obj, 100, 100, 0);
247     todo_wine
248     {
249         ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %d\n", status);
250     }
251     if (status != STATUS_SUCCESS) return;
252 
253     size = FIELD_OFFSET(LPC_MESSAGE, Data) + MAX_MESSAGE_LEN;
254     LpcMessage = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, size);
255 
256     while (TRUE)
257     {
258         status = pNtReplyWaitReceivePort(PortHandle, NULL, NULL, LpcMessage);
259         todo_wine
260         {
261             ok(status == STATUS_SUCCESS, "Expected STATUS_SUCCESS, got %d(%x)\n", status, status);
262         }
263         /* STATUS_INVALID_HANDLE: win2k without admin rights will perform an
264          *                        endless loop here
265          */
266         if ((status == STATUS_NOT_IMPLEMENTED) ||
267             (status == STATUS_INVALID_HANDLE)) return;
268 
269         switch (LpcMessage->MessageType)
270         {
271             case LPC_CONNECTION_REQUEST:
272                 ProcessConnectionRequest(LpcMessage, &AcceptPortHandle);
273                 break;
274 
275             case LPC_REQUEST:
276                 ProcessLpcRequest(PortHandle, LpcMessage);
277                 done = TRUE;
278                 break;
279 
280             case LPC_DATAGRAM:
281                 ok(!lstrcmp((LPSTR)LpcMessage->Data, REQUEST1),
282                    "Expected %s, got %s\n", REQUEST1, LpcMessage->Data);
283                 break;
284 
285             case LPC_CLIENT_DIED:
286                 ok(done, "Expected LPC request to be completed!\n");
287                 return;
288 
289             default:
290                 ok(FALSE, "Unexpected message: %d\n", LpcMessage->MessageType);
291                 break;
292         }
293     }
294 }
295 
296 START_TEST(port)
297 {
298     HANDLE thread;
299     DWORD id;
300 
301     if (!init_function_ptrs())
302         return;
303 
304     myARGC = winetest_get_mainargs(&myARGV);
305     strcpy(selfname, myARGV[0]);
306 
307     thread = CreateThread(NULL, 0, test_ports_client, NULL, 0, &id);
308     ok(thread != NULL, "Expected non-NULL thread handle!\n");
309 
310     test_ports_server();
311     CloseHandle(thread);
312 }
313 

posted on 2008-02-28 00:48 Gohan 閱讀(1760) 評論(0)  編輯 收藏 引用 所屬分類: MFC/SDK

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久成人免费日本黄色| 亚洲国产毛片完整版| 国产婷婷色一区二区三区在线 | 夜夜狂射影院欧美极品| 91久久黄色| 欧美亚洲尤物久久| 在线播放国产一区中文字幕剧情欧美| 香蕉乱码成人久久天堂爱免费 | 久久影视精品| 欧美日韩午夜激情| 亚洲国产免费看| 亚洲国产欧美在线| 亚洲国产美女久久久久| 国产精品欧美日韩| 久久精品在线播放| 亚洲欧美一区二区原创| 国产一区二三区| 亚洲人成7777| 久久资源av| 亚洲男人的天堂在线观看| 国产乱子伦一区二区三区国色天香 | 欧美a一区二区| 欧美.www| 亚洲视频一二| 一区二区三区导航| 午夜精品www| 欧美一区二区三区四区在线观看地址 | 久久久久青草大香线综合精品| 国产精品亚洲综合一区在线观看 | 欧美日韩在线一区二区| 一本色道精品久久一区二区三区| 久久综合狠狠综合久久综合88| 一本久久综合| 亚洲男人av电影| 亚洲第一偷拍| 国产欧美精品一区二区三区介绍| 久久成人18免费网站| 久久亚洲精品网站| 欧美成年人在线观看| 久久高清免费观看| 精品91在线| 国产精品乱子久久久久| 欧美日韩高清区| 久久久久久夜| 亚洲国产日韩欧美在线99| 亚洲欧美精品在线观看| 国产一二精品视频| 久久亚洲视频| 国产综合香蕉五月婷在线| 久久久免费精品| 欧美大色视频| 欧美va亚洲va香蕉在线| 久久久久久久综合日本| 中文在线不卡| 亚洲高清不卡在线| 在线看欧美日韩| 一区免费观看| 亚洲特级毛片| aa国产精品| 久久人人爽爽爽人久久久| 欧美色中文字幕| 国产精品99久久久久久有的能看| 性伦欧美刺激片在线观看| 亚洲综合久久久久| 久久久久久日产精品| 亚洲精品1区2区| 欧美一区三区三区高中清蜜桃| 欧美aaa级| 久久精品国产一区二区三区| 亚洲人成人一区二区三区| 欧美午夜宅男影院| 蜜桃精品久久久久久久免费影院| 亚洲美女视频在线免费观看| 免费一区二区三区| 99热精品在线| 久久视频这里只有精品| 亚洲人成网站影音先锋播放| 欧美成人精品在线| 欧美日韩国产小视频| 午夜电影亚洲| 久久午夜色播影院免费高清| **性色生活片久久毛片| 亚洲久久在线| 一本久道久久综合狠狠爱| 欧美国产高清| 亚洲精品免费在线| 欧美日韩成人免费| 欧美一级播放| 国产精品乱码妇女bbbb| 久久综合久久88| 欧美激情综合| 欧美电影免费观看高清| 久久亚洲欧美| 免费一级欧美在线大片| 国产欧美69| 亚洲精品视频啊美女在线直播| 国产一区激情| 免费亚洲电影| 欧美激情2020午夜免费观看| 亚洲国产欧美精品| 嫩草国产精品入口| 亚洲精品免费一二三区| 日韩视频中午一区| 欧美freesex交免费视频| 亚洲高清色综合| 激情欧美一区二区三区| 亚久久调教视频| 久久亚洲二区| 精品1区2区| 欧美日韩理论| 午夜宅男久久久| 亚洲国产专区校园欧美| 国内精品伊人久久久久av影院 | 国产午夜精品久久久久久免费视 | 国产一区二区在线免费观看| 久久久一区二区三区| 亚洲国产三级网| 日韩亚洲综合在线| 精品不卡一区二区三区| 国产精品久久久久久久免费软件| 亚洲综合大片69999| 久久久久国产一区二区三区四区| 国产一区二区三区四区三区四 | 美女性感视频久久久| 国产精品视频一二三| 亚洲一区日本| 亚洲人久久久| 欧美一站二站| 亚洲精品一二区| 永久免费视频成人| 欧美性大战久久久久久久蜜臀| 久久精品国产欧美亚洲人人爽| 欧美aⅴ99久久黑人专区| 亚洲午夜91| 亚洲视频精品在线| 亚洲欧美日韩中文视频| 亚洲毛片视频| 激情一区二区三区| 欧美网站大全在线观看| 欧美在线免费观看| 欧美精品自拍| 免费在线一区二区| 欧美日本亚洲韩国国产| 欧美日本精品在线| 国产精品试看| 欧美另类高清视频在线| 久久成人亚洲| 欧美综合国产| 亚洲久久一区二区| 久久精品国产久精国产一老狼| 久久成人国产精品| 亚洲欧美在线另类| 欧美黄免费看| 欧美在线观看一区| 欧美日韩日本视频| 国产麻豆综合| 亚洲综合三区| 亚洲久色影视| 久久激情婷婷| 久久综合狠狠| 黄色在线一区| 久久爱www.| 久久国产乱子精品免费女| 国产精品国码视频| av不卡在线观看| 亚洲国产成人高清精品| 亚洲图色在线| 国产精品久久久久9999吃药| 亚洲欧美日韩中文播放| 欧美大片免费| 久久先锋资源| 亚洲乱码国产乱码精品精| 亚洲高清色综合| 一区二区日韩| 国产一本一道久久香蕉| 午夜精品福利一区二区三区av| 亚洲人体影院| 欧美精品在线观看| 亚洲国产成人不卡| 久久精品人人| 久久先锋资源| 亚洲一区欧美激情| 99精品视频免费全部在线| 欧美三级资源在线| 欧美aⅴ99久久黑人专区| 久久久www| 欧美一级播放| 欧美尤物一区| 亚洲国产一成人久久精品| 一区二区三区 在线观看视频| 欧美日韩在线亚洲一区蜜芽 | 亚洲一区二区三区精品在线观看| 亚洲欧美卡通另类91av| 91久久国产综合久久| 欧美日韩一区视频| 久久精品日产第一区二区三区| 欧美在线3区| 久久精品91| 欧美日韩久久精品| 久久夜色精品|