当前位置:首页 > 单片机 > 单片机
[导读]今天查看STM32资料时,对输出速度2M 10M 50M不是很了解,再加上移植ARF2496K程序到STM32时出现意外情况。一、STM8S端作为接收端和发送端时接收到的数据都正常。二、发送端(STM8S),接收端(STM32)这时也正常。三、

今天查看STM32资料时,对输出速度2M 10M 50M不是很了解,再加上移植ARF2496K程序到STM32时出现意外情况。

一、STM8S端作为接收端和发送端时接收到的数据都正常。

二、发送端(STM8S),接收端(STM32)这时也正常。

三、发送端(STM32),接收端(STM8)时,接收到的就是错误数据,数据每次都相同,但是是错的。


于是,便考虑是不是STM32 I/O输出速度太快导致的,今天便拿示波器测试,果然,豁然开朗。

网上很多全他妈瞎说,STM32的I/O输出配置成2MHz 10MHz 50MHz根本就不是所谓的输出速度,仅仅是翻转速度。


测试示波器为 RIGOL DS1062CA,探头为10X,通道二进行捕获。

硬件: STM32F107主控,采用神舟IV开发板。 另外STM8S主控,采用STM8S核心板

软件: 分为使用库函数和非库函数两种。

一、 使用库函数做输出:

intmain()

{

SystemInit();//初始化系统时钟源选择,PLL等这是个库函数,使用外部晶振系统工作与72MHz

#if1//测试I/O翻转速度,库函数2M左右,直接操作寄存器8M

Init_PD11();//

while(1)

{

GPIO_SetBits(GPIOD,GPIO_PD11);

GPIO_ResetBits(GPIOD,GPIO_PD11);

}

#endif

}

voidInit_PD11()

{

GPIO_InitTypeDefgpio;

//将LED对应的PD口外设时钟打开

RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOD,ENABLE);

gpio.GPIO_Pin=GPIO_Pin_11;

gpio.GPIO_Speed=GPIO_Speed_2MHz;

gpio.GPIO_Mode=GPIO_Mode_Out_PP;//推挽输出

GPIO_Init(GPIOD,&gpio);

}

示波器波形图如下:


实测,无论 GPIO_Speed初始成多少,都是这个波形。也就是说输出速度就这么点了(2.25MHz),跟所谓的2M,10M,50M没什么关系。

上升沿时间与下降沿时间相比要长。


二、直接操作寄存器

只是改动while(1)循环中的代码,如下:

while(1)

{

GPIOD->BSRR=GPIO_Pin_11;

GPIOD->BRR=GPIO_Pin_11;

}

示波器波形如下:


实测,2M 10M 50M输出都是这个波形,但速度明显提升3.5倍,由此可见库函数效率低下。 按手册所讲应该的翻转速度最大为18MHz,不知道什么原因,我这里只能测试出8MHz速度。

同样,上升的时间比下降的时间长。


STM8S测试部分

这里测试时,增加了一部分内容,STM8S 4分频后测试和 STM8S 不分频测试。 使用内部16MHz RC 振荡器。

第一种情况,4MHz主频进行测试

一、 使用库函数,代码如下:

main()

{

CLK_CKDIVR=CLK_CKDIVR_HSIDIV_4;//fHSI=16/4=4MHz将主时钟分频

GPIO_Init(GPIOB,GPIO_PIN_1,GPIO_MODE_OUT_PP_HIGH_FAST);

while(1)

{

GPIO_WriteHigh(GPIOB,GPIO_PIN_1);

GPIO_WriteLow(GPIOB,GPIO_PIN_1);

}

}

示波器波形如下:


这里上升时间与下降时间差距并不怎么明显。


二、操作寄存器控制输出

代码改动如下:

while(1)

{

GPIOB->ODR|=GPIO_PIN_1;//其实这就是库函数的代码,只是免去了调用函数的过程

GPIOB->ODR&=~GPIO_PIN_1;

}

示波器波形如下:



这里能清晰看出上升与下降的时间差别,而且速度也快了8倍,其实这些时间只是耗费在了函数调用与返回上。


第二种情况,16MHz主频进行测试。

这里就不再测库函数的IO速度了,除去函数调用,内部代码就是一致的。

直接操作寄存器控制输出,示波器波形如下:

挺给力,竟然能达到3.2MHz。


总结:

STM32 里面的输出速度不是I/O翻转速度,本人测试速度仅为8MHz

STM32的库函数效率比较猥琐。


之前接收端与发送端都采用STM8S的情况下,将频率分频为4MHz下,通信是正常的,尝试过将发送端频率不分频,使用其16MHz,现象和我在STM32里面的一致。

能进行正常通信的情况下,I/O口速率为95.8KHz,当时并没有采用直接操作寄存器的方式。现在发现,原来STM8S 16MHz主频下I/O速度竟然达到了3.2MHz,STM32作为发送端,自然I/O口速度最小都有2.2MHz, 很有可能是因为这个速度太快,而ARF2496K的速度跟不上导致的,至于为什么,暂时还没有能力进行探究。


本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