STM32 IIC总线编程实践与参考

版权申诉
0 下载量 93 浏览量 更新于2024-10-19 收藏 2KB ZIP 举报
资源摘要信息:"关于STM32 IIC总线编程的学习资料" 知识点一: STM32 IIC总线概述 IIC(Inter-Integrated Circuit)总线,又称I2C总线,是一种多主机、多从机的串行通讯总线。STM32是一种广泛使用的32位ARM Cortex-M微控制器系列,由意法半导体(STMicroelectronics)生产。STM32微控制器中集成了IIC接口,使得设备能够通过I2C总线与其他I2C设备进行通讯。 知识点二: STM32 IIC总线特性 STM32的IIC接口具备多种特性,包括: 1. 支持多种通讯速率:标准模式(100 kbit/s)、快速模式(400 kbit/s)以及快速模式Plus(1 Mbit/s)。 2. 主机与从机功能:STM32可以作为I2C主机发送数据或命令,也可以作为从机响应主机请求。 3. 多主机模式:在总线空闲时,STM32可以尝试成为主机。 4. 总线冲突检测:STM32能够在I2C总线上进行冲突检测,以避免数据损坏。 5. DMA支持:可以使用直接存储器访问(DMA)进行数据传输,减少CPU的负担。 知识点三: STM32 IIC总线编程 在STM32中进行IIC编程,通常涉及以下几个步骤: 1. 初始化IIC接口:配置IIC工作模式、时钟速度、地址模式、主机/从机选择等参数。 2. 读写数据:实现数据的发送和接收,包括启动信号、停止信号、应答位的处理。 3. 错误处理:检测和处理通讯过程中的各种错误,如总线繁忙、总线错误、仲裁丢失等。 4. 中断或轮询:数据传输可以通过中断驱动或轮询方式进行。 知识点四: myiic.c和myiic.h文件分析 1. myiic.c文件: - myiic.c文件通常是STM32 IIC接口的驱动程序实现文件,包含了IIC通讯所需的各种功能函数。 - 这个文件可能包含函数用于初始化IIC接口(如I2C_Init)。 - 还可能包含用于发送(如I2C_Transmit)和接收(如I2C_Receive)数据的函数。 - 可能包含对中断服务例程(ISR)的处理,例如响应I2C事件的中断处理函数。 - 也可能会有错误检测与处理机制的相关函数实现。 2. myiic.h文件: - myiic.h是myiic.c文件对应的头文件,包含了驱动程序中函数的声明,以及IIC接口相关的宏定义。 - 这个文件可能包含IIC接口初始化的宏定义,如设置工作模式、时钟速度等。 - 定义了IIC通讯中用到的数据结构和常量,例如地址模式、数据长度等。 - 包含了myiic.c中所有函数的函数原型声明,供其他源文件调用。 知识点五: IIC总线编程实例 以下为一个简化的IIC总线编程流程: 1. 配置IIC接口: - 初始化IIC时钟。 - 配置GPIO引脚为开漏输出模式并设置为复用功能。 - 设置IIC时钟速率(例如在快速模式下设置为400 kHz)。 - 使能IIC接口。 2. 发送数据: - 设置要通信的从机地址和数据方向(读或写)。 - 启动IIC传输。 - 发送数据字节,等待应答。 - 如果需要,发送更多的数据字节。 - 停止IIC传输。 3. 接收数据: - 设置要通信的从机地址和数据方向(读)。 - 启动IIC传输。 - 请求数据字节并发送应答。 - 如果需要,读取更多的数据字节并发送应答或非应答。 - 停止IIC传输。 4. 错误处理: - 检测并处理总线错误、仲裁丢失等。 - 在出现错误时进行适当的恢复操作。 知识点六: IIC通讯在嵌入式系统中的应用 IIC总线广泛应用于嵌入式系统中,连接诸如传感器、EEPROM、实时钟、LCD显示器、电源管理芯片等外围设备。STM32通过IIC总线与这些设备进行高效、低引脚数的通信,节省了微控制器的I/O资源。在设计时,工程师们通常会根据实际应用的性能需求,选择适当的通讯速率和工作模式,以达到系统性能和功耗的最佳平衡。

帮我改进一这段代码import machine import time from machine import I2C from machine import Pin from machine import sleep class accel(): def __init__(self, i2c, addr=0x68): self.iic = i2c self.addr = addr self.iic.start() self.iic.writeto(self.addr, bytearray([107, 0])) self.iic.stop() def get_raw_values(self): self.iic.start() a = self.iic.readfrom_mem(self.addr, 0x3B, 14) self.iic.stop() return a def get_ints(self): b = self.get_raw_values() c = [] for i in b: c.append(i) return c def bytes_toint(self, firstbyte, secondbyte): if not firstbyte & 0x80: return firstbyte << 8 | secondbyte return - (((firstbyte ^ 255) << 8) | (secondbyte ^ 255) + 1) def get_values(self): raw_ints = self.get_raw_values() vals = {} vals["AcX"] = self.bytes_toint(raw_ints[0], raw_ints[1]) vals["AcY"] = self.bytes_toint(raw_ints[2], raw_ints[3]) vals["AcZ"] = self.bytes_toint(raw_ints[4], raw_ints[5]) vals["Tmp"] = self.bytes_toint(raw_ints[6], raw_ints[7]) / 340.00 + 36.53 vals["GyX"] = self.bytes_toint(raw_ints[8], raw_ints[9]) vals["GyY"] = self.bytes_toint(raw_ints[10], raw_ints[11]) vals["GyZ"] = self.bytes_toint(raw_ints[12], raw_ints[13]) return vals # returned in range of Int16 # -32768 to 32767 def val_test(self): # ONLY FOR TESTING! Also, fast reading sometimes crashes IIC from time import sleep while 1: print(self.get_values()) sleep(0.05) clk = Pin(("clk", 36), Pin.OUT_OD) sda = Pin(("sda", 37), Pin.OUT_OD) i2c = I2C(-1, clk, sda, freq=100000) #initializing the I2C method for ESP32 #i2c = I2C(scl=Pin(5), sda=Pin(4)) #initializing the I2C method for ESP8266 mpu= accel(i2c) while True: mpu.get_values() print(mpu.get_values()) time.sleep(2)

2023-05-30 上传
2023-05-30 上传

一句句的解释void Write_IIC_Byte(unsigned char IIC_Byte) { unsigned char i; unsigned char m,da; da=IIC_Byte; OLED_SCLK_Clr(); for(i=0;i<8;i++) { m=da; // OLED_SCLK_Clr(); m=m&0x80; if(m==0x80) {OLED_SDIN_Set();} else OLED_SDIN_Clr(); da=da<<1; OLED_SCLK_Set(); OLED_SCLK_Clr(); } } /********************************************** // IIC Write Command **********************************************/ void Write_IIC_Command(unsigned char IIC_Command) { IIC_Start(); Write_IIC_Byte(0x78); //Slave address,SA0=0 IIC_Wait_Ack(); Write_IIC_Byte(0x00); //write command IIC_Wait_Ack(); Write_IIC_Byte(IIC_Command); IIC_Wait_Ack(); IIC_Stop(); } /********************************************** // IIC Write Data **********************************************/ void Write_IIC_Data(unsigned char IIC_Data) { IIC_Start(); Write_IIC_Byte(0x78); //D/C#=0; R/W#=0 IIC_Wait_Ack(); Write_IIC_Byte(0x40); //write data IIC_Wait_Ack(); Write_IIC_Byte(IIC_Data); IIC_Wait_Ack(); IIC_Stop(); } void OLED_WR_Byte(unsigned dat,unsigned cmd) { if(cmd) { Write_IIC_Data(dat); } else { Write_IIC_Command(dat); } } /******************************************** // fill_Picture ********************************************/ void fill_picture(unsigned char fill_Data) { unsigned char m,n; for(m=0;m<8;m++) { OLED_WR_Byte(0xb0+m,0); //page0-page1 OLED_WR_Byte(0x00,0); //low column start address OLED_WR_Byte(0x10,0); //high column start address for(n=0;n<128;n++) { OLED_WR_Byte(fill_Data,1); } } } /***********************Delay****************************************/ void Delay_50ms(unsigned int Del_50ms) { unsigned int m; for(;Del_50ms>0;Del_50ms--) for(m=6245;m>0;m--); } void Delay_1ms(unsigned int Del_1ms) { unsigned char j; while(Del_1ms--) { for(j=0;j<123;j++); } }

2023-06-13 上传
2023-06-12 上传