1.首先说明一下本人这次使用的STM32芯片是STM32F103RB,使用的资源是片内的USART1。
2.下面是我的电路连接图:
做一下简单的说明:
(1)PA8是sp3485的发送/接收使能端,sp3485只能支持半双工的通信,所以这个引脚就是来控制这个芯片到底是收数据还是发数据的。
(2)在有些电路连接中,sp3485的A和B端会一个被连接一个上拉电阻到3.3V,另一个会连接一个下拉电阻到GND,这样做的目的是当本sp3485不参与通信时不会影响网络的稳定性。
3.本次调试方式
PC机——USB转232转换头——RS232/RS485双向转换头——sp3485——STM32,因为是第一次调试sp3485芯片,所以当然没有太大意,先拿电脑调试,调试通了再看板子和板子之间的通信了。
4.本次试验的代码:
main函数:
int main(void)
{
/* Configure the system clocks */
RCC_Configuration();
/* NVIC Configuration */
NVIC_Configuration();
/* Configure the GPIOs */
GPIO_Configuration();
/* Configure the USART1 */
USART_Configuration();
GPIO_SetBits(GPIOA, GPIO_Pin_8); //PA8是sp3485发送/接收控制端,这里先设置为发送(实现的功能就是上电之后STM32先向PC发送一个4和一个3)
delay_ms(2);//稍稍延时一下,原因去查看sp3485的手册吧
USART_ClearFlag(USART1,USART_FLAG_TC);//这一句很关键,如果没有这一句这个4会发送不成功或者发送错误的,
//其实手册上讲了使能发送位后会发送一个无用的帧,所以那个帧发送完了这个
//发送完成的标志位USART_FLAG_TC当然也被置位了。
USART_SendData(USART1, 4);
while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==RESET);//上面清除了发送完成标志位,那么这里就可以等待发送完成标志位被置位来判断这一帧是否发完了
USART_SendData(USART1, 3);
while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==RESET);
while(1)
{
GPIO_ResetBits(GPIOA, GPIO_Pin_8);//现在把PA8清零,试试接收PC机发送过来的数据
delay_ms(2);//稍稍延时一下,原因去查看sp3485的手册吧
USART_ClearFlag(USART1,USART_FLAG_RXNE);//既然上面开始发送之前都将发送完成标志位清零,这里也将接收完成标志位清下零,就当是一个好习惯吧
while(1)
{
if(USART_GetFlagStatus(USART1,USART_FLAG_RXNE)==SET)//判断是否有一帧数据接收完成
{
buf[j++] = USART_ReceiveData(USART1); //接收完成的话就直接放到缓存区域里
}
if(10 == j)//接收完成10个之后就跳出去,不再接收了,有个意思就OK了
break;
}
j = 0;//清零一下j变量,使得实验可以反复接收PC发过来的10个数据
GPIO_SetBits(GPIOA, GPIO_Pin_8);//将sp3485设置为发送数据
while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==RESET);
delay_ms(2);//稍稍延时一下,原因去查看sp3485的手册吧
for(i = 0; i < 10; i++)
{
USART_SendData(USART1, buf[i]);//将数据依次发送出去
while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==RESET);
}
}
}
RCC设置函数:
void RCC_Configuration(void)
{
/* RCC system reset(for debug purpose) */
RCC_DeInit();
/* Enable HSE */
RCC_HSEConfig(RCC_HSE_ON);
/* Wait till HSE is ready */
HSEStartUpStatus = RCC_WaitForHSEStartUp();
if(HSEStartUpStatus == SUCCESS)
{
/* HCLK = SYSCLK */
RCC_HCLKConfig(RCC_SYSCLK_Div1);
/* PCLK2 = HCLK */
RCC_PCLK2Config(RCC_HCLK_Div1);
/* PCLK1 = HCLK/2 */
RCC_PCLK1Config(RCC_HCLK_Div2);
/* Flash 2 wait state */
FLASH_SetLatency(FLASH_Latency_2);
/* Enable Prefetch Buffer */
FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);
/* PLLCLK = 8MHz * 9 = 72 MHz */
RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_9);
/* Enable PLL */
RCC_PLLCmd(ENABLE);
/* Wait till PLL is ready */
while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)
{
}
/* Select PLL as system clock source */
RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);
/* Wait till PLL is used as system clock source */
while(RCC_GetSYSCLKSource() != 0x08)
{
}
}
/* Enable USART1 and GPIOA clock */
RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOC, ENABLE);
}
GPIO设置函数:
void GPIO_Configuration(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
/* Configure USART1 Tx (PA.09) as alternate function push-pull */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOA, &GPIO_InitStructure);
/* Configure USART1 Rx (PA.10) as input floating */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_Init(GPIOA, &GPIO_InitStructure);
/* Configure PC. as Output push-pull */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;//GPIO_Mode_Out_PP = 0x10
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOA, &GPIO_InitStructure);
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;//GPIO_Mode_Out_PP = 0x10
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOC, &GPIO_InitStructure);
}
USART设置函数:
void USART_Configuration(void)
{
USART_InitTypeDef USART_InitStructure;
USART_ClockInitTypeDef USART_ClockInitStructure;
USART_ClockInitStructure.USART_Clock = USART_Clock_Disable;
USART_ClockInitStructure.USART_CPOL = USART_CPOL_Low;
USART_ClockInitStructure.USART_CPHA = USART_CPHA_2Edge;
USART_ClockInitStructure.USART_LastBit = USART_LastBit_Disable;
/* Configure the USART1 synchronous paramters */
USART_ClockInit(USART1, &USART_ClockInitStructure);
USART_InitStructure.USART_BaudRate = 9600;
USART_InitStructure.USART_WordLength = USART_WordLength_8b;
USART_InitStructure.USART_StopBits = USART_StopBits_1;
USART_InitStructure.USART_Parity = USART_Parity_No ;
USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
/* Configure USART1 basic and asynchronous paramters */
USART_Init(USART1, &USART_InitStructure);
/* Enable USART1 */
USART_Cmd(USART1, ENABLE);
}
NVIC设置函数:
void NVIC_Configuration(void)
{
#ifdef VECT_TAB_RAM
/* Set the Vector Table base location at 0x20000000 */
NVIC_SetVectorTable(NVIC_VectTab_RAM, 0x0);
#else /* VECT_TAB_FLASH */
/* Set the Vector Table base location at 0x08000000 */
NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x0);
#endif
}
5.实验结果
不成功,找了很久的原因,首先请检查sp3485与232/485双向转换头的连接线,我得到的最终的正确的连接办法是sp3485的A连接到T/R+,而sp3485的B连接到T/R-。
更改连接顺序之后还是出现了很奇怪的现象,每次上电之后PC的串口调试助手都会接收到04 03 00,都要多一个00(十六进制),还有更奇怪的现象,当在PC机上输入十个数据,点击发送之后,返回来居然是20个数据,前10个数据是错误的,后10个才是我发送过去的数据。。。
这个现象非常奇怪,将程序反复修改,还是不能解决问题,甚至一度怀疑sp3485坏掉了,最后弄了一整天,将sp3485A和B引脚之间的120欧姆的电阻去掉,一切恢复正常了!
说明一下:我的sp3485和232/485互转器之间的距离20cm左右,所以这个距离应该是不用接120欧姆的匹配电阻的。
更多
第二篇:调试培训总结
调试培训总结
作为一个刚进入火电的应届毕业生,我很高兴也很荣幸参加这次调试培训。对于刚参加工作的我来讲,这次调试培训是一个很好的学习交流机会,感谢公司领导的安排,同时我也非常珍惜这次学习机会,从这次调试培训中我学到了不少工作上的专业知识,积累了一定的工作经验。
在这段培训期间,我们先后进行了对电厂辅机方面的理论培训学习,调试跟班学习,以及火力发电站结构及系统的理论培训与跟班实习,培训内容由易到难,由理论到实际,覆盖面广,各个专业均有涉及。
初到电厂,首先是进行对安全知识的学习。通过安全学习以及培训老师对一些真实违章事故的讲述使得我再一次认识到安全对于生产和生命的重要性;尤其是在后来的调试跟班学习中,更是深刻认识到安全规范是无数电力建设人员的经验总结、甚至是血的教训,是避免违规操作的基本依据,也是成为一名合格的电力工作人员的必要条件。通过学习电厂的安全规范,我顺利的通过了电厂组织的安全考试并拿到了电厂的出入证,调试培训开始进入正轨。
进入电厂开始调试培训期间,我首先对电厂设备的整体结构进行了解,其次是对火电站锅炉设备电气一次主接线图、厂用电主要负荷、煤、气、水、风系统、开关站、直流系统等进行了学习。虽然刚开始的理论学习有些地方不是很明白,但是在调试跟班学习过程中,通过沙A电厂技术组几位工程师的现场讲解,以及火电脱硝项目部工程师的指点,对原来学习中迷惑得到了释疑,也从前一阶段理论上的理解上升到现场实际的了解。在后来近半个月的调试跟班学习过程中,加强现场实际操作学习,对于引风机机、空预器、稀释风机、吹灰器等结构,各部位的组成,作用等有了进一步认识,同时加强理论学习,对火力发电厂的各专业运行规程进行了系统学习,虚心向运行班组师傅们请教,积极学习动手操作及工作票、操作票制度,在这一阶段中,对电厂调试运行工作有了更深刻的认识。 在调试培训跟班学习中,最先接触到的就是引风机的调试,我们先后对引风机的电机、冷却风机、油泵进行了系统的检查,各工种分工配合相互学习,机务方面检查的设备的安装是否符合安装规范和设计要求;热控电仪方面进行仪表的校验以及检查线路的连接是否正确,控制系统是否全部合乎要求。经检验完毕,引风机顺利试转,且转数、电流、温度、震动等参数符合设计要求,满足所有工
作条件,可以按照计划运行。同时空气预热器的电机试转也是按照这样的方法有条不紊的进行调试,经检查设备安装正常,线路控制系统正常,可以满足试转要求.经检验完毕,空预器电机顺利试转,且转数、电流、温度、震动等参数符合设计要求,满足所有工作条件,可以按照计划运行。之后我们按照计划要求对稀释风机试转进行调试,在对稀释风机试转之前,我们先后对稀释风机送风系统进行了检查,在对所有的设备安装,控制阀门,电路系统进行检查后,发现并无问题,但当稀释风机开始试转时,从阀门开口并无空气流动,进而在运行中无法完成对氨气的稀释,所以停止了稀释风机的试转进行检查,通过对电气控制系统,以及各个控制阀门的逐个排查,最终我们发现这种状况是由于其中一个阀门无法开启,经过检修,排除问题之后,我们再次进行了稀释风机的试转,并且试转正常,满足所有工作条件,可以按照计划运行。按照计划要求我们又对反应器的蒸汽吹灰器进行了调试,首先参加培训的人员配合电厂技术工程师,对吹灰器的电气控制系统进行了逐一的对线检查,电气控制系统符合控制要求,但是安装的吹灰蒸汽管大部分没有直接与下面导向滑轮相接触,但是不影响设备工作。按照耙式吹灰器的正常运行路径,控制中心对吹灰器吹扫路径开始调试,在培训人员的配合之下,电厂工作人员开始对吹灰机进行控制运行,在运行期间,我们发现上层吹灰器运行状态和路径运行正常,但是中层下层行程开关触发装置无法触发且无法触发蒸汽限位开关,在设计单位,供货厂家,施工单位,电厂业主一致协商,最终根据现场情况商量出最佳解决方案,就是调整行程开关位置和增加限位开关的触发杆长度。经过现场的整改调试,问题得到解决,蒸汽吹灰器能够正常运行。最后调试的就是
完成对电厂辅机方面的相关调试,涉及范围很广,各个专业都有所涉及,虽然对很多内容都只有一个笼统的概念,但是对于某些专业更深一步的理解上确实有难度,比如对微机系统的很多原理不明白,二次保护方面还有些地方的理解不是很深刻等,这些内容都需要以后时间的磨练、知识的积累,循序渐进的进行学习。在沙A的最后一段调试跟班实习中,由于在每个班组的时间短,对各个班组的工作核心未能做到像前一段运行时那样深刻的认识,也得到了一个很好的了解火力发电设备的机会,看到了图纸上很多没有立体感的实物,或许对以后我们认识自己电厂机组安装有所帮助。
经过这些天的培训,我在摸索中逐渐掌握了正确的学习方法:发电站系统特点就是发展比较快、理论性和工程性都比较强,涉及专业多,因此对于培训课程,需要听重点、记难点、重思路和方法;同时还要加强熟悉设备的现场实际位置、接线、运行方式等。总之,在这些天的培训过程中,自己逐渐从对水电站运行与维护的懵懵懂懂到对水电站各个组成部分有所了解、掌握了一些实际操作能力。但是自己没有实际操作的经验,对很多知识也不是很了解,还需要在今后的培训中努力学习,开阔视野,对几种经常涉及的主要专业加强学习。在下一阶段的学习中,要加强对我们潘口电站的各种技术图纸与设备型号的理论学习,多看书,多和同事们交流,互相学习,充分利用资源,继续充电,希望在正式上岗以后能以新的认识高度来从事以后的工作。
培训结束,要感谢火电沙A脱硝项目部的全体人员和电厂的工作人员,在培训这段时间沙A项目部不仅在生活上给予我们这些培训人员无微不至的关怀,在工作上也给我们不少的帮助和指点,使我们在生活和工作上都能顺利的进行。同时火电沙A项目部的内部文化也值得我们学习,大事上一丝不苟,小事上精益求精,管理分工明确,工作落实到位,是我们学习的榜样和楷模!
以上是我本次调试培训的总结心得,不足之处,敬请请领导评阅指正!
胡侨
20xx年8月