📄 cspiloopbacktest.cpp
字号:
//------------------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
//
// Use of this source code is subject to the terms of the Microsoft end-user
// license agreement (EULA) under which you licensed this SOFTWARE PRODUCT.
// If you did not accept the terms of the EULA, you are not authorized to use
// this source code. For a copy of the EULA, please see the LICENSE.RTF on your
// install media.
//
//------------------------------------------------------------------------------
//
// Copyright (C) 2006, Freescale Semiconductor, Inc. All Rights Reserved.
// THIS SOURCE CODE, AND ITS USE AND DISTRIBUTION, IS SUBJECT TO THE TERMS
// AND CONDITIONS OF THE APPLICABLE LICENSE AGREEMENT
//
//------------------------------------------------------------------------------
////////////////////////////////////////////////////////////////////////////////
//
// CSPILoopBack TUX DLL
//
// Module: CSPILoopBackTest.cpp
// Contains the shell processing function.
//
////////////////////////////////////////////////////////////////////////////////
#include <windows.h>
#include <Devload.h>
#include <ceddk.h>
#include "main.h"
#include "globals.h"
//#include "mxarm11.h"
#include "csp.h"
#include "mx27_cspi.h"
#include "cspibus.h"
#include "cspiutil.h"
//-----------------------------------------------------------------------------
// External Functions
//-----------------------------------------------------------------------------
//-----------------------------------------------------------------------------
// External Variables
//-----------------------------------------------------------------------------
//-----------------------------------------------------------------------------
// Defines
//-----------------------------------------------------------------------------
//-----------------------------------------------------------------------------
// Types
//-----------------------------------------------------------------------------
//-----------------------------------------------------------------------------
// Global Variables
//-----------------------------------------------------------------------------
//-----------------------------------------------------------------------------
// Local Variables
//-----------------------------------------------------------------------------
// Holds the open file handle to NLeddrvr driver
static HANDLE g_hCspi = NULL;
static UINT32 g_TXDATA[10] = {0x1, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0A};
static UINT32 g_RXDATA[10] = {0};
static CSPI_BUSCONFIG_T gBusCnfg;
static CSPI_XCH_PKT_T gXchPkt;
static PCSPI_XCH_PKT_T gpXchPkt = &gXchPkt;
static UINT g_Count = 1;
//-----------------------------------------------------------------------------
// Local Functions
//-----------------------------------------------------------------------------
////////////////////////////////////////////////////////////////////////////////
// DllMain
// Main entry point of the DLL. Called when the DLL is loaded or unloaded.
//
// Parameters:
// hInstance Module instance of the DLL.
// dwReason Reason for the function call.
// lpReserved Reserved for future use.
//
// Return value:
// TRUE if successful, FALSE to indicate an error condition.
BOOL WINAPI DllMain(HANDLE hInstance, ULONG dwReason, LPVOID lpReserved)
{
// Any initialization code goes here.
return TRUE;
}
////////////////////////////////////////////////////////////////////////////////
// Debug
// Printf-like wrapping around OutputDebugString.
//
// Parameters:
// szFormat Formatting string (as in printf).
// ... Additional arguments.
//
// Return value:
// None.
void Debug(LPCTSTR szFormat, ...)
{
static TCHAR szHeader[] = TEXT("CSPILoopBack: ");
TCHAR szBuffer[1024];
va_list pArgs;
va_start(pArgs, szFormat);
lstrcpy(szBuffer, szHeader);
wvsprintf(
szBuffer + countof(szHeader) - 1,
szFormat,
pArgs);
va_end(pArgs);
_tcscat(szBuffer, TEXT("\r\n"));
OutputDebugString(szBuffer);
}
////////////////////////////////////////////////////////////////////////////////
// ShellProc
// Processes messages from the TUX shell.
//
// Parameters:
// uMsg Message code.
// spParam Additional message-dependent data.
//
// Return value:
// Depends on the message.
SHELLPROCAPI ShellProc(UINT uMsg, SPPARAM spParam)
{
LPSPS_BEGIN_TEST pBT;
LPSPS_END_TEST pET;
switch (uMsg)
{
case SPM_LOAD_DLL:
// Sent once to the DLL immediately after it is loaded. The spParam
// parameter will contain a pointer to a SPS_LOAD_DLL structure. The
// DLL should set the fUnicode member of this structure to TRUE if the
// DLL is built with the UNICODE flag set. If you set this flag, Tux
// will ensure that all strings passed to your DLL will be in UNICODE
// format, and all strings within your function table will be processed
// by Tux as UNICODE. The DLL may return SPR_FAIL to prevent the DLL
// from continuing to load.
Debug(TEXT("ShellProc(SPM_LOAD_DLL, ...) called"));
//--------------------------------------
// Added To Framework Program
//--------------------------------------
// Initializes the system to validate the results in the registry
if(!InitializeTests())
{
RETAILMSG(1,
(TEXT(" ShellProc():InitializeTests() failed!\r\n")));
}
// If we are UNICODE, then tell Tux this by setting the following flag.
#ifdef UNICODE
((LPSPS_LOAD_DLL)spParam)->fUnicode = TRUE;
#endif // UNICODE
g_pKato = (CKato*)KatoGetDefaultObject();
break;
case SPM_UNLOAD_DLL:
// Sent once to the DLL immediately before it is unloaded.
Debug(TEXT("ShellProc(SPM_UNLOAD_DLL, ...) called"));
//--------------------------------------
// Added To Framework Program
//--------------------------------------
FinishTests();
break;
case SPM_SHELL_INFO:
// Sent once to the DLL immediately after SPM_LOAD_DLL to give the DLL
// some useful information about its parent shell and environment. The
// spParam parameter will contain a pointer to a SPS_SHELL_INFO
// structure. The pointer to the structure may be stored for later use
// as it will remain valid for the life of this Tux Dll. The DLL may
// return SPR_FAIL to prevent the DLL from continuing to load.
Debug(TEXT("ShellProc(SPM_SHELL_INFO, ...) called"));
// Store a pointer to our shell info for later use.
g_pShellInfo = (LPSPS_SHELL_INFO)spParam;
break;
case SPM_REGISTER:
// This is the only ShellProc() message that a DLL is required to
// handle (except for SPM_LOAD_DLL if you are UNICODE). This message is
// sent once to the DLL immediately after the SPM_SHELL_INFO message to
// query the DLL for its function table. The spParam will contain a
// pointer to a SPS_REGISTER structure. The DLL should store its
// function table in the lpFunctionTable member of the SPS_REGISTER
// structure. The DLL may return SPR_FAIL to prevent the DLL from
// continuing to load.
Debug(TEXT("ShellProc(SPM_REGISTER, ...) called"));
((LPSPS_REGISTER)spParam)->lpFunctionTable = g_lpFTE;
#ifdef UNICODE
return SPR_HANDLED | SPF_UNICODE;
#else // UNICODE
return SPR_HANDLED;
#endif // UNICODE
case SPM_START_SCRIPT:
// Sent to the DLL immediately before a script is started. It is sent
// to all Tux DLLs, including loaded Tux DLLs that are not in the
// script. All DLLs will receive this message before the first
// TestProc() in the script is called.
Debug(TEXT("ShellProc(SPM_START_SCRIPT, ...) called"));
break;
case SPM_STOP_SCRIPT:
// Sent to the DLL when the script has stopped. This message is sent
// when the script reaches its end, or because the user pressed
// stopped prior to the end of the script. This message is sent to
// all Tux DLLs, including loaded Tux DLLs that are not in the script.
Debug(TEXT("ShellProc(SPM_STOP_SCRIPT, ...) called"));
break;
case SPM_BEGIN_GROUP:
// Sent to the DLL before a group of tests from that DLL is about to
// be executed. This gives the DLL a time to initialize or allocate
// data for the tests to follow. Only the DLL that is next to run
// receives this message. The prior DLL, if any, will first receive
// a SPM_END_GROUP message. For global initialization and
// de-initialization, the DLL should probably use SPM_START_SCRIPT
// and SPM_STOP_SCRIPT, or even SPM_LOAD_DLL and SPM_UNLOAD_DLL.
Debug(TEXT("ShellProc(SPM_BEGIN_GROUP, ...) called"));
g_pKato->BeginLevel(0, TEXT("BEGIN GROUP: CSPILoopBack.DLL"));
break;
case SPM_END_GROUP:
// Sent to the DLL after a group of tests from that DLL has completed
// running. This gives the DLL a time to cleanup after it has been
// run. This message does not mean that the DLL will not be called
// again; it just means that the next test to run belongs to a
// different DLL. SPM_BEGIN_GROUP and SPM_END_GROUP allow the DLL
// to track when it is active and when it is not active.
Debug(TEXT("ShellProc(SPM_END_GROUP, ...) called"));
g_pKato->EndLevel(TEXT("END GROUP: CSPILoopBack.DLL"));
break;
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -