430单片机IIC驱动与AT24C56存储器应用

版权申诉
0 下载量 46 浏览量 更新于2024-11-12 收藏 2KB ZIP 举报
资源摘要信息:"IIC.zip_430 iic_存储 单片机" IIC.zip 文件包含用于430系列单片机的IIC(Inter-Integrated Circuit,即I2C)驱动程序代码。I2C总线是一种多主机串行总线,最初由飞利浦公司于1980年代开发,用于连接低速外围设备到主板、嵌入式系统或者手机中的处理器、电源管理芯片、实时时钟等。I2C总线以其简单性、高可靠性和低功耗的特点,在嵌入式系统设计中广泛应用。 430系列单片机是德州仪器(Texas Instruments)生产的一系列超低功耗微控制器,它广泛应用于各种电池供电的便携式设备和嵌入式系统中。该系列单片机通常具备多种外设接口,并且为了方便与各种外围设备通信,通常会内置I2C模块。 驱动程序的作用主要是提供一套标准的方法和协议来控制I2C总线上的设备。在本压缩包中,驱动程序被设计为能够与AT24C56存储器进行通信。AT24C56是一款EEPROM(电可擦可编程只读存储器),拥有56K位的存储容量,支持I2C总线协议。这类存储器常用于存储配置数据、小量程序或日志信息等。 该驱动程序应实现以下基本功能: 1. 初始化I2C模块,设置I2C总线的速率(例如标准模式100kHz或快速模式400kHz)。 2. 提供发送数据到I2C总线的函数。 3. 提供接收数据从I2C总线的函数。 4. 提供设备地址选择功能,以便能够区分和选择连接到同一I2C总线上的多个设备。 5. 错误处理机制,比如在通信失败时进行重试或报错。 为了使用这些驱动程序,用户可能需要对430单片机的I2C模块编程有一定的了解,这包括对I2C的时序图、数据包格式、起始信号、停止信号、应答位和非应答位等概念有一定的认识。此外,用户还需要理解AT24C56的存储结构和如何通过I2C总线地址进行读写操作。 在文件名称列表中,“IIC”是I2C的另一种缩写形式,这说明压缩包中的内容主要与I2C通信协议相关。由于列表中只有一个文件名“IIC”,这表明该压缩包可能只包含一个文件,即前述的驱动程序源代码文件。在实际使用中,用户需要将此驱动程序集成到其项目中,并根据具体应用场景进行适当的修改和扩展。 该驱动程序对于嵌入式系统开发者来说是一个非常有用的资源。通过使用这个驱动程序,开发者可以更加便捷地通过I2C总线与AT24C56等存储器或其他I2C兼容设备进行通信,从而实现数据存储、读取和其他控制功能。对于初学者来说,这也是一个学习和理解I2C通信协议如何在硬件层面上实现的宝贵学习资料。

帮我改进一这段代码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 上传