Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
模拟IIC_I2C
rtthread使用软件模拟IIC时速度比较慢
发布于 2024-08-21 17:20:22 浏览:238
订阅该版
最近准备将原有的基于freeRTOS程序转成rtthread,但是在使用软件模拟IIC的时候,突然发现软件模拟IIC的读取数据速度比原程序的速度慢了不少。 原本在freeRTOS中,读取数据只需要2ms的时候即可完成,但是在rtt中读取的时候,突然发现读取时间需要8ms。以下为基于rtt的读取代码: ```c for(i=0;i
dev_addr; uint8_t buf[8] = {0}; uint16_t len = 0; switch(i2c->addrFill) { case 0: //不需要填充地址 break; case 1: //仅需要填充1位地址 buf[0] = (uint8_t)reg_addr; len = 1; break; case 2: //仅需要填充2位地址 buf[0] = (uint8_t)(reg_addr >> 8); buf[1] = (uint8_t)(reg_addr & 0xff); len = 2; break; default: break; } if( dataWrite == 1 ) { switch( i2c->dataSize_Min ) { case DataSize_8bits: buf[len++] = (uint8_t)(usdata & 0xff); break; case DataSize_16bits: buf[len++] = (uint8_t)(usdata >> 8); buf[len++] = (uint8_t)(usdata & 0xff); break; case DataSize_32bits: break; default:break; } } msgs.addr = device_addr; msgs.flags = RT_I2C_WR; msgs.buf = buf; msgs.len = len; if( rt_i2c_transfer(i2c->handle, &msgs, 1) != 1) return RT_ERROR; return RT_EOK; } static rt_err_t iic_read_reg(i2c_info_t *i2c,uint8_t *usdata,uint16_t uslen) { struct rt_i2c_msg msgs; msgs.addr = i2c->dev_addr; msgs.flags = RT_I2C_RD; msgs.buf = usdata; msgs.len = uslen; if( rt_i2c_transfer(i2c->handle, &msgs, 1) != 1 ) return RT_ERROR; return RT_EOK; } rt_err_t device_i2c_readData(uint8_t i2c_port,uint32_t reg_addr,uint8_t *usdata,uint16_t uslen) { i2c_info_t *i2c = get_i2c_para(i2c_port); /* 写入读取地址 */ iic_write_reg(i2c, reg_addr, 0,0); /* 读出数据 */ iic_read_reg(i2c, usdata, uslen); return RT_EOK; } ``` 本来以为是哪里使用了不合理的延时导致的时间的增加,但是在单步debug后,却没发现异常处,然后就突然想到,如果是基于rtt和freeRTOS中,IO口的翻转速度是否一致?然后基于这个,就进行了一次测试。 1.先新建一个基于rtt的工程,然后翻转IO口: ```c int main(void) { rt_pin_mode(LED_RED, 0); while (1) { rt_pin_write(LED_RED, 1); rt_pin_write(LED_RED, 0); } return RT_EOK; } ``` 使用示波器测得IO的翻转速率是将近159KHz; ![IO翻转1.png](https://oss-club.rt-thread.org/uploads/20240821/c747975e8bf85082acea1d558b1daa84.png.webp) 2.然后基于freeRTOS进行一次IO翻转: ```c void StartDefaultTask(void *argument) { /* USER CODE BEGIN 5 */ /* Infinite loop */ for(;;) { HAL_GPIO_WritePin(GPIOC,GPIO_PIN_13,1); HAL_GPIO_WritePin(GPIOC,GPIO_PIN_13,0); // osDelay(100); } /* USER CODE END 5 */ } ``` 使用示波器测得IO翻转速率为1.389MHz ![IO翻转2.png](https://oss-club.rt-thread.org/uploads/20240821/c6bbb805413cb875688373774f330488.png.webp) 不知道是哪里导致的问题,找大佬帮忙解惑一下
查看更多
3
个回答
默认排序
按发布时间排序
踩姑娘的小蘑菇
2024-08-22
这家伙很懒,什么也没写!
rtt也用HAL_GPIO_WritePin试试,可能是调用效率的问题
大懒猫
2024-08-22
勤能补拙
系统工作时钟设置的是多少?这个影响是比较大的吧?
oxlm
2024-08-22
这家伙很懒,什么也没写!
用两个系统跑,再用逻辑分析仪抓一下数据,分析数据会发现很多差异点,再看看有没有机会改善就能搞定大部分情况吧。 按你测得翻转速度,其实不管是159K还是1.3M,都不是最大的影响I2C速度的点,抓模拟I2C波形,看主要是哪变大了,再去针对性的查代码,估计就能找到原因并解决
撰写答案
登录
注册新账号
关注者
0
被浏览
238
关于作者
聪_001
这家伙很懒,什么也没写!
提问
2
回答
0
被采纳
0
关注TA
发私信
相关问题
1
模拟IIC中 SCL 延时的问题
2
在RTT中增加IIC设备
3
rt-thread ov2640 模拟iic 初始化失败
4
模拟I2C使用,线程调度貌似有问题
5
RTT studio打开软件IIC加载不出来drive_iic.c文件
6
使用max30102软件包时出现线程断言错误
7
F407zgoled编译报错
8
stm32F103核心板使用IIC出现的问题
9
rt_thread IICunlock问题
10
使用sensor_lsm6dsm时,出现了传感器可以注册成功却无法读数的问题
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
使用百度AI助手辅助编写一个rt-thread下的ONVIF设备发现功能的功能代码
2
RT-Thread 发布 EtherKit开源以太网硬件!
3
rt-thread使用cherryusb实现虚拟串口
4
《C++20 图形界面程序:速度与渲染效率的双重优化秘籍》
5
《原子操作:程序世界里的“最小魔法单位”解析》
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
WIZnet_W5500
ota在线升级
UART
PWM
cubemx
freemodbus
flash
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
Debug
编译报错
msh
SFUD
keil_MDK
rt_mq_消息队列_msg_queue
at_device
ulog
C++_cpp
本月问答贡献
踩姑娘的小蘑菇
7
个答案
3
次被采纳
a1012112796
13
个答案
2
次被采纳
张世争
9
个答案
2
次被采纳
rv666
5
个答案
2
次被采纳
用户名由3_15位
11
个答案
1
次被采纳
本月文章贡献
程序员阿伟
7
篇文章
2
次点赞
hhart
3
篇文章
4
次点赞
大龄码农
1
篇文章
2
次点赞
ThinkCode
1
篇文章
1
次点赞
Betrayer
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部