GD32开发实战指南(基础篇) 第21章 I2C

发布者:Huanle666最新更新时间:2024-11-08 来源: elecfans关键字:GD32  开发实战  I2C 手机看文章 扫描二维码
随时随地手机看文章

开发环境:

MDK:Keil 5.30

开发板:GD32F207I-EVAL

MCU:GD32F207IK


1 I2C工作原理

1.1 I2C串行总线概述

I2C总线是PHLIPS公司推出的一种双线式半双工串行总线,是具备多主机系统所需的总线裁决和高低速器件同步功能的高性能串行总线。用于连接微控器及外围设备。I2C总线只有两根双向信号线。一根是数据线SDA,另一根是时钟线SCL。

  • 物理层

1)它只使用两条总线线路 :一条双向串行数据线(SDA),一条串行时钟线(SCL)。见图 1。

2)每个连接到总线的设备都有一个独立的地址,主机可以利用这个地址进行不同设备之间的访问。

3)多主机同时使用总线时,为了防止数据冲突,会利用仲裁方式决定由哪个设备占用总线。

4)具有三种传输模式 :标准模式的传输速率为 100 Kbit/s ,快速模式为 400 Kbit/s ,高速模式下可达 3.4 Mbit/s,但目前大多12C设备尚不支持高速模式。

5)片上的滤波器可以滤去总线数据线上的毛刺波以保证数据完整。

6)连接到相同总线的 IC 数量受到总线的最大电容 400 pF 限制

1684633670533lhn352peak

I2C总线通过上拉电阻接正电源。当总线空闲时,两根线均为高电平。连到总线上的任一器件输出的低电平,都将使总线的信号变低,即各器件的SDA及SCL都是线“与”关系。

16846336708962h44cnnhxm

每个接到I2C总线上的器件都有唯一的地址。主机与其它器件间的数据传送可以是由主机发送数据到其它器件,这时主机即为发送器。由总线上接收数据的器件则为接收器。

在多主机系统中,可能同时有几个主机企图启动总线传送数据。为了避免混乱, I2C总线要通过总线仲裁,以决定由哪一台主机控制总线。

  • 协议层

I2C的协议包括起始和停止条件、数据有效性、响应、仲裁、时钟同步和地址广播等环节,由于我们使用的是 STM32 集成的硬件I2C接口,并不需要用软件去模拟 SDA 和SCL 线的时序。

1684633671187u7bg1qs1jg

16846336714300q1gyex2f0

这两幅图表示的是主机和从机通信时 SDA 线的数据包序列。

其中 S 表示由主机的I2C接口产生的传输起始信号(S),这时连接到I2C总线上的所有从机都会接收到这个信号。

起始信号产生后,所有从机就开始等待主机紧接下来广播的从机地址信号(SLAVE_ADDRESS),在I2C总线上,每个设备的地址都是唯一的。当主机广播的地址与某个设备地址相同时,这个设备就被选中了,没被选中的设备将会忽略之后的数据信号。根据I2C协议,这个从机地址可以是 7 位或 10 位。

在地址位之后,是传输方向的选择位,该位为 0 时,表示后面的数据传输方向是由主机传输至从机。该位为 1 时,则相反。

从机接收到匹配的地址后,主机或从机会返回一个应答(A)或非应答信号,只有接收到应答信号后,主机才能继续发送或接收数据。

若配置的方向传输位为写数据,广播完地址,接收到应答信号后,主机开始正式向从机传输数据(DATA),数据包的大小为 8 位。主机每发送完一个数据,都要等待从机的应答信号(A),重复这个过程,可以向从机传输 N 个数据,这个 N 没有大小限制。当数据传输结束时,主机向从机发送一个停止传输信号(P),表示不再传输数据。

若配置的方向传输位为读数据,广播完地址,接收到应答信号后,从机开始向主机返回数据(DATA),数据包大小也为 8 位。从机每发送完一个数据,都会等待主机的应答信号(A),重复这个过程,可以返回 N 个数据,这个 N 也没有大小限制。当主机希望停止接收数据时,就向从机返回一个非应答信号,则从机自动停止数据传输。

  • I2C接口特性

1)STM32 的中等容量和大容量型号的芯片均有多达两个的I2C总线接口。

2)能够工作于多主模式或从模式,分别为主接收器、主发送器、从接收器及从发送器。

3)支持标准模式 100 Kbit/s 和快速模式 400 Kbit/s,不支持高速模式。

4)支持 7 位或 10 位寻址。

5)内置了硬件 CRC 发生器 / 校验器。

6)I2 C 的接收和发送都可以使用 DMA 操作。

7)支持系统管理总线(SMBus)2.0 版。

  • I 2 C 架构

I2C的所有硬件架构就是根据 SCL 线和 SDA 线展开的(其中 SMBALERT 线用于 SMBus)。SCL 线的时序即为I2C 协议中的时钟信号,它由I2C 接口根据时钟控制寄存器(CCR)控制,控制的参数主要为时钟频率。而 SDA 线的信号则通过一系列数据控制架构,在将要发送的数据的基础上,根据协议添加各种起始信号、应答信号、地址信号,实现以 I 2 C 协议的方式发送出去。读取数据时则从 SDA 线上的信号中取出接收到的数据值。发送和接收的数据都被保存在数据寄存器(DR)上。

1684633672553yebaw59s20

1.2 I2C总线的数据传送

  • 数据位的有效性规定

I2C总线进行数据传送时,时钟信号为高电平期间,数据线上的数据必须保持稳定,只有在时钟线上的信号为低电平期间,数据线上的高电平或低电平状态才允许变化。

1684633672849j1ygrcot7v

  • 起始和终止信号

SCL线为高电平期间, SDA线由高电平向低电平的变化表示起始信号 ;SCL线为高电平期间, SDA线由低电平向高电平的变化表示终止信号 。

1684633673077fjpfzjb8r3

起始和终止信号都是由主机发出的 ,在起始信号产生后,总线就处于被占用的状态;在终止信号产生后,总线就处于空闲状态。连接到I2C总线上的器件,若具有I2C总线的硬件接口,则很容易检测到起始和终止信号。每当发送器件传输完一个字节的数据后,后面必须紧跟一个校验位,这个校验位是接收端通过控制SDA(数据线)来实现的,以提醒发送端数据我这边已经接收完成,数据传送可以继续进行。

  • 数据传送格式

  • 字节传送与应答

每一个字节必须保证是8位长度。数据传送时,先传送最高位(MSB),每一个被传送的字节后面都必须跟随一位应答位(即一帧共有9位)。

1684633673303tz8x0cse92

由于某种原因从机不对主机寻址信号应答时(如从机正在进行实时性的处理工作而无法接收总线上的数据),它必须将数据线置于高电平,而由主机产生一个终止信号以结束总线的数据传送。

如果从机对主机进行了应答,但在数据传送一段时间后无法继续接收更多的数据时,从机可以通过对无法接收的第一个数据字节的“非应答”通知主机,主机则应发出终止信号以结束数据的继续传送。

当主机接收数据时,它收到最后一个数据字节后,必须向从机发出一个结束传送的信号。这个信号是由对从机的“非应答”来实现的。然后,从机释放SDA线,以允许主机产生终止信号。

  • 总线的寻址

I2C总线协议有明确的规定:采用7位的寻址字节(寻址字节是起始信号后的第一个字节)。

1684633673518xvtc75e3ay

  • 寻址字节的位定义

D7~D1位组成从机的地址。D0位是数据传送方向位,为“0”时表示主机向从机写数据,为“1”时表示主机由从机读数据。

主机发送地址时,总线上的每个从机都将这7位地址码与自己的地址进行比较,如果相同,则认为自己正被主机寻址,根据R/T位将自己确定为发送器或接收器。

从机的地址由固定部分和可编程部分组成。在一个系统中可能希望接入多个相同的从机,从机地址中可编程部分决定了可接入总线该类器件的最大数目。如一个从机的7位寻址位有4位是固定位,3位是可编程位,这时仅能寻址8个同样的器件,即可以有8个同样的器件接入到该I2C总线系统中。

  • 数据帧格式

I2C总线上传送的数据信号是广义的,既包括地址信号,又包括真正的数据信号。

