mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2026-06-18 11:42:23 +08:00
Create a driver diectory
Add I2C driver and a 24LC024H i2c eeprom usage example Now only support I2C1, not yet fully support I2C2 ****GPIO Config**** I2C1 SDA -> PB8 I2C1 SCL -> PB9 git-svn-id: https://rt-thread.googlecode.com/svn/trunk@1716 bbd45198-f89e-11dd-88c7-29a3b14d5316
This commit is contained in:
@@ -0,0 +1,153 @@
|
||||
#include <rtthread.h>
|
||||
#include "i2c.h"
|
||||
|
||||
#define EE_Address 0xA0
|
||||
|
||||
#define EE24LC024H
|
||||
|
||||
/*
|
||||
Note: If eeprom size lager then 256 byte, you must define EE_ADDR_SIZE == I2C_MEM_2Bytes
|
||||
*/
|
||||
#ifdef EE24LC024H
|
||||
#define EE_PageSize 8
|
||||
#define EE_ADDR_SIZE I2C_MEM_1Byte
|
||||
#define EE_MEM_SIZE 256
|
||||
#define EE_PageSize 16
|
||||
#endif
|
||||
|
||||
static struct rt_device ee_dev;
|
||||
|
||||
uint32_t EE_ReadBuffer(uint8_t* pBuffer, uint16_t ReadAddr, uint16_t NumByteToRead)
|
||||
{
|
||||
return I2C_IORW(I2C1, pBuffer, NumByteToRead, ReadAddr, EE_Address | 0x01, I2C_MEM_1Byte );
|
||||
}
|
||||
|
||||
uint32_t EE_WritePage(uint8_t* pBuffer, uint16_t WriteAddr)
|
||||
{
|
||||
I2C_IORW(I2C1, pBuffer, EE_PageSize , WriteAddr, EE_Address , EE_ADDR_SIZE );
|
||||
|
||||
/*if( I2C_AcknowledgePolling(I2C1 , EE_Address) == Error )
|
||||
rt_kprintf("EE ACK failed\n");*/
|
||||
rt_thread_delay(50);
|
||||
}
|
||||
uint32_t EE_WriteByte(uint8_t* pBuffer, uint16_t WriteAddr)
|
||||
{
|
||||
I2C_IORW(I2C1, pBuffer, 1 , WriteAddr, EE_Address, EE_ADDR_SIZE );
|
||||
|
||||
/*if( I2C_AcknowledgePolling(I2C1 , EE_Address) == Error )
|
||||
rt_kprintf("EE ACK failed\n");*/
|
||||
rt_thread_delay(50);
|
||||
}
|
||||
|
||||
Status EE_WriteBuffer(uint8_t* pBuffer, uint16_t WriteAddr, uint16_t NumByteToWrite)
|
||||
{
|
||||
uint8_t NumOfPage = 0, NumOfSingle = 0;
|
||||
uint16_t Addr = 0,count = 0;
|
||||
uint8_t* ptr = pBuffer;
|
||||
|
||||
Addr = WriteAddr;
|
||||
|
||||
count = NumByteToWrite;
|
||||
|
||||
if( (WriteAddr + NumByteToWrite ) > EE_MEM_SIZE )
|
||||
return Error;
|
||||
|
||||
while( count >= EE_PageSize )
|
||||
{
|
||||
EE_WritePage(ptr, Addr);
|
||||
Addr += EE_PageSize;
|
||||
count -= EE_PageSize;
|
||||
ptr += EE_PageSize;
|
||||
}
|
||||
|
||||
while( count )
|
||||
{
|
||||
EE_WriteByte( ptr++, Addr++ );
|
||||
count--;
|
||||
}
|
||||
|
||||
return Success;
|
||||
|
||||
}
|
||||
|
||||
static rt_err_t ee24LCxx_init (rt_device_t dev)
|
||||
{
|
||||
return RT_EOK;
|
||||
}
|
||||
static rt_size_t ee24LCxx_read( rt_device_t dev, rt_off_t pos, void *buf, rt_size_t size )
|
||||
{
|
||||
if( EE_ReadBuffer(buf, pos, size) == Success )
|
||||
return size;
|
||||
else
|
||||
return -1;
|
||||
}
|
||||
|
||||
static rt_size_t ee24LCxx_write( rt_device_t dev, rt_off_t pos, void *buf, rt_size_t size )
|
||||
{
|
||||
if( EE_WriteBuffer(buf, pos, size) == Success )
|
||||
return size;
|
||||
else
|
||||
return -1;
|
||||
}
|
||||
|
||||
static rt_err_t ee24LCxx_open(rt_device_t dev, rt_uint16_t oflag)
|
||||
{
|
||||
return RT_EOK;
|
||||
}
|
||||
|
||||
static rt_err_t ee24LCxx_close(rt_device_t dev)
|
||||
{
|
||||
return RT_EOK;
|
||||
}
|
||||
|
||||
static rt_err_t ee24LCxx_control (rt_device_t dev, rt_uint8_t cmd, void *args)
|
||||
{
|
||||
return RT_EOK;
|
||||
}
|
||||
|
||||
void ee24LCxx_hw_init()
|
||||
{
|
||||
I2C1_INIT();
|
||||
|
||||
ee_dev.init = ee24LCxx_init;
|
||||
ee_dev.open = ee24LCxx_open;
|
||||
ee_dev.close = ee24LCxx_close;
|
||||
ee_dev.read = ee24LCxx_read;
|
||||
ee_dev.write = ee24LCxx_write;
|
||||
ee_dev.control = ee24LCxx_control;
|
||||
ee_dev.type = RT_Device_Class_I2C;
|
||||
|
||||
|
||||
rt_device_register(&ee_dev, "eeprom", RT_DEVICE_FLAG_RDWR);
|
||||
}
|
||||
|
||||
void ee_test()
|
||||
{
|
||||
char buf[256], read[256];
|
||||
int i,ret;
|
||||
|
||||
rt_device_t dev;
|
||||
dev = rt_device_find("eeprom");
|
||||
|
||||
for(i = 0; i < 256; i++ )
|
||||
{
|
||||
buf[i] = i;
|
||||
read[i] = 0;
|
||||
}
|
||||
if( rt_device_write(dev, 0, buf, 256 ) == 256 )
|
||||
rt_kprintf("Write Success\n");
|
||||
|
||||
rt_device_read(dev, 0, read, 256 );
|
||||
|
||||
for(i = 0; i < 256; i++ )
|
||||
{
|
||||
if( buf[i] != read[i] )
|
||||
rt_kprintf("EE Failed %X != %X at %d\n", buf[i], read[i], i);
|
||||
}
|
||||
rt_kprintf("Finsh\n");
|
||||
|
||||
}
|
||||
#ifdef RT_USING_FINSH
|
||||
#include <finsh.h>
|
||||
FINSH_FUNCTION_EXPORT(ee_test, test system);
|
||||
#endif
|
||||
File diff suppressed because it is too large
Load Diff
@@ -0,0 +1,137 @@
|
||||
#ifndef I2C_H
|
||||
#define I2C_H
|
||||
|
||||
#include "stm32f2xx.h"
|
||||
|
||||
/* Exported constants --------------------------------------------------------*/
|
||||
|
||||
#define SR1_AF_Set ((uint16_t)0x0400)
|
||||
#define SR1_ARLO_Set ((uint16_t)0x0200)
|
||||
#define SR1_BERR_Set ((uint16_t)0x0100)
|
||||
#define SR1_ADDR_Set ((uint16_t)0x0002)
|
||||
#define SR1_SB_Set ((uint16_t)0x0001)
|
||||
|
||||
|
||||
#define SR2_BUSY ((uint16_t)0x0002)
|
||||
#define SR2_MSL ((uint16_t)0x0001)
|
||||
|
||||
#define CR1_SWRST_Set ((uint16_t)0x8000)
|
||||
/* I2C SPE mask */
|
||||
#define CR1_PE_Set ((uint16_t)0x0001)
|
||||
#define CR1_PE_Reset ((uint16_t)0xFFFE)
|
||||
|
||||
/* I2C START mask */
|
||||
#define CR1_START_Set ((uint16_t)0x0100)
|
||||
#define CR1_START_Reset ((uint16_t)0xFEFF)
|
||||
|
||||
#define CR1_POS_Set ((uint16_t)0x0800)
|
||||
#define CR1_POS_Reset ((uint16_t)0xF7FF)
|
||||
|
||||
/* I2C STOP mask */
|
||||
#define CR1_STOP_Set ((uint16_t)0x0200)
|
||||
#define CR1_STOP_Reset ((uint16_t)0xFDFF)
|
||||
|
||||
/* I2C ACK mask */
|
||||
#define CR1_ACK_Set ((uint16_t)0x0400)
|
||||
#define CR1_ACK_Reset ((uint16_t)0xFBFF)
|
||||
|
||||
/* I2C ENARP mask */
|
||||
#define CR1_ENARP_Set ((uint16_t)0x0010)
|
||||
#define CR1_ENARP_Reset ((uint16_t)0xFFEF)
|
||||
|
||||
/* I2C NOSTRETCH mask */
|
||||
#define CR1_NOSTRETCH_Set ((uint16_t)0x0080)
|
||||
#define CR1_NOSTRETCH_Reset ((uint16_t)0xFF7F)
|
||||
|
||||
/* I2C registers Masks */
|
||||
#define CR1_CLEAR_Mask ((uint16_t)0xFBF5)
|
||||
|
||||
/* I2C DMAEN mask */
|
||||
#define CR2_DMAEN_Set ((uint16_t)0x0800)
|
||||
#define CR2_DMAEN_Reset ((uint16_t)0xF7FF)
|
||||
|
||||
/* I2C LAST mask */
|
||||
#define CR2_LAST_Set ((uint16_t)0x1000)
|
||||
#define CR2_LAST_Reset ((uint16_t)0xEFFF)
|
||||
|
||||
/* I2C FREQ mask */
|
||||
#define CR2_FREQ_Reset ((uint16_t)0xFFC0)
|
||||
|
||||
/* I2C ADD0 mask */
|
||||
#define OAR1_ADD0_Set ((uint16_t)0x0001)
|
||||
#define OAR1_ADD0_Reset ((uint16_t)0xFFFE)
|
||||
|
||||
/* I2C ENDUAL mask */
|
||||
#define OAR2_ENDUAL_Set ((uint16_t)0x0001)
|
||||
#define OAR2_ENDUAL_Reset ((uint16_t)0xFFFE)
|
||||
|
||||
/* I2C ADD2 mask */
|
||||
#define OAR2_ADD2_Reset ((uint16_t)0xFF01)
|
||||
|
||||
/* I2C F/S mask */
|
||||
#define CCR_FS_Set ((uint16_t)0x8000)
|
||||
|
||||
/* I2C CCR mask */
|
||||
#define CCR_CCR_Set ((uint16_t)0x0FFF)
|
||||
|
||||
/* I2C FLAG mask */
|
||||
#define FLAG_Mask ((uint32_t)0x00FFFFFF)
|
||||
|
||||
/* I2C Interrupt Enable mask */
|
||||
#define ITEN_Mask ((uint32_t)0x07000000)
|
||||
|
||||
|
||||
#define I2C_IT_BUF ((uint16_t)0x0400)
|
||||
#define I2C_IT_EVT ((uint16_t)0x0200)
|
||||
#define I2C_IT_ERR ((uint16_t)0x0100)
|
||||
|
||||
|
||||
#define ClockSpeed 400000
|
||||
|
||||
#define I2C_DIRECTION_TX 0
|
||||
#define I2C_DIRECTION_RX 1
|
||||
|
||||
#define OwnAddress1 0x28
|
||||
#define OwnAddress2 0x30
|
||||
|
||||
|
||||
#define I2C1_DMA_CHANNEL_TX DMA1_Stream6
|
||||
#define I2C1_DMA_CHANNEL_RX DMA1_Stream0
|
||||
#define I2C1_DMA_TX_IRQn DMA1_Stream6_IRQn
|
||||
#define I2C1_DMA_RX_IRQn DMA1_Stream0_IRQn
|
||||
|
||||
#define I2C2_DMA_CHANNEL_TX DMA1_Stream2
|
||||
#define I2C2_DMA_CHANNEL_RX DMA1_Stream7
|
||||
|
||||
#define I2C1_DR_Address 0x40005410
|
||||
#define I2C2_DR_Address 0x40005810
|
||||
|
||||
#define I2C1_SDA_PIN GPIO_Pin_9
|
||||
#define I2C1_SCL_PIN GPIO_Pin_8
|
||||
#define I2C1_SDA_SOURCE GPIO_PinSource9
|
||||
#define I2C1_SCL_SOURCE GPIO_PinSource8
|
||||
#define I2C1_GPIO_PORT GPIOB
|
||||
#define I2C1_GPIO_CLK RCC_AHB1Periph_GPIOB
|
||||
#define I2C1_CLK RCC_APB1Periph_I2C1
|
||||
|
||||
#define I2C_MEM_1Byte 1
|
||||
#define I2C_MEM_2Bytes 2
|
||||
|
||||
typedef enum
|
||||
{
|
||||
Error = 0,
|
||||
Success = !Error
|
||||
}Status;
|
||||
|
||||
typedef enum
|
||||
{
|
||||
Polling = 0x00,
|
||||
Interrupt = 0x01,
|
||||
DMA = 0x02
|
||||
} I2C_ProgrammingModel;
|
||||
|
||||
void I2C1_INIT();
|
||||
Status I2C_AcknowledgePolling(I2C_TypeDef* I2Cx ,uint8_t Addr);
|
||||
Status I2C_IORW(I2C_TypeDef* I2Cx, uint8_t* pBuffer, uint32_t NumByteToRead, uint16_t memAddr, uint8_t SlaveAddress , uint8_t MemType );
|
||||
|
||||
#endif
|
||||
Reference in New Issue
Block a user