linux stm32 主从,STM32F407和STM32F051主从I2C通信方法

STM32F407和STM32F051主从I2C通信方法

作者:华清远见讲师

M4作为主机:

int main(void)

{

HAL_Init();

SystemClock_Config();

MX_GPIO_Init();

MX_I2C1_Init();

MX_USART1_UART_Init();

while (1)

{

int i;

HAL_I2C_Master_Receive_IT(&hi2c1, 0x22, bbb,

4);

HAL_Delay(1000);

if(i2c_flag == 1)

{

i2c_flag = 0;

printf("\naddr is 11:");

for(i = 0; i < 4; i++)

{

printf("x ", aaa[i]);

}

printf("\naddr is 22:");

for(i = 0; i < 4; i++)

{

printf("x ", bbb[i]);

}

}

}

}

M0作为从机:

void IIC_GPIO_Configuration(void)

{

GPIO_InitTypeDef GPIO_InitStruct;

RCC_AHBPeriphClockCmd(RCC_AHBPeriph_GPIOB, ENABLE);

RCC_APB1PeriphClockCmd(RCC_APB1Periph_I2C1 , ENABLE);

GPIO_InitStruct.GPIO_Pin = GPIO_Pin_6;

GPIO_InitStruct.GPIO_Mode = GPIO_Mode_AF;//GPIO_Mode_IN

GPIO_InitStruct.GPIO_Speed = GPIO_Speed_Level_3;

GPIO_InitStruct.GPIO_OType = GPIO_OType_OD;//open-drain

GPIO_Init(GPIOB , &GPIO_InitStruct);

GPIO_InitStruct.GPIO_Pin = GPIO_Pin_7;

GPIO_Init(GPIOB , &GPIO_InitStruct);

GPIO_PinAFConfig( GPIOB , GPIO_PinSource6, GPIO_AF_1);

GPIO_PinAFConfig( GPIOB , GPIO_PinSource7, GPIO_AF_1);

}

void IIC_Configuration(void)

{

I2C_InitTypeDef I2C_InitStruct;

I2C_InitStruct.I2C_Mode = I2C_Mode_I2C;

I2C_InitStruct.I2C_AnalogFilter = I2C_AnalogFilter_Enable;

I2C_InitStruct.I2C_DigitalFilter = 0x00;

I2C_InitStruct.I2C_OwnAddress1 = 0x22;

I2C_InitStruct.I2C_Ack = I2C_Ack_Enable;

I2C_InitStruct.I2C_AcknowledgedAddress =

I2C_AcknowledgedAddress_7bit;

I2C_InitStruct.I2C_Timing = 0xb0420f13;//100Kbits

I2C_Cmd(I2C1, ENABLE);

I2C_Init(I2C1, &I2C_InitStruct);

}

int main(void)

{

peripheral_init();

board_init();

I2C1_isr.CR1 |= 0X08; //地址匹配产生中断

while(1)

{

if(Recv_flag == 1)

{

Recv_flag = 0;

if(I2C_GetFlagStatus(I2C1, I2C_FLAG_TCR) != SET)

{

printf("transfer\n");

for( i = 0; i < 5; i++)

{

while(I2C_GetFlagStatus(I2C1, I2C_FLAG_TXIS) != SET);

I2C_SendData(I2C1, Data_to_M4_1[i]);

}

}

}

}

}

void I2C1_IRQHandler(void)

{

uint8_t i = 0;

uint8_t j = 0;

I2C_ClearITPendingBit(I2C1, I2C_ISR_ADDR);

I2C1->ISR |= 0x00000001;

I2C_ClearFlag(I2C1, I2C_FLAG_ADDR);

printf("IIC irq in2\n");

Recv_flag = 1;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
STM32 HAL是一款为STM32系列微控制器提供高层次的硬件抽象层的软件库。在STM32 HAL中,我们可以使用I2C总线实现主从通信。 I2C是一种串行通信协议,它允许多个设备通过同一条总线进行通信。在I2C通信中,主设备负责控制总线的占用权,从设备被动响应主设备的操作指令。 在STM32 HAL中,我们可以通过以下步骤实现主从通信: 1. 配置I2C总线:首先,我们需要设置I2C总线的基本配置,包括时钟速率、寄存器设置等。这可以通过HAL库提供的函数来完成。 2. 初始化I2C设备:接下来,我们需要初始化I2C设备,包括设置设备地址、数据传输模式等。这可以通过HAL库提供的函数来完成。 3. 主设备发送数据:主设备通过调用HAL库提供的函数向从设备发送数据。这包括指定从设备地址、传输的数据、数据长度等。 4. 从设备接收数据:从设备接收到主设备发送的数据后,通过调用HAL库提供的函数接收数据。这包括指定主设备地址、接收缓冲区、接收数据长度等。 5. 从设备发送响应:从设备接收到数据后,可以通过调用HAL库提供的函数向主设备发送响应数据。 6. 主设备接收响应:主设备接收从设备发送的响应数据后,可以通过调用HAL库提供的函数接收响应数据。 7. 结束通信:当数据传输完成后,可以调用HAL库提供的函数来结束通信。 通过以上步骤,我们可以实现基于STM32 HAL的I2C主从通信。使用STM32 HAL可以简化I2C通信的编程过程,提高开发效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值