📄 shellproc.cpp
字号:
//******************************************************************************
//
//
// This source code is licensed under Microsoft Shared Source License
// Version 1.0 for Windows CE.
// For a copy of the license visit http://go.microsoft.com/fwlink/?LinkId=3223.
//******************************************************************************
/*++
Module Name:
Shellproc.cpp
Abstract:
Interface between test dll and tux
--*/
#include "testmain.h"
#include "common.h"
#include "resource.h"
#include "ddlxioct.h"
//globals
//DECLARE_CARDSERVICES_TABLE;
// Global CKato logging object. Set while processing SPM_LOAD_DLL message.
DDLXKato_Talk* g_pKato = NULL;
// Global shell info structure. Set while processing SPM_SHELL_INFO message.
SPS_SHELL_INFO *g_pShellInfo;
// Global critical section to be used by threaded tests if necessary.
CRITICAL_SECTION g_csProcess;
//Handle for this dll
HINSTANCE g_hInst = NULL;
//The handle for pcmcia.dll
HINSTANCE hInst = NULL;
CARD_CLIENT_HANDLE g_hClient = NULL;
CLIENT_CONTEXT g_ClientData = {0};
USHORT uTestCategory;
BOOL bCardNotInSlot;
BOOL bRegUpdated;
DWORD dwTotalThread;
SOCKET_DESCRIPTOR g_SocketDescs[MAX_SOCKETS];
CARD_DESCRIPTOR g_CardDescs[MAX_SOCKETS*2];
DWORD g_dwTotalSockets;
DWORD g_dwTotalCards;
HINSTANCE g_hPCCardDll = NULL;
//******************************************************************************
//***** Windows CE specific code
//******************************************************************************
#ifdef UNDER_CE
#ifdef __cplusplus
extern "C" {
#endif
BOOL WINAPI DllMain(HANDLE hInstance, ULONG dwReason, LPVOID lpReserved) {
g_hInst = (HINSTANCE)hInstance;
return TRUE;
}
#ifdef __cplusplus
}
#endif
#endif
extern "C" {
// --------------------------------------------------------------------
// Tux testproc function table
//
FUNCTION_TABLE_ENTRY g_lpFTE[] = {
_T("Single-function card test in one socket"), 0, 0, 0, NULL,
_T("Request configuration test"), 1, 1, 11001, TestDispatchEntry,
_T("Modify configuration test"), 1, 1, 11002, TestDispatchEntry,
_T("Access config registers test"), 1, 1, 11003, TestDispatchEntry,
_T("Card disable and reset test"), 1, 1, 11004, TestDispatchEntry,
_T("Normal window test"), 1, 1, 12001, TestDispatchEntry,
_T("Window test with invalid inputs"), 1, 1, 12002, TestDispatchEntry,
_T("Request/Release IRQ test"), 1, 1, 13001, TestDispatchEntry,
_T("Tuple Full Test"), 1, 1, 16001, TestDispatchEntry,
_T("Tuple Full Test - Multithreaded"), 1, 1, 16002, TestDispatchEntry,
_T("Tuple Full Test 2"), 1, 1, 16003, TestDispatchEntry,
_T("Additional: CardGetFirstTuple"), 1, 1, 16101, TestDispatchEntry,
_T("Additional: CardGetNextTuple"), 1, 1, 16102, TestDispatchEntry,
_T("Multiple function card test in two sockets"), 0, 0, 0, NULL,
_T("Request configuration test"), 1, 1, 21001, TestDispatchEntry,
_T("Modify configuration test"), 1, 1, 21002, TestDispatchEntry,
_T("Access config registers test"), 1, 1, 21003, TestDispatchEntry,
_T("Normal window test"), 1, 1, 22001, TestDispatchEntry,
_T("Window test with invalid inputs"), 1, 1, 22002, TestDispatchEntry,
_T("Request/Release IRQ test"), 1, 1, 23001, TestDispatchEntry,
_T("Tuple Full Test"), 1, 1, 26001, TestDispatchEntry,
_T("Tuple Full Test - Multithreaded"), 1, 1, 26002, TestDispatchEntry,
_T("Additional: CardGetFirstTuple"), 1, 1, 26101, TestDispatchEntry,
_T("Additional: CardGetNextTuple"), 1, 1, 26102, TestDispatchEntry,
_T("Additional: CardGetTupleData"), 1, 1, 26103, TestDispatchEntry,
_T("card test in all sockets"), 0, 0, 0, NULL,
_T("Request configuration test"), 1, 1, 31001, TestDispatchEntry,
_T("Modify configuration test"), 1, 1, 31002, TestDispatchEntry,
_T("Access config registers test"), 1, 1, 31003, TestDispatchEntry,
_T("Normal window test"), 1, 1, 32001, TestDispatchEntry,
_T("Window test with invalid inputs"), 1, 1, 32002, TestDispatchEntry,
_T("Request/Release IRQ test"), 1, 1, 33001, TestDispatchEntry,
_T("Tuple Full Test"), 1, 1, 36001, TestDispatchEntry,
_T("Tuple Full Test - Multithreaded"), 1, 4, 36002, TestDispatchEntry,
_T("Tuple Full Test 2"), 1, 1, 36003, TestDispatchEntry,
_T("Additional: CardGetFirstTuple"), 1, 1, 36101, TestDispatchEntry,
_T("Additional: CardGetNextTuple"), 1, 1, 36102, TestDispatchEntry,
NULL, 0, 0, 0, NULL,
};
}
// --------------------------------------------------------------------
SHELLPROCAPI
ShellProc(
UINT uMsg,
SPPARAM spParam )
// --------------------------------------------------------------------
{
LPSPS_BEGIN_TEST pBT = {0};
LPSPS_END_TEST pET = {0};
DWORD dwRet;
switch (uMsg) {
// --------------------------------------------------------------------
// Message: SPM_LOAD_DLL
//
case SPM_LOAD_DLL:
DEBUGMSG(ZONE_FUNCTION, (_T("ShellProc(SPM_LOAD_DLL, ...) called")));
// If we are UNICODE, then tell Tux this by setting the following flag.
#ifdef UNICODE
((LPSPS_LOAD_DLL)spParam)->fUnicode = TRUE;
#endif
// turn on kato debugging
KatoDebug(1, KATO_MAX_VERBOSITY,KATO_MAX_VERBOSITY,KATO_MAX_LEVEL);
//try loading pcc_serv.dll and get API addresses
if(PC16bitWR_Init(TEXT("pcc_serv.dll")) == FALSE){
return SPR_NOT_HANDLED;
}
if(Update16BitRegistry() == FALSE){
return SPR_NOT_HANDLED;
}
// Get/Create our global logging object.
// g_pKato = (CKato*)KatoGetDefaultObject();
// Initialize our global critical section.
InitializeCriticalSection(&g_csProcess);
uTestCategory = 0xFF;
bCardNotInSlot = FALSE;
bRegUpdated = FALSE;
memset(g_SocketDescs, 0, sizeof(g_SocketDescs));
memset(g_CardDescs, 0, sizeof(g_CardDescs));
g_dwTotalCards = 0;
g_dwTotalSockets = 0;
CARD_REGISTER_PARMS crParam;
//register client now
g_ClientData.uClientID = MAIN_THREAD_ID;
//create event:
g_ClientData.hEvent = CreateEvent(0L, FALSE, FALSE , NULL);
if (g_ClientData.hEvent == NULL){
g_pKato->Log(LOG_DETAIL, TEXT("CreateEvent() FAILed:\r\n"));
return SPR_NOT_HANDLED;
}
crParam.fAttributes = CLIENT_ATTR_IO_DRIVER; //mem cards are rare now
crParam.fEventMask = 0xFFFF;
crParam.uClientData = (UINT32) &g_ClientData;
g_hClient = CardRegisterClient(CallBackFn_Client, &crParam);
dwRet = WaitForSingleObject( g_ClientData.hEvent, TEST_WAIT_TIME);
if (g_hClient == NULL || dwRet == WAIT_TIMEOUT){
g_pKato->Log(LOG_DETAIL,TEXT("CardRegisterClient() FAILed\r\n"));
return SPR_NOT_HANDLED;
}
g_ClientData.hClient = g_hClient;
ResetEvent(g_ClientData.hEvent);
return SPR_HANDLED;
// --------------------------------------------------------------------
// Message: SPM_UNLOAD_DLL
//
case SPM_UNLOAD_DLL:
DEBUGMSG(ZONE_FUNCTION, (_T("ShellProc(SPM_UNLOAD_DLL, ...) called")));
//deregister client
if(CardDeregisterClient(g_hClient) != CERR_SUCCESS){
g_pKato->Log(LOG_FAIL, TEXT("Can not deregister client!\n"));
return SPR_FAIL;
}
// This is a good place to delete our global critical section.
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -