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

📄 csl_i2chwsetupraw.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_i2cHwSetupRaw.c * *  @brief File for functional layer of CSL API @a CSL_i2cHwSetupRaw() * *  Description *    - The @a CSL_i2cHwSetupRaw() function definition & it's associated *      functions * *  PATH  \\(CSLPATH)\\ipmodules\\i2c\\src * *  Modification 1 *    - Modified on: 28/5/2004 *    - Reason: created the sources * *  Date 28th May, 2004 *  Author Santosh Narayanan. * *//* ============================================================================= *  Revision History *  =============== *  11-oct-2004 Hs updated code according to code review comments. *  01-Sep-2004 Hs File Created. * ============================================================================= */#include <csl_i2c.h>/** ============================================================================ *   @n@b CSL_i2cHwSetupRaw * *   @b Description *   @n This function initializes the device registers with the register-values *      provided through the Config Data structure. * *   @b Arguments *   @verbatim            hI2c            Handle to the I2C            config          Pointer to config structure     @endverbatim * *   <b> Return Value </b>  CSL_Status *   @li                    CSL_SOK             - Configuration successful *   @li                    CSL_ESYS_BADHANDLE  - Invalid handle *   @li                    CSL_ESYS_INVPARAMS  - Configuration is not *                                                properly initialized * *   @n Both @a CSL_i2cInit() and @a CSL_i2cOpen() must be called successfully *      in that order before @a CSL_i2cHwSetupRaw() can be called. * *   <b> Post Condition </b> *   @n  The registers of the specified I2C instance will be setup *       according to value passed. * *   @b Modifies *   @n Hardware registers of the specified I2C instance. * *   @b Example *   @verbatim        CSL_I2cHandle       hI2c;        CSL_I2cConfig       config = CSL_I2C_CONFIG_DEFAULTS;        CSL_Status          status;        status = CSL_i2cHwSetupRaw (hI2c, &config);     @endverbatim *  ============================================================================ */#pragma CODE_SECTION (CSL_i2cHwSetupRaw, ".text:csl_section:i2c");CSL_Status CSL_i2cHwSetupRaw (    CSL_I2cHandle               hI2c,    CSL_I2cConfig              *config){    if (hI2c == NULL) {        return CSL_ESYS_BADHANDLE;    }    if (config == NULL ) {        return CSL_ESYS_INVPARAMS;    }    hI2c->regs->ICOAR   = config->ICOAR;    hI2c->regs->ICIMR   = config->ICIMR;    hI2c->regs->ICSTR   = config->ICSTR;    hI2c->regs->ICCLKL  = config->ICCLKL;    hI2c->regs->ICCLKH  = config->ICCLKH;    hI2c->regs->ICCNT   = config->ICCNT;    hI2c->regs->ICSAR   = config->ICSAR;    hI2c->regs->ICDXR   = config->ICDXR;    hI2c->regs->ICMDR   = config->ICMDR;    hI2c->regs->ICIVR   = config->ICIVR;    /* hI2c->regs->ICEMDR  = config->ICEMDR;     */    hI2c->regs->ICPSC   = config->ICPSC;    hI2c->regs->ICPFUNC = config->ICPFUNC;    hI2c->regs->ICPDIR  = config->ICPDIR;    hI2c->regs->ICPDOUT = config->ICPDOUT;    hI2c->regs->ICPDSET = config->ICPDSET;    hI2c->regs->ICPDCLR = config->ICPDCLR;    return CSL_SOK;}

⌨️ 快捷键说明

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