📄 csl_pwrdwnhwsetupraw.c
字号:
/* ============================================================================
* Copyright (c) Texas Instruments Inc 2002, 2003, 2004, 2005
*
* Use of this software is controlled by the terms and conditions found in the
* license agreement under which this software has been supplied.
* ============================================================================
*/
/** ===========================================================================
* @file csl_pwrdwnHwSetupRaw.c
*
* @brief File for functional layer of CSL API @a CSL_pwrdwnHwSetupRaw()
*
* PATH \\(CSLPATH)\\ipmodules\\pwrdwn\\src
*
* Description
* - The @a CSL_pwrdwnHwSetupRaw() function definition & it's associated
* functions
*
* Modification 1
* - Modified on: 7/16/2004
* - Reason: created the sources
*
* @author Ruchika Kharwar.
* ============================================================================
*/
#include <csl_pwrdwn.h>
/** ===========================================================================
* @n@b CSL_pwrdwnHwSetupRaw
*
* @b Description
* @n This function initializes the device registers with the register-values
* provided through the config data structure.
*
* @b Arguments
* @verbatim
hPwrdwn Pointer to the object that holds reference to the
instance of PWRDWN requested after the call
config Pointer to the config structure containing the
device register values
@endverbatim
*
* <b> Return Value </b> CSL_Status
* @li CSL_SOK - Configuration successful
* @li CSL_ESYS_BADHANDLE - Invalid handle
* @li CSL_ESYS_INVPARAMS - Configuration structure
* pointer is not properly
* initialized
*
* <b> Pre Condition </b>
* @n CSL_pwrdwnInit(), CSL_pwrdwnOpen() must be opened prior to this call
*
* <b> Post Condition </b>
* @n The registers of the specified General purpose timer instance will be setup
* according to the values passed through the config structure
*
* @b Modifies
* @n Hardware registers of the specified General purpose timer instance
*
* @b Example
@verbatim
CSL_PwrdwnObj pwrObj;
CSL_PwrdwnConfig pwrConfig;
CSL_PwrdwnHandle hPwr;
// Init Module
...
if (CSL_pwrdwnInit(NULL) != CSL_SOK)
exit;
// Opening a handle for the Module
hPwr = CSL_pwrdwnOpen (&pwrObj, CSL_PWRDWN_0, NULL, NULL);
// Setup the arguments for the Config structure
...
// Setup
CSL_pwrdwnHwSetupRaw(hPwr,&pwrConfig);
// Close handle
CSL_pwrdwnClose(hPwr);
@endverbatim
* ============================================================================
*/
#pragma CODE_SECTION (CSL_pwrdwnHwSetupRaw, ".text:csl_section:pwrdwn");
CSL_Status CSL_pwrdwnHwSetupRaw(
/** Pointer to the object that holds reference to the
* instance of PWRDWN requested after the call
*/
CSL_PwrdwnHandle hPwrdwn,
/** Pointer to config structure which contains the
* register values to program PWRDWN to a useful state
*/
CSL_PwrdwnConfig *config
)
{
hPwrdwn->pdcRegs->PDCCMD = config->PDCCMD;
hPwrdwn->l2pwrdwnRegs->L2PDAEN[0] = config->L2PDAEN_UMAP0;
hPwrdwn->l2pwrdwnRegs->L2PDAEN[1] = config->L2PDAEN_UMAP1;
hPwrdwn->l2pwrdwnRegs->L2PDAPS[0] = config->L2PDAPS_UMAP0;
hPwrdwn->l2pwrdwnRegs->L2PDAPS[1] = config->L2PDAPS_UMAP1;
hPwrdwn->l2pwrdwnRegs->L2PDAP = config->L2PDAP;
hPwrdwn->l2pwrdwnRegs->L2PDWAKE[0] = config->L2PDWAKE_UMAP0;
hPwrdwn->l2pwrdwnRegs->L2PDWAKE[1] = config->L2PDWAKE_UMAP1;
hPwrdwn->l2pwrdwnRegs->L2PDSLEEP[0] = config->L2PDSLEEP_UMAP0;
hPwrdwn->l2pwrdwnRegs->L2PDSLEEP[1] = config->L2PDSLEEP_UMAP1;
return CSL_SOK;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -