⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 csl_i2cgetbaseaddress.c

📁 TI达芬奇dm644x各硬件模块测试代码
💻 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_i2cGetBaseAddress.c * *  @brief File for functional layer of CSL API @a CSL_i2cGetBaseAddress() * *  Description *    - The @a CSL_i2cGetBaseAddress() function definition & it's associated *      functions * *//*  ============================================================================ *  Revision History *  =============== *  11-oct-2004 Hs updated according to code review comments. *  31-aug-2004 Hs File Created. *  ============================================================================ */#include <csl_i2c.h>/** ============================================================================ *   @n@b CSL_i2cGetBaseAddress * *   @b Description *   @n  Function to get the base address of the peripheral instance. *       This function is used for getting the base address of the peripheral *       instance. This function will be called inside the CSL_i2cOpen() *       function call. This function is open for re-implementing if the user *       wants to modify the base address of the peripheral object to point to *       a different location and there by allow CSL initiated write/reads into *       peripheral. MMR's go to an alternate location. * *   @b Arguments *   @verbatim            i2cNum        Specifies the instance of the I2C to be opened.            pI2cParam     Module specific parameters.            pBaseAddress  Pointer to baseaddress structure containing base                          address details.     @endverbatim * *   <b> Return Value </b>  CSL_Status *   @li                    CSL_OK            Open call is successful *   @li                    CSL_ESYS_FAIL     The instance number is invalid. * *   <b> Pre Condition </b> *   @n  None * *   <b> Post Condition </b> *   @n  Base Address structure is populated * *   @b Modifies *   @n    1. The status variable * *         2. Base address structure is modified. * *   @b Example *   @verbatim        CSL_Status          status;        CSL_I2cBaseAddress  baseAddress;       ...      status = CSL_i2cGetBaseAddress(CSL_I2C_PER_CNT, NULL, &baseAddress);    @endverbatim * =========================================================================== */#pragma CODE_SECTION (CSL_i2cGetBaseAddress, ".text:csl_section:i2c");CSL_Status CSL_i2cGetBaseAddress (    CSL_InstNum                     i2cNum,    CSL_I2cParam                   *pI2cParam,    CSL_I2cBaseAddress             *pBaseAddress){    CSL_Status status = CSL_SOK;    pI2cParam = pI2cParam; /* To avoid compiler warning/remark */    /* Added according to review comment 2. */    if(pBaseAddress == NULL) {        status = CSL_ESYS_INVPARAMS;    }    switch (i2cNum) {        case CSL_I2C:            pBaseAddress->regs = (CSL_I2cRegsOvly)CSL_I2C_1_REGS;            break;        default:            pBaseAddress->regs = NULL;            status = CSL_ESYS_FAIL;    }    return status;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -