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

📄 i2c_export.h

📁 MPC8241:本程序是freescale的824*系列的BSP源程序
💻 H
字号:
#ifndef I2C_EXPORT_H#define I2C_EXPORT_H/*************************************************************************** *     Copyright Motorola, Inc. 1989-2001 ALL RIGHTS RESERVED * *  $ID:$ * * You are hereby granted a copyright license to use, modify, and * distribute the SOFTWARE, also know as DINK32 (Dynamic Interactive Nano  * Kernel for 32-bit processors) solely in conjunction with the development  * and marketing of your products which use and incorporate microprocessors  * which implement the PowerPC(TM) architecture manufactured by  * Motorola and provided you comply with all of the following restrictions  * i) this entire notice is retained without alteration in any * modified and/or redistributed versions, and  * ii) that such modified versions are clearly identified as such.  * No licenses are granted by implication, estoppel or * otherwise under any patents or trademarks of Motorola, Inc. *  * The SOFTWARE is provided on an "AS IS" basis and without warranty. To * the maximum extent permitted by applicable law, MOTOROLA DISCLAIMS ALL * WARRANTIES WHETHER EXPRESS OR IMPLIED, INCLUDING IMPLIED WARRANTIES OF * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE AND ANY WARRANTY  * AGAINST INFRINGEMENT WITH REGARD TO THE SOFTWARE  * (INCLUDING ANY MODIFIED VERSIONS THEREOF) AND ANY ACCOMPANYING  * WRITTEN MATERIALS. *  * To the maximum extent permitted by applicable law, IN NO EVENT SHALL * MOTOROLA BE LIABLE FOR ANY DAMAGES WHATSOEVER (INCLUDING WITHOUT  * LIMITATION, DAMAGES FOR LOSS OF BUSINESS PROFITS, BUSINESS  * INTERRUPTION, LOSS OF BUSINESS INFORMATION, * OR OTHER PECUNIARY LOSS) ARISING OF THE USE OR INABILITY TO USE THE * SOFTWARE. * Motorola assumes no responsibility for the maintenance and support of * the SOFTWARE. ************************************************************************//* These are the defined return values for the I2C_do_transaction function. * Any non-zero value indicates failure.  Failure modes can be added for  * more detailed error reporting. */typedef enum _i2c_status{ I2C_SUCCESS     = 0, I2C_ERROR,} I2C_Status;/* These are the defined tasks for I2C_do_transaction. * Modes for SLAVE_RCV and SLAVE_XMIT will be added. */typedef enum _i2c_transaction_mode{	I2C_MASTER_RCV =  0,	I2C_MASTER_XMIT = 1,} I2C_TRANSACTION_MODE;typedef enum _i2c_interrupt_mode{	I2C_INT_DISABLE =  0,	I2C_INT_ENABLE = 1,} I2C_INTERRUPT_MODE;typedef enum _i2c_stop{	I2C_NO_STOP =  0,	I2C_STOP = 1,} I2C_STOP_MODE;typedef enum _i2c_restart{	I2C_NO_RESTART =  0,	I2C_RESTART = 1,} I2C_RESTART_MODE;/******************** App. API ******************** * The application API is for user level application  * to use the functionality provided by I2C driver. * This is a "generic" I2C interface, it should contain * nothing specific to the Kahlua implementation. * Only the generic functions are exported by the library. *  * Note: Its App.s responsibility to swap the data *       byte. In our API, we just transfer whatever *       we are given **************************************************//*  Initialize I2C unit with the following: *  driver's slave address  *  interrupt enabled *  optional pointer to application layer print function * *  These parameters may be added: *  desired clock rate *  digital filter frequency sampling rate * *  This function must be called before I2C unit can be used. */extern I2C_Status I2C_Initialize( 	unsigned char addr,            /* driver's I2C slave address */	I2C_INTERRUPT_MODE en_int,     /* 1 - enable I2C interrupt 	                                * 0 - disable I2C interrupt	                                */        int (*app_print_function)(char *,...)); /* pointer to optional "printf"                                                 * provided by application                                                 *//* Perform the given I2C transaction, only MASTER_XMIT and MASTER_RCV * are implemented.  Both are only in polling mode. *  * en_int controls interrupt/polling mode * act is the type of transaction * addr is the I2C address of the slave device * len is the length of data to send or receive * buffer is the address of the data buffer * stop = I2C_NO_STOP, don't signal STOP at end of transaction *        I2C_STOP, signal STOP at end of transaction * retry is the timeout retry value, currently ignored * rsta = I2C_NO_RESTART, this is not continuation of existing transaction *        I2C_RESTART, this is a continuation of existing transaction */extern I2C_Status I2C_do_transaction( I2C_INTERRUPT_MODE en_int,                                      I2C_TRANSACTION_MODE act,                                      unsigned char i2c_addr,                                      unsigned char data_addr,                                      int len,                                      char *buffer,                                      I2C_STOP_MODE stop,                                      int retry,                                      I2C_RESTART_MODE rsta);#endif

⌨️ 快捷键说明

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