在起始信号后必须传送一个从机的地址(7位),第8位是数据的传送方向位(R/T),用“0”表示主机发送数据(T),“1”表示主机接收数据(R)。每次数据传送总是由主机产生的终止信号结束。但是,若主机希望继续占用总线进行新的数据传送,则可以不产生终止信号,马上再次发出起始信号对另一从机进行寻址。

在总线的一次数据传送过程中,可以有以下几种组合方式:

A)主机向从机发送数据,数据传送方向在整个过程中不变;

1684633673722kyay9yo8kv

注:有阴影部分表示数据由主机向从机传送,无阴影部分则表示数据由从机向主机传送。A表示应答, A表示非应答(高电平)。S表示起始信号,P表示终止信号。

B)主机在第一个字节后,立即从从机读数据。

1684633673932n8tfisfwgv

C)在传送过程中,当需要改变传送方向时,起始信号和从机地址都被重复产生一次,但两次读/写方向位正好反相。

1684633674132xvanmmcugx

1684633674344rt78493cst

要想了解对I2C的主从模式详细了解,参看GD32xxx参考手册的I2C接口章节。


2 AT24Cxx存储器原理

2.1 AT24Cxx概述

AT24C01/02/04/08/16是一个1K/2K/4K/8K/16K位串行CMOS,EEPROM内部含有128/256/512/1024/2048个8位字节CATALYST公司的先进CMOS技术实质上减少了器件的功耗,AT24C01/02有一个8字节页写缓冲器AT24C04/08/16有一个16字节页写缓冲器,该器件通过I2C总线接口进行操作有一个专门的写保护功能。 AT24C01/02每页有8个字节,分别为16/32页;AT24C04/08/16每页有16个字节,分别为32/64/128页 。

工作特点

  • 与400KHz I2C总线兼容

  • 1.8到6.0伏工作电压范围

  • 低功耗CMOS技术

  • 写保护功能当WP为高电平时进入写保护状态

  • 页写缓冲器

  • 自定时擦写周期

  • 100万次编程/擦除周期

  • 可保存数据100年

  • 8脚DIP SOIC或TSSOP封装

  • 温度范围商业级和工业级

AT24Cxx的引脚定义如下:

1684633674574z2lxs9v7ws

Note: For use of 5-lead SOT23, the software A2, A1, and A0 bits in the device address word must be set to zero toproperly communicate.

1684633674909vdvue4k0gz

2.2总线时序

I2C总线时序如下:

16846336753392d3l1vj27n

其读写周期的电压范围如下:

1684633675715dtey3ehaa1

写周期时间是指从一个写时序的有效停止信号到内部编程/擦除周期结束的这一段时间。在写周期期间,总线接口电路禁能,SDA保持为高电平,器件不响应外部操作。

2.3 器件寻址

主器件通过发送一个起始信号启动发送过程,然后发送它所要寻址的从器件的地址。8位从器件地址的高4位固定为(1010)。接下来的3位(A2、A1、A0)为器件的地址位,用来定义哪个器件以及器件的哪个部分被主器件访问,上述8个AT24C01/02,4个AT24C04,2个AT24C08,1个AT24C16可单独被系统寻址。从器件8位地址的最低位,作为读写控制位。“1”表示对从器件进行读操作,“0”表示对从器件进行写操作。在主器件发送起始信号和从器件地址字节后,AT24C01/02/04/08/16监视总线并当其地址与发送的从地址相符时响应一个应答信号(通过SDA线)。AT24C01/02/04/08/16再根据读写控制位(R/W)的状态进行读或写操作。

1684633676175pxeug081dy

  • 字节写

在字节写模式下,主器件发送起始命令和从器件地址信息(R/W)位置发给从器件,在从器件产生应答信号后,主器件发送AT24Cxx的字节地址,主器件在收到从器件的另一个应答信号后,再发送数据到被寻址的存储单元。AT24Cxx再次应答,并在主器件产生停止信号后开始内部数据的擦写,在内部擦写过程中,AT24Cxx不再应答主器件的任何请求。

1684633676484wukfnf0sjo

  • 页写

用页写,AT24C01/02可一次写入8 个字节数据,AT24C04/08/16可以一次写入16个字节的数据。__页写操作的启动和字节写一样,不同在于传送了一字节数据后并不产生停止信号。__主器件被允许发送P(AT24C01:P=7;AT24C02/04/08/16:P=15)个额外的字节。每发送一个字节数据后AT24Cxx产生一个应答位并将字节地址低位加1,高位保持不变。

如果在发送停止信号之前主器件发送超过P+1个字节,地址计数器将自动翻转,先前写入的数据被覆盖。

接收到P+1字节数据和主器件发送的停止信号后,AT24Cxx启动内部写周期将数据写到数据区。所有接收的数据在一个写周期内写入AT24Cxx。

1684633676702e0m63f0p6i

  • 读字节

读操作允许主器件对寄存器的任意字节进行读操作,主器件首先通过发送起始信号、从器件地址和它想读取的字节数据的地址执行一个写操作。在AT24Cxx应答之后,主器件重新发送起始信号和从器件地址,此时R/W位置1,AT24Cxx响应并发送应答信号,然后输出所要求的一个8位字节数据,主器件不发送应答信号但产生一个停止信号。

16846336769686k3c29fu7j

  • 顺序读

在AT24Cxx发送完一个8位字节数据后,主器件产生一个应答信号来响应,告知AT24Cxx主器件要求更多的数据,对应每个主机产生的应答信号AT24Cxx将发送一个8位数据字节。当主器件不发送应答信号而发送停止位时结束此操作。

从AT24Cxx输出的数据按顺序由N到N+1输出。读操作时地址计数器在AT24Cxx整个地址内增加,这样整个寄存器区域可在一个读操作内全部读出,当读取的字节超过E(对于24WC01,E=127;对24C02,E=255;对24C04,E=511;对24C08,E=1023;对24C16,E=2047)计数器将翻转到零并继续输出数据字节。

168463367719777znsxbglf

  • 典型应用

ATC02的典型电路如下:

1684633677472dlwqz7xw5l

根据AT24C02的芯片资料,我们会发现AT24C02有三个地址A0,A1,A2。同时,我们会在资料的Device Address介绍发现I2C器件一共有七位地址码,还有一位是读/写(R/W)操作位,而在AT24C02的前四位已经固定为1010。R/W为1则为 读操作,为0则为写操作。R/W位我们要设置为0(写操作)。

规则为:1010(A0)(A1)(A2)(R/W)

例子1:

那么对应的A0,A1,A2都是接的VCC,所以为A0=1,A1=1,A2=1;可以知道AT24C02的从设备写地址为10101110(0xae),读设备地址为10101111(0xaf)。

例子2:

那么对应的A0,A1,A2都是接的GND,所以为A0=0,A1=0,A2=0;可以知道AT24C02的从设备写地址为10100000(0xa0),读设备地址为10100001(0xa1)。

3 I2C寄存器描述

I2C有6类寄存器,详细的介绍请参考GD32F2XXX参考手册的I2C寄存器描述部分。在这里笔者只讲最重要的2个寄存器。

  • 数据寄存器

数据寄存器的详细描述如下所示。

1684633677753jqwyrcyw35

  • 时钟寄存器

时钟寄存器是I2C中比较重要的一个寄存器,时钟信号的信号的稳定是I2C正常工作的前提。

16846336780924amw1tzup9

4 硬件设计及连接

本文是使用I2C协议对EEPROM进行读写操作,具体的硬件连接如下。

1684633678467powz2w66xn

从硬件链接可以得到AT24C02的地址是0xA0,I2C的接口是I2C0。


5 硬件I2C

5.1 具体代码实现

首先看看I2C的初始化。这有两部分。


一部分是I2C的GPIO初始化。


/*

    brief      configure the GPIO ports

    param[in]  i2c_typedef_enum i2c_id

    param[out] none

    retval     none

*/

void i2c_gpio_config(i2c_typedef_enum i2c_id)

{

    /* enable GPIO clock */

    rcu_periph_clock_enable(I2C_BUS_SCL_GPIO_CLK[i2c_id]);

    rcu_periph_clock_enable(I2C_BUS_SDA_GPIO_CLK[i2c_id]);


    /* Config I2C_SCL */

    gpio_init(I2C_BUS_SCL_GPIO_PORT[i2c_id], GPIO_MODE_AF_OD, GPIO_OSPEED_50MHZ, I2C_BUS_SCL_PIN[i2c_id]);


    /* Config I2C_SDA */

    gpio_init(I2C_BUS_SDA_GPIO_PORT[i2c_id], GPIO_MODE_AF_OD, GPIO_OSPEED_50MHZ, I2C_BUS_SDA_PIN[i2c_id]);

}


/*

    brief      configure the I2C0 interfaces

    param[in]  i2c_typedef_enum i2c_id

    param[out] none

    retval     none

*/

void i2c_mode_config(i2c_typedef_enum i2c_id)

{

    /* enable I2C clock */

    rcu_periph_clock_enable(I2C_BUS_CLK[i2c_id]);

    /* configure I2C clock */

    i2c_clock_config(I2C_BUS[i2c_id], I2C_SPEED, I2C_DTCY_2);

    /* configure I2C address */

    i2c_mode_addr_config(I2C_BUS[i2c_id], I2C_I2CMODE_ENABLE, I2C_ADDFORMAT_7BITS, I2C_OWN_ADDRESS7);

    /* enable I2C0 */

    i2c_enable(I2C_BUS[i2c_id]);

    /* enable acknowledge */

    i2c_ack_config(I2C_BUS[i2c_id], I2C_ACK_ENABLE);

}


主要配置I2C模式、低电平占空比、I2C寻址模式以及通信速率,最后使能I2C设备。

初始化完成后就是对AT24C02的读写操作,严格按照相应的时序操作就行。

  • 字节写

在字节写模式下,向AT24C02中写数据时序如下:

16846336788315v4o0dthkg

操作时序如下:

1.MCU先发送一个开始信号(START)启动总线

2.接着跟上首字节,发送器件写操作地址(DEVICE ADDRESS)+写数据(0xA0)

3.等待应答信号(ACK)

4.发送数据的存储地址。24C02一共有256个字节的存储空间,地址从0x00~0xFF,想把数据存储在哪个位置,此刻写的就是哪个地址。

5.发送要存储的数据,在写数据的过程中,AT24C02会回应一个“应答位0”,则表明写AT24C02数据成功,如果没有回应答位,说明写入不成功。

6.发送结束信号(STOP)停止总线。


代码很简单,跟着时序来就行。


/*

    brief      write one byte to the I2C EEPROM

    param[in]  i2c_typedef_enum i2c_id

    p_buffer: pointer to the buffer containing the data to be written to the EEPROM

    param[in]  write_address: EEPROM's internal address to write to

    param[out] none

    retval     none

*/

void eeprom_byte_write(i2c_typedef_enum i2c_id, uint8_t *p_buffer, uint8_t write_address)

{

    /* wait until I2C bus is idle */

    while(i2c_flag_get(I2C_BUS[i2c_id], I2C_FLAG_I2CBSY));


    /* send a start condition to I2C bus */

    i2c_start_on_bus(I2C_BUS[i2c_id]);


    /* wait until SBSEND bit is set */

    while(!i2c_flag_get(I2C_BUS[i2c_id], I2C_FLAG_SBSEND));


    /* send slave address to I2C bus */

    i2c_master_addressing(I2C_BUS[i2c_id], eeprom_address, I2C_TRANSMITTER);


    /* wait until ADDSEND bit is set */

    while(!i2c_flag_get(I2C_BUS[i2c_id], I2C_FLAG_ADDSEND));


    /* clear the ADDSEND bit */

    i2c_flag_clear(I2C_BUS[i2c_id], I2C_FLAG_ADDSEND);


    /* wait until the transmit data buffer is empty */

    while(SET != i2c_flag_get(I2C_BUS[i2c_id], I2C_FLAG_TBE));


    /* send the EEPROM's internal address to write to : only one byte address */

    i2c_data_transmit(I2C_BUS[i2c_id], write_address);


    /* wait until BTC bit is set */

    while(!i2c_flag_get(I2C_BUS[i2c_id], I2C_FLAG_BTC));


    /* send the byte to be written */

    i2c_data_transmit(I2C_BUS[i2c_id], *p_buffer);


    /* wait until BTC bit is set */

    while(!i2c_flag_get(I2C_BUS[i2c_id], I2C_FLAG_BTC));


    /* send a stop condition to I2C bus */

    i2c_stop_on_bus(I2C_BUS[i2c_id]);


    /* wait until the stop condition is finished */

    while(I2C_CTL0(I2C_BUS[i2c_id]) & 0x0200);

}


  • 页写

用页写,AT24C01可一次写入8 个字节数据,AT24C02/04/08/16可以一次写入16个字节的数据。__页写操作的启动和字节写一样,不同在于传送了一字节数据后并不产生停止信号。__每发送一个字节数据后AT24Cxx产生一个应答位并将字节地址低位加1,高位保持不变。

[1] [2] [3] [4]
关键字:GD32  开发实战  I2C 引用地址:GD32开发实战指南(基础篇) 第21章 I2C

上一篇:GD32开发实战指南(基础篇) 第18章 CRC校验
下一篇:GD32 MCU超频后无法再次下载程序的解决办法

推荐阅读最新更新时间:2026-03-25 11:05

GD32开发实战指南(基础篇) 第8章 定时器
开发环境: MDK:Keil 5.30 开发板:GD32F207I-EVAL MCU:GD32F207IK 1 PWM输出的工作原理 脉冲宽度调制(PWM) ,是英文“Pulse Width Modulation” 的缩写,简称脉宽调制,是利用微处理器的数字输出来对模拟电路进行控制的一种非常有效的技术。简单一点,就是对脉冲宽度的控制。 GD32 的定时器除了 TIMER5 和 6(基本定时器)。其他的定时器都可以用来产生 PWM 输出。 每个定时器有四个通道,每一个通道都有一个捕获比较寄存器,,将寄存器值和计数器值比较,通过比较结果输出高低电平,便可以实现脉冲宽度调制模式(PWM信号)。 在上一节,讲解了定时器
[单片机]
GD32开发实战指南(基础篇) 第14章 内部温度传感器
开发环境: MDK:Keil 5.30 开发板:GD32F207I-EVAL MCU:GD32F207IK 1 内部温度传感器工作原理 GD32 有一个内部的温度传感器,可以用来测量 CPU 及周围的温度(TA)。该温度传感器在内部和 ADCx_IN16 输入通道相连接,此通道把传感器输出的电压转换成数字值。温度传感器模拟输入推荐采样时间是 17.1μs。GD32 的内部温度传感器支持的温度范围为: -40~125度。精度比较差,为±1.5℃左右。 GD32 内部温度传感器的使用很简单,只要设置一下内部 ADC,并激活其内部通道就差不多了。关于 ADC 的设置,我们在前面的章节已经进行了详细的介绍,这里就不再多说。接下来我们介
[单片机]
MYD-LR3576 AMP非对称多核开发实战:从配置到深度优化
一、什么是AMP?为什么重要? AMP(Asymmetric Multi-Processing)非对称多处理架构,允许单个芯片的不同核心运行不同的或裸机程序。相比传统的SMP(对称多处理),AMP具有独特优势。 核心特性: 异构运算:不同核心运行最适合的操作系统,如处理复杂应用,保障实时任务; 资源隔离:各核心拥有独立内存空间,避免资源冲突; 灵活:通过共享内存、RPMSG等方式实现高效核间通信; 商业价值: 成本优化:单芯片替代多芯片方案,减少面积和数量; 开发灵活:支持Linux、RT-Thread、裸机程序的自由组合; 系统可靠:故障隔离,关键任务永不掉线;
[嵌入式]
MYD-LR3576 AMP非对称多核<font color='red'>开发</font><font color='red'>实战</font>:从配置到深度优化
【深度实战】米尔RK3576开发板AMP非对称多核开发指南:从配置到实战
一、什么是AMP?为什么重要? AMP(Asymmetric Multi-Processing)非对称多处理架构,允许单个芯片的不同核心运行不同的操作系统或裸机程序。相比传统的SMP(对称多处理),AMP具有独特优势。 核心特性: • 异构运算:不同核心运行最适合的操作系统,如Linux处理复杂应用,RT-Thread保障实时任务 • 资源隔离:各核心拥有独立内存空间,避免资源冲突 • 灵活通信:通过共享内存、RPMSG等方式实现高效核间通信 商业价值: • 成本优化:单芯片替代多芯片方案,减少PCB面积和元器件数量 • 开发灵活:支持Linux、RT-Thread、裸机程序的自由组合 • 系统可靠:故障隔离,关键任务
[嵌入式]
【深度<font color='red'>实战</font>】米尔RK3576<font color='red'>开发</font>板AMP非对称多核<font color='red'>开发</font>指南:从配置到<font color='red'>实战</font>
MYD-LD25X Cortex-M33实时核开发实战解析
在嵌入式系统设计中,如何平衡高性能计算与实时控制一直是工程师面临的挑战。STM32MP257的异构架构为这一难题提供了优雅的解决方案,而其中的Cortex-M33实时核更是实现硬实时性能的关键所在。 一、异构架构:分工明确,效能卓越 STM32MP257采用创新的双核子系统设计: Cortex-A35应用核(双核1.5GHz):运行Linux系统,负责复杂UI、网络通信、文件管理等非实时任务。 Cortex-M33实时核(400MHz):专攻实时控制,具备纳秒级中断响应,集成FPU和DSP指令集。 二、架构优势凸显: 硬件级资源隔离:通过RIF单元确保M33核独占关键外设,避免核间冲突 能效精细控制:支持独
[嵌入式]
MYD-LD25X Cortex-M33实时核<font color='red'>开发</font><font color='red'>实战</font>解析
STM32实战指南:智能温度控制系统开发从入门到精通全攻略
一、项目背景与意义 在工业自动化、智能家居、农业大棚等场景中,精准的温度控制是实现高效生产的关键。传统温控系统存在成本高、扩展性差等问题,基于STM32的解决方案具有以下优势: 1. 高性能:Cortex-M3内核提供72MHz主频 2. 低成本:核心板价格低于20元 3. 易扩展:丰富的外设接口支持多种传感器 4. 低功耗:多种省电模式可选 本系统实现功能: – 实时温度采集(精度±0.5℃) – 自适应PID算法控制 – 双模式人机交互(本地+远程) – 多重安全保护机制 — 二、硬件系统深度解析 2.1 元件选型指南 2.2 硬件电路设计要点 温度采集电路 ! (https://i3.
[单片机]
STM32<font color='red'>实战</font>指南:智能温度控制系统<font color='red'>开发</font>从入门到精通全攻略
《STM32库开发实战指南 》USART
补充几个当时还不会的知识点。 发送寄存器 寄存器 功能 TE 发送使能 TXE 发送单个字节的时候使用,检查发送寄存器为空? TC 发送字符串的时候使用,实质上时多次调用发送单字符的函数,但是最后一次退出前要检查TC,发送完成寄存器 TXIE 发送完成中断使能 printf的多态 我们可以在Keil5中的工程选项中,勾选Use MicroLIB,这样我们就可以在工程中使用stdio.h头文件了。 当然了,单片机又没有屏幕和键盘,所以原来printf、scanf的实现方法当然不能用了,不过我们可以通过串口的方式来实现其。按照串口的方法,将要显示的内容输出到串口,将要获得的字符从串口中读取,那么无论是printf
[单片机]
S3C2440 开发实战(2):start.S初认识 + SDRAM配置 + 重定位
1、看门狗部分 废话不多说,直接开始配置,首先就是要关闭暂时不使用的看门狗,找到看门狗的寄存器:WTCON,将其第0位置0,即禁用看门狗,即: # define pWTCON 0x53000000 //WTCON地址 ldr r0, =pWTCON mov r1, #0x0 str r1, //关闭看门狗 2、时钟部分 在S3C2440中有三种时钟频率,分别为FCLK, HCLK, PCLK,分别控制不同种类的外设,在时钟树中可以进行查找,这里不做过多赘述,在以后的博客中有应用。 从芯片手册中查找FCLK, HCLK, PCLK 的最高频率,在范围内我们选择设置FCLK = 400MHZ, H
[单片机]
S3C2440 <font color='red'>开发</font>板<font color='red'>实战</font>(2):start.S初认识 + SDRAM配置 + 重定位
小广播
最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

厂商技术中心

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

 
机器人开发圈

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2026 EEWORLD.com.cn, Inc. All rights reserved