keil的软件逻辑分析仪使用教程
用Keil C软件自带的逻辑分析仪仿真HT1621驱动的段码型LCD
用Keil C软件自带的逻辑分析仪仿真HT1621驱动的段码型LCD 一:大体按图示3步进行,首先对项目进行编译OK,其次对软件仿真设置,最后调试输出。
二:在debug项下勾选“Use Simulator”
三:进入Debug,进入调试界面
(P2_0, P2_1, P2_2是我这块板上对应的HT1621与MCU连接的3个硬件引脚,分别对应CS/,WR/,Data。
)
点击”Logic Analyzer”的Setup,进入设置界面,因P2_0, P2_1, P2_2均以位输出,所以在”Display Type”中要设置成”Bit”,并设置不同的颜色,对示区分波形。
点击全速运行后,调节逻辑分析仪的缩放,输出合适的波形。
说明:
对应HT1621、HT1621B、HT1620等手册,对波形进行解析(已解析)
101(兰色字)是3位命令码,表示写模式
000101(红色字)是6位地址码,RAM的地址是0X05
0011(黑色字)是4位数据码,RAM的数据是0X03
也就是说,此波形的含义是在对应LCD的SEG5与COM1、COM0相交的字段点亮了。
可以过LCD实物验证。
最后说明:
本人对比硬件逻辑分析仪,波形相似度相当高。
用Keil C软件自带的逻辑分析仪仿真对于编程调试还是相当有用的,如PWM、UART等。
对于更复杂的处理也是无能为力的,比如触发方式、采样率、采样深度的设置,测量解析波形数据,如各种协议等,还得依赖硬件的逻辑分析仪。
逻辑分析仪使用教程
声明: 本文来自分析仪开发手册.pdf)前言一、什么是逻辑分析仪二、使用介绍三、安装说明四、Saleae软件使用方法五、逻辑分析仪硬件安装六、使用Saleae分析电视红外遥控器通信协议七、使用Saleae分析UART通信八、使用Saleae分析IIC总线通信九、使用Saleae分析SPI总线通信十、Saleae逻辑分析仪使用问题和注意事项淘宝地址:(原文件名:21.jpg)前言:工欲善其事,必先利其器。
逻辑分析仪是电子行业不可或缺的工具。
但是由于一直以来,逻辑分析仪都属于高端产品,所以价格居高不下。
因此我们首先要感谢Cypress公司,提供给我们68013这么好的芯片,感谢俄罗斯毛子哥将这个Saleae逻辑分析仪开源出来,让我们用平民的价格,就可以得到贵族的待遇,获得一款性价比如此之高的逻辑分析仪,可以让我们在进行数字逻辑分析仪的时候,快速查找并且解决许多信号、时序等问题,进一步提高我们处理实际问题的能力。
原本计划,直接将Saleae的英文版本使用手册直接翻译过来提供给大家,我花费半天时间翻译完后,发现外国人写的东西不太符合我们国人的思维习惯,当然,也是由于我的英语水平有限,因此,我根据自己摸索这个Saleae的过程,写了一份个人认为符合中国人习惯的Saleae,提供给大家,希望大家在使用过程中少走弯路,快速掌握使用方法,更快的解决自己实际遇到的问题。
由于个人水平有限,因此在文章撰写的过程中难免存在问题和错误,如果有任何问题,希望大家能够提出来,我会虚心接受并且改进,希望通过我们的交流,给越来越多的人提供更加优秀的资料,共同进步。
一、什么是逻辑分析仪:逻辑分析仪是一种类似于示波器的波形测试设备,它通过采集指定的信号,并通过图形或者数据统计化的方式展示给开发人员,开发人员通过这些图形化时序信号按照协议来分析硬件或者软件中的错误。
逻辑分析仪是设计中不可缺少的设备,通过它,可以迅速定位错误,发现并解决问题,达到事半功倍的效果,尤其在分析时序,比如1wire、I2C、UART、SPI、CAN等数据的时候,应用逻辑分析仪解决问题非常快速。
(4条消息)STM32使用keil自带的逻辑分析仪
打开逻辑分析仪
在command窗口中输入 dir vtreg
查看有哪些引脚可以被检
B、C、D、E、F、G
比如我要使用的GPIOB_Pin_5,就需要打开逻辑分析仪,setup
PORTB.5代表的就是GPIOB_Pin_5,点击旁边的空白就会自动变成
更改红圈内的选项下面的因为我用的是stm32f103ze应该改为自己的板子型号如果这个不改后续无法在逻辑分析仪中添加信号
(4条消息)STM32使用keil自带的逻辑分析仪
1.首先打开你的工程
点击options for target
更改红圈内的选项,下面的因为我用的是STM32F103ZE,应该改为自己的板子型号,如果这个不改后续无法在逻辑分析仪中添加信号
KEIL逻辑分析仪使用
KEIL 逻辑分析仪的使用
Osprey----- 2016/11/2
以STM32F103RET6,外接8M晶振,输出引脚PA.7,70Khz为例.每一步都很重要。
1.准备输出PWM的程序
2.设置时钟,设置为8M。
点击图示,进入配置页面。
在Target中配置8M晶振,在同一
界面的Debug配置为仿真模式
3.进入仿真界面,点击Debug 图标。
4.找到逻辑分析仪界面。
点击所示,即可出现窗口。
也可在View菜单中找分析窗口。
4.点击Setup ,进入设置界面,如图,敲上porta.7 (PA7引脚),按回车键,点击Close然后
在回到这个界面设置Display Type为bit,表示显示位。
再Close。
以下是最终结果。
5.先开始运行程序一会再停止。
注意一定要停止,否则分析窗口不会出现波形。
6.最后就是窗口的使用了,将光标点(不是移)在窗口上,鼠标滚轮移动可以调节波形大小,左击波形的某个位置,再点击移动光标置另一个位置,就会显示时间差和频率。
可以放大后再确定位置。
逻辑分析仪使用教程
声明: 本文来自分析仪开发手册.pdf)前言一、什么是逻辑分析仪二、使用介绍三、安装说明四、Saleae软件使用方法五、逻辑分析仪硬件安装六、使用Saleae分析电视红外遥控器通信协议七、使用Saleae分析UART通信八、使用Saleae分析IIC总线通信九、使用Saleae分析SPI总线通信十、Saleae逻辑分析仪使用问题和注意事项淘宝地址:(原文件名:21.jpg)前言:工欲善其事,必先利其器。
逻辑分析仪是电子行业不可或缺的工具。
但是由于一直以来,逻辑分析仪都属于高端产品,所以价格居高不下。
因此我们首先要感谢Cypress公司,提供给我们68013这么好的芯片,感谢俄罗斯毛子哥将这个Saleae逻辑分析仪开源出来,让我们用平民的价格,就可以得到贵族的待遇,获得一款性价比如此之高的逻辑分析仪,可以让我们在进行数字逻辑分析仪的时候,快速查找并且解决许多信号、时序等问题,进一步提高我们处理实际问题的能力。
原本计划,直接将Saleae的英文版本使用手册直接翻译过来提供给大家,我花费半天时间翻译完后,发现外国人写的东西不太符合我们国人的思维习惯,当然,也是由于我的英语水平有限,因此,我根据自己摸索这个Saleae的过程,写了一份个人认为符合中国人习惯的Saleae,提供给大家,希望大家在使用过程中少走弯路,快速掌握使用方法,更快的解决自己实际遇到的问题。
由于个人水平有限,因此在文章撰写的过程中难免存在问题和错误,如果有任何问题,希望大家能够提出来,我会虚心接受并且改进,希望通过我们的交流,给越来越多的人提供更加优秀的资料,共同进步。
一、什么是逻辑分析仪:逻辑分析仪是一种类似于示波器的波形测试设备,它通过采集指定的信号,并通过图形或者数据统计化的方式展示给开发人员,开发人员通过这些图形化时序信号按照协议来分析硬件或者软件中的错误。
逻辑分析仪是设计中不可缺少的设备,通过它,可以迅速定位错误,发现并解决问题,达到事半功倍的效果,尤其在分析时序,比如1wire、I2C、UART、SPI、CAN等数据的时候,应用逻辑分析仪解决问题非常快速。
Keil软件使用手册【精选文档】
Keil软件使用手册(本手册参考keil 4版本)一安装到网上下载一个安装包,里面必须包含以下内容:1:(安装包文件,圈选的文件为安装说明,请务必仔细阅读) 2:(打开安装文件)3:(点击下一步)4:(勾选同意,并点击下一步) 5:(浏览选择到你想安装的地方,然后选择下一步)6:(两个空可以随便打,不重要,填完后点击下一步)7:(正在安装中)8:(点击完成)9:(进入安装的文件夹,点击UV4)10:(打开Keil4的执行文件)11:(点击File,再选择License Management)Pic 12:(复制右上角的ID号)12:(打开注册机文件)13:(将复制的ID号粘贴在此处)14:(点击Generate,在上方会生成一组ID,复制下来)15:(将复制好的ID粘贴在圈选出,并点击Add LIC)16:(当你看见这两组单词,那么恭喜你,注册成功,准备开始你的奇妙程序之旅吧!)二新建工程1.单击Project,选择New Project2.选择保存位置,输入工程的名字3.选择CPU。
紧接着,Keil C51提示您选择CPU器件。
8051内核片机最早是由Intel公司发明的,后来其他厂商如Philips、Atmel、Winbond等先后推出其兼容产品,并在8051的基础上扩展了许多增强功能,根据芯片的实际情况,选择相应的器件(本例程选择Atmel公司下的AT89C52),如图:注:选择8051也可以,8051与8052有一点的差别,可以说8052是8051的升级版,主要有以下不同:1.内部RAM,8051单片机为128Byte(00H—7FH),8052单片机为56 Byte (00H—0FFH)2. 内部ROM,8051单片机为4KB,8052单片机为8KB3. 8051有两个Timer:T0和T1。
8052除了有T0和T1以外,还有一个Timer2 4。
8051有5个中断源8052有6个。
介绍单片机中Keil的软件仿真和硬件仿真
介绍单片机中Keil的软件仿真和硬件仿真 一、软件仿真 Keil有很强大的软件仿真功能,通过软件仿真可以发现很多将要出现的问题,Keil的仿真可以查看很多硬件相关的寄存器,通过观察这些寄存器值的变化可以知道代码有没有正常运行。
这样可以避免频繁下载程序,延长单片机Flash寿命。
开始仿真之前,先配置一些选项。
1.在工程设置里设置好芯片型号和晶振频率。
2.在“Debug”选项卡中选择“Use Simulator”,表示使用软件仿真;选择“Run to main()”则表示跳过汇编代码,直接跳转到main函数开始仿真。
设置下面的“Dialog DLL”项为“DARMSTM.DLL”和“TARMSTM.DLL”;parameter 项为“-pSTM32F103C8”,用于设置支持STM32F103C8的软硬件仿真。
3.点击开始仿真,这个时候会多出来一个工具条,就是Debug工具条。
1:复位,其功能等同于硬件上按复位按钮,相当于实现了一次硬复位。
按下该按钮后,代码会重新从头开始执行。
2:执行到断点处,按按钮用来快速执行到断点处,有时候并不需要观看每步时怎幺执行的,而是想快速执行到程序的某个地方看结果,这个按钮就可以实现这样的功能,前提是已在查看的地方设置了断点。
3:停止运行,此按钮在程序一直执行的时候变为有效,可以使程序停止下来进入到单步调试状态。
4:执行进去,该按钮用来实现执行到某个函数里面去的功能,在没有函数的情况下等同于执行过去按钮。
5:执行过去,在碰到有函数的地方,通过该按钮就可以单步执行过这个函数,而不进入这个函数单步执行。
6:执行出去,该按钮是进入了函数单步调试的时候,有时候可能不必再执行该函数的剩余部分了,通过该按钮就直接一步执行完函数余下的部分,并跳出函数回到函数被调用的位置。
7:执行到光标处:该按钮可以迅速使程序运行到光标处,与执行到断点处按钮功能类似。
8:汇编窗口,通过该按钮可以查看汇编代码,这对分析程序很有用。
KEIL使用方法简介共32页文档
修改晶振频率 单位MHz
单击 开始仿真 注: 仿真前应先编译
寄存器列表
程序对应的汇编语句
程序 PC指针位置
复位 全速运行 停止 单步进入语句内 单步不进入语句内 从语句内返回 程序运行时间(单位:秒)
外围: 中断
I/O 串口 定时器/计数器
关于断点调试
31、只有永远躺在泥坑里的人,才不会再掉进坑里。——黑格尔 32、希望的灯一旦熄灭,生活刹那间变成了一片黑暗。——普列姆昌德 33、希望是人生的乳母。——科策布 34、形成天才的决定因素应该是勤奋。——郭沫若 35、学到很多东西的诀窍,就是一下子不要学很多。——洛克
单击是(Y)
这里不一样的自行展开
工程创建好的样子
3、创建文件
单击 创建新文件
这个可以不一样 单击这里保存文件并定义文件类型
自己写文件名和后缀 后缀决定文件类型 填写完成后单击保存返回
4、添加文件到工程
右键单击 左键单击
1 、
如果找不到文件 单击 这个下三角找到相应的
文件后缀 选择后就可
KEIL使用方法简介
16、自己选择的路、跪着也要把它走 完。 17、一般情况下)不想三年以后的事, 只想现 在的事 。现在 有成就 ,以后 才能更 辉煌。
18、敢于向黑暗宣战的人,心里必须 充满光 明。 19、学习的关键--重复。
20、懦弱的人只会裹足不前,莽撞的 人只能 引为烧 身,只 有真正 勇敢的 人才能 所向披 靡。
1、单击选择Output 2、选中Creat HEX file 3、单击OK结束
单击 编译整个工程 并生成.HEX文件
6、KEIL仿真
KEIL仿真虽然不是老师要求的内容 但是对以后单片机的学习非常有用 使用KEIL仿真可以单步运行每一条语句并观察各I/O 口、寄存器、内存的变化 如果设置了晶振频率还可以大致显示运行时间 所以我在这里简单介绍一下 不感兴趣的可以不看
EL-MUT-Keil C CPU板与逻辑分析仪接口说明
EL-MUT-Keil C CPU板与逻辑分析仪接口说明下图所示,为CPU板上信号,与逻辑分析仪接口通道序号及针脚定义左插座右插座1、逻辑分析仪上有两组26针探测头接口针,面板上标识为“CH1”、“CH2”。
2、在使用逻辑分析仪检测CPU板上信号的时序时,将逻辑分析仪面板上标识为“CH1”的26针探测接口插入CPU板上标识为JP1的右插座;将逻辑分析仪面板上标识为“CH2”的26针探测接口插入单片机CPU板上标识为JP2的左插座。
3、 JP1,JP2左右两边的横向标识“D0/A0……D7/A7、A8……A15、ALE”,“P10/CH0……P17/CH7……WR、RD、XT2”为对应的CPU的信号标识,其中CH0……CH7为CPU板上的8个扩展的二号探测口,其余信号为从CPU管脚引出的信号。
当需要探测外部信号的时序时,把相应的外部信号用实验导线,接到CPU板上对应标识为CH0、CH1……CH7的2号孔上,并且JP_S跳线选择相应的方向。
4、 JP1两侧的纵向标识“0……12、13……15、CLK1、GND、NC”对应逻辑分析仪的通道号0到15通道,外部钟1,接地针GND,及第26针为悬空状态NC;JP2两侧的纵向标识“16……28、29……31、CLK2、GND、NC”对应逻辑分析仪的通道号16到31通道,外部钟2,接地针GND,及第26针为悬空状态NC。
5、 JP2左侧的标识“P10/CH0、P11/CH1……INT1/PSEN”等,表示P10与/CH0复用探测通道16,P11与/CH1复用探测通道17,……,INT1与PSEN复用探测通道27。
具体哪组信号有效,则由JP_S跳线选择而决定。
如跳线帽短接JP_S左端的CH0则表示,此时逻辑分析仪探测的信号为CH0;如跳线帽短接右端的P10则表示,此时逻辑分析仪探测的信号为P10;如此类推。
至于JP1左侧的标识“D0/A0……D7/A7”则是CPU 内部信号复用,当CPU对总线进行操作时,逻辑分析仪探测到的这8位数据则既有数据信号,又有地址信号,具体什么时候为数据,什么时候为地址,请参照单片机CPU 标准总线时序加以判断。
Keil软件仿真逻辑分析仪引脚unknownsignal
Keil软件仿真逻辑分析仪引脚unknownsignal ⼀简述
⽹友说看了某某视频,在⽤mdk5软件仿真设置逻辑分析仪引脚时,总是提⽰
Unknown Signal 错误
因为有 C51 和 ARM 两种⽅式的软件调试⽅式,需要对应地正确配置其动态库
当然,也可能是输⼊错误的虚拟寄存器名称引起
⼆参数设置
1 C51系列
在参数的DEBGUG 选项页中,设置如下:
CPU DLL Parameter | Driver DLL Parameter
S8051.DLL | S8051.DLL
Dialog DLL Parameter | Dialog DLL Parameter
DP51.DLL -pAT52 | TP51.DLL -pAT52
2 ARM系列
在参数的DEBGUG 选项页中,设置如下:
CPU DLL Parameter | Driver DLL Parameter
SARMCM3.DLL -REMAP | SARMCM3.DLL
Dialog DLL Parameter | Dialog DLL Parameter
DARMSTM.DLL -pSTM32F103ZE | TARMSTM.DLL -pSTM32F103ZE
三查看可使⽤的虚拟寄存器
启动调试,在命令窗⼝的底部,输⼊ dir vtreg 即可列出。
四在逻辑分析仪下,查看引脚的具体位的数值,可以分析波形
1 设置引脚的具体位
2 在图形⽅式下查看时间差
五测试引脚外部中断
点击具体的端⼝引脚的位,可以测试中断等。
keil软件的使用方法课件
勾选“生成hex文件”
使用仿真器时对KEIL的设置
➢点击“调试”选项, 选“Kil monitor-51 Driver” 勾选“生成hex文件” 勾选“加载代码到仿真器”
使用仿真器时对KEIL的设置
➢点击“设置”选项, 选串行口 选波特率
仿真界面
PC指针
端口监视 硬件应对应工作
C:×××× 程序存储器
存储器区选择
➢选标签 ➢分别输入地址
I:×× 片内RAM X:×××× 片外RAM
文件编译
编译, 建造目标
文件的调试与运行
•先复位 •进入/退出 调试状态
文件的调试界面
进入/退出 DEBUG
程序计数器PC
工程窗口
寄存器窗口
调试工具
复位 停止运行
源程序/反汇编 窗口切换
文件 编辑 视图
工程窗口
源代码浏览
输出窗口
选择对应的 工具条
打开/关闭 对应的窗口
KIEL的主菜单功能
工程
KIEL的主菜单功能
调试 菜单
调试 工具
KIEL的主菜单功能
外围设备
(在调试状态 下使用)
可观察 端口状态
KIEL的主菜单功能
存储器 选择
D:××
SFR
I:×× 片内RAM
X:×××× 片外RAM
跟踪运行 运行到光标处
连续运 单步运行
查看串行口
查看堆栈
使用仿真器时对KEIL的设置
➢单击“工程”菜单 在下拉式菜单中选择
“目标1属性”
使用仿真器时对KEIL的设置
➢单击“工程”菜单 在下拉式菜单中选择
“目标1属性” ➢点击“目标”选项,
逻辑分析仪使用方法
逻辑分析仪使用方法逻辑分析仪是一种用于对数字信号进行分析和测量的仪器,它可以帮助我们更好地理解和分析数字电路中的信号变化。
在使用逻辑分析仪时,我们需要注意一些使用方法和技巧,以确保获得准确的测量结果和分析数据。
本文将介绍逻辑分析仪的基本使用方法,希望能够帮助大家更好地使用这一仪器。
首先,使用逻辑分析仪之前,我们需要对仪器的各个部分进行检查和准备工作。
确保逻辑分析仪的各个连接线缆都已经连接好,并且连接牢固可靠。
同时,检查仪器的电源和信号输入接口是否正常,以及仪器的各项功能是否正常。
在确认一切准备工作就绪后,我们可以开始进行逻辑分析仪的使用。
在使用逻辑分析仪时,我们需要根据具体的测量需求和实际情况来设置仪器的各项参数。
首先,我们需要选择合适的采样频率和采样深度,以确保能够捕获到所需的信号波形。
同时,我们还需要设置触发条件和触发方式,以确保逻辑分析仪能够在正确的时刻进行触发和捕获信号。
在设置参数时,我们需要根据实际情况进行调整,并且需要注意参数的合理性和稳定性。
在进行信号测量和分析时,我们需要根据实际情况选择合适的测量通道和测量模式。
逻辑分析仪通常具有多个测量通道,我们可以根据需要选择单通道测量或者多通道同时测量。
同时,我们还可以选择不同的测量模式,比如时序模式、状态模式和协议分析模式等,以满足不同的测量需求。
在选择测量通道和测量模式时,我们需要根据实际情况进行选择,并且需要注意测量结果的准确性和可靠性。
在进行信号测量和分析时,我们需要注意逻辑分析仪的测量精度和测量范围。
逻辑分析仪通常具有一定的测量精度和测量范围,我们需要根据实际情况选择合适的测量范围,以确保能够获得准确的测量结果。
同时,我们还需要注意信号的采样和处理,以确保能够捕获到所需的信号波形,并且能够对信号进行准确的分析和测量。
在使用逻辑分析仪时,我们需要注意仪器的操作方法和技巧。
比如,在进行信号测量和分析时,我们需要注意信号的触发和捕获,以确保能够在正确的时刻进行信号的捕获和分析。
Keil使用教程详细教程PPT课件
工程管理窗口内容及分布,与Windows 的资源管理器相似。
3 Keil C应用
图4-7 Keil C51的 工程管理器
3 Keil C应用
一、项目的建立
1、建立项目
选择Project菜单下的New Project命令, 创建新工程,在对话框中设定新工程的位 置,输入新工程名字保存即可。
1
• 要求 掌握使用KEIL进行程序创建,运行。
C51集成开发软件Keil C
主要内容
1 Keil C集成开发工具 简介
2 Keil C操作界面 3 Keil C的使用 4 项目的运行调试
C51集成开发软件Keil C
Keil C:是德国KEIL公司开发的单片机C 语言编译器。其前身是FRANKLIN C51,功 能相当强大。
这些库是按规定格式排列的目标模块, 可在以后被链接器所使用。
1 KeilC集成工具简介
三、模拟调试器
Keil C有三个模拟调试器。
1、软件模拟调试器dScope51
(1)模拟程序运行与调试,包括C、汇编、 宏汇编程序; (2)模拟CPU及其外围器 件,如串行口、定时器/计数器、I/O口等。
2、硬件调试器tScope51
19)Function Editor…: 编辑调试函数和调试配
置文件
2 Keil C操作界面
六、片内外设(Peripheral)菜 单
1)Reset CPU:复位CPU 2)Interrupt:设置/观察中断(触发方式、
优先级、使能等) 3)I/O Ports:设置/观察各个I/O口 4)Serial:设置/观察串行口 5)Timer:设置/观察各个定时器/计数器 6)A/D Converter:设置/观察A/D转换器 7)D/A Converter:设置/观察D/A转换器
逻辑分析仪使用方法
逻辑分析仪使用方法逻辑分析仪是一种用于观察和分析数字信号的仪器,它可以帮助用户快速准确地分析和诊断数字电路中的问题。
在使用逻辑分析仪时,需要注意一些使用方法,以确保测试结果的准确性和可靠性。
首先,使用逻辑分析仪前,需要对待测电路进行充分的了解和准备。
用户应该清楚待测电路的工作原理、信号波形特点以及测试的目的。
这样可以帮助用户选择合适的测量参数和设置逻辑分析仪的工作模式。
其次,连接逻辑分析仪时,需要注意正确接线,保证信号的准确传输。
通常情况下,逻辑分析仪需要与待测电路进行正确的信号连接,包括时钟信号、数据信号、控制信号等。
在接线过程中,要确保连接牢固,信号传输无误,避免因连接问题导致测试结果不准确。
接着,设置逻辑分析仪的参数和工作模式。
根据待测电路的特点和测试的要求,用户需要合理设置逻辑分析仪的采样率、触发条件、触发级别等参数。
在设置参数时,需要根据实际情况进行调整,以确保测试结果的准确性和稳定性。
在进行测试时,需要注意观察测量结果,并及时调整逻辑分析仪的参数。
通过观察信号波形和数据分析,用户可以及时发现问题所在,并对测试参数进行调整,以获取更准确的测试结果。
在测试过程中,用户需要耐心等待测试结果稳定后再进行数据记录和分析。
最后,使用完逻辑分析仪后,需要进行仪器的清理和保养工作。
及时清理仪器表面的灰尘和污渍,保持仪器的清洁和整洁。
在长时间不使用时,还需要对逻辑分析仪进行适当的保养和维护工作,以确保仪器的性能和使用寿命。
总之,使用逻辑分析仪需要用户具备一定的电路知识和操作经验,同时需要注意正确的连接和设置参数,以确保测试结果的准确性和可靠性。
希望以上内容可以帮助用户更好地使用逻辑分析仪,提高工作效率和测试精度。
keil的调试步骤与方法
keil的调试步骤与方法Keil调试步骤与方法Keil是一款常用的嵌入式开发环境,用于编写和调试嵌入式系统的程序。
在进行嵌入式开发过程中,调试是一个非常重要的环节,它可以帮助开发人员找出程序中存在的问题并进行修复。
本文将介绍Keil的调试步骤与方法,帮助读者更好地进行嵌入式开发与调试。
一、准备工作在使用Keil进行调试之前,我们需要先进行一些准备工作。
首先,我们需要安装Keil软件,并配置好开发板的硬件环境。
其次,我们需要将待调试的程序下载到开发板中,并连接上调试器。
最后,我们需要在Keil中打开待调试的项目文件,以便进行后续的调试操作。
二、设置断点在进行程序调试时,我们常常需要在程序中设置断点,以便在指定位置停下来观察程序的执行情况。
在Keil中,我们可以通过单击代码行号的方式来设置断点。
当程序执行到设置的断点位置时,会自动停下来,以便我们观察相关的变量值和程序执行流程。
三、单步执行单步执行是调试过程中常用的操作之一,它可以使程序以单步的方式执行,以便我们逐行观察程序的执行情况。
在Keil中,我们可以通过点击工具栏上的“单步执行”按钮来进行单步执行操作。
在单步执行过程中,我们可以观察变量的值的变化,以及程序的执行流程,帮助我们找出程序中的问题。
四、观察变量值在调试过程中,我们经常需要观察程序中的变量值,以便判断程序的执行是否符合预期。
在Keil中,我们可以通过“观察窗口”来观察变量的值。
在观察窗口中,我们可以添加需要观察的变量,并在程序执行过程中实时查看其数值的变化。
五、查看寄存器值在嵌入式系统中,寄存器是非常重要的硬件资源,它们直接影响着程序的执行。
在Keil中,我们可以通过“寄存器窗口”来查看寄存器的值。
在寄存器窗口中,我们可以查看各个寄存器的当前值,以便判断程序的执行是否符合预期。
六、调试输出除了观察变量和寄存器的值外,我们还可以通过调试输出来观察程序的执行情况。
在Keil中,我们可以使用printf函数来进行调试输出。
逻辑分析仪使用教程
声明: 本文来自另外,将68013制作逻辑分析仪的原理说明简单整理了一下,大家可以看看,如果想DIY也就不难了。
点击此处下载(文件大小:203K)(原文件名:逻辑分析仪开发手册.pdf)前言一、什么是逻辑分析仪二、使用介绍三、安装说明四、Saleae软件使用方法五、逻辑分析仪硬件安装六、使用Saleae分析电视红外遥控器通信协议七、使用Saleae分析UART通信八、使用Saleae分析IIC总线通信九、使用Saleae分析SPI总线通信十、Saleae逻辑分析仪使用问题和注意事项123淘宝地址:(原文件名:前言:工欲善其事,必先利其器。
逻辑分析仪是电子行业不可或缺的工具。
但是由于一直以来,逻辑分析仪都属于高端产品,所以价格居高不下。
因此我们首先要感谢Cypress 公司,提供给我们68013这么好的芯片,感谢俄罗斯毛子哥将这个Saleae逻辑分析仪开源出来,让我们用平民的价格,就可以得到贵族的待遇,获得一款性价比如此之高的逻辑分析仪,可以让我们在进行数字逻辑分析仪的时候,快速查找并且解决许多信号、时序等问题,进一步提高我们处理实际问题的能力。
原本计划,直接将Saleae的英文版本使用手册直接翻译过来提供给大家,我花费半天时间翻译完后,发现外国人写的东西不太符合我们国人的思维习惯,当然,也是由于我的英语水平有限,因此,我根据自己摸索这个Saleae的过程,写了一份个人认为符合中国人习惯的Saleae,提供给大家,希望大家在使用过程中少走弯路,快速掌握使用方法,更快的解决自己实际遇到的问题。
由于个人水平有限,因此在文章撰写的过程中难免存在问题和错误,如果有任何问题,希望大家能够提出来,我会虚心接受并且改进,希望通过我们的交流,给越来越多的人提供更加优秀的资料,共同进步。
一、什么是逻辑分析仪:逻辑分析仪是一种类似于示波器的波形测试设备,它通过采集指定的信号,并通过图形或者数据统计化的方式展示给开发人员,开发人员通过这些图形化时序信号按照协议来分析硬件或者软件中的错误。
KEIL中逻辑分析仪的使用
KEIL中逻辑分析仪的使用
程序写好了,编译好了,那么下边就要使用逻辑分析仪进行软件调试(不要选择用Jlink硬件调试),看看输出是不是你想要的波形。
首先进入调试模式,(讲解的时候我就从菜单栏而不用快捷面板上的快捷按钮吧,也为了让大家熟悉所使用的工具在哪个菜单下。
)
菜单栏的Debug下拉菜单的start/stop debug session选项,
然后调出逻辑分析仪,(只有进入调试模式才可以看到逻辑分析仪)。
在菜单栏的View下拉菜单中找到Analysis Windows就看到逻辑分析仪了
点出来之后就是下边的窗口了:
下边是如何设置的问题。
首先你要知道那些引脚可以被检测到,你可以在命令行窗口输入dir vtreg,如图所示:
然后就可以显示出那些引脚是可以被检测到的。
本程序我检测的是P3.25脚,即PORT3口的25脚。
然后点击逻辑分析仪面板左上角的setup开始设置,新建插入(红叉叉旁边)直接输入port3.25
回车就可以了:
然后设置成下边的形式,意思是将port3口的值与上0x02000000后屏蔽掉其他位的信号就只剩下P3.25的状态值,然后右移25位出来。
最后点击run全速运行就可以看到输出的波形了:
如图所示一个脉冲间隔0.499957符合我们的要求。
keil的软件逻辑分析仪使用教程
keil的软件逻辑分析仪(logic analyzer)使用教程在keil MDK中软件逻辑分析仪很强的功能,可以分析数字信号,模拟化的信号,CPU的总线(UART、IIC等一切有输出的管脚),提供调试函数机制,用于产生自定义的信号,如Sin,三角波、澡声信号等,这些都可以定义。
以keil里自带的stm32的CPU为例,对PWM波形跟踪观测,打开C:\Keil\ARM\Boards\Keil\MCBSTM32\PWM_2目录下的stm32的Dome,第一步:进行仿真配置,如图:(原文件名:1.jpg)把开工程中的Abstract.txt文件有对工程的描述,PWM从PB0.8和PB0.9输出,稍后将它加入软件逻辑分析仪里。
The 'PWM' project is a simple program for the STM32F103RBT6 using Keil 'MCBSTM32' Evalua tion Board and demonstrating the use of PWM (Pulse Width Modulation) with Timer TIM4 .Example functionality:- Clock Settings:- XTAL = 8.00 MHz- SYSCLK = 72.00 MHz- HCLK = SYSCLK = 72.00 MHz- PCLK1 = HCLK/2 = 36.00 MHz- PCLK2 = HCLK = 72.00 MHz- ADCLK = PCLK2/6 = 12.00 MHz- SYSTICK = HCLK/8 = 9.00 MHz- TIM4 is running at 100Hz.LEDs PB8, PB9 are dimmed using the PWM function of TIM4 channel3, channel4The Timer program is available in different targets:Simulator: - configured for software SimulatorMCBSTM32: - runs from Internal Flash located on chip(used for production or target debugging)第二、选择软件仿真(原文件名:2.jpg)第三、编译程序,如果程序没有错的话,将出现以下线框编译信息,然后进入调试,点出红色的“D"按,如下图所示(原文件名:3.jpg)第四步、打开软件逻辑分析仪图标,并把要观察的波形信号拉到逻辑分析仪里,如果进入调试状态下没有"sysbols"标签话,点击“View”菜单弹出来,从“Peripheral Register”里把要观察的(GPIOB_IDR输出的PWM信号会从这个寄存器反映出来)信号拖到逻辑析分析里,(原文件名:4.jpg)第五步、把不用的bit屏蔽掉,并按bit形式显示,配置如图(原文件名:5.jpg)第六步,点“GO”按钮进入全速运行,OK,PWM波形出来了,用IN和OUT可以调扫描时间,如下图STM32学习心得笔记憨牛电子时钟篇在STM32中,有五个时钟源,为HSI、HSE、LSI、LSE、PLL。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
keil的软件逻辑分析仪(logic analyzer)使用教程在keil MDK中软件逻辑分析仪很强的功能,可以分析数字信号,模拟化的信号,CPU的总线(UART、IIC等一切有输出的管脚),提供调试函数机制,用于产生自定义的信号,如Sin,三角波、澡声信号等,这些都可以定义。
以keil里自带的stm32的CPU为例,对PWM波形跟踪观测,打开C:\Keil\ARM\Boards\Keil\MCBSTM32\PWM_2目录下的stm32的Dome,第一步:进行仿真配置,如图:(原文件名:1.jpg)把开工程中的Abstract.txt文件有对工程的描述,PWM从PB0.8和PB0.9输出,稍后将它加入软件逻辑分析仪里。
The 'PWM' project is a simple program for the STM32F103RBT6 using Keil 'MCBSTM32' Evalua tion Board and demonstrating the use of PWM (Pulse Width Modulation) with Timer TIM4 .Example functionality:- Clock Settings:- XTAL = 8.00 MHz- SYSCLK = 72.00 MHz- HCLK = SYSCLK = 72.00 MHz- PCLK1 = HCLK/2 = 36.00 MHz- PCLK2 = HCLK = 72.00 MHz- ADCLK = PCLK2/6 = 12.00 MHz- SYSTICK = HCLK/8 = 9.00 MHz- TIM4 is running at 100Hz.LEDs PB8, PB9 are dimmed using the PWM function of TIM4 channel3, channel4The Timer program is available in different targets:Simulator: - configured for software SimulatorMCBSTM32: - runs from Internal Flash located on chip(used for production or target debugging)第二、选择软件仿真(原文件名:2.jpg)第三、编译程序,如果程序没有错的话,将出现以下线框编译信息,然后进入调试,点出红色的“D"按,如下图所示(原文件名:3.jpg)第四步、打开软件逻辑分析仪图标,并把要观察的波形信号拉到逻辑分析仪里,如果进入调试状态下没有"sysbols"标签话,点击“View”菜单弹出来,从“Peripheral Register”里把要观察的(GPIOB_IDR输出的PWM信号会从这个寄存器反映出来)信号拖到逻辑析分析里,(原文件名:4.jpg)第五步、把不用的bit屏蔽掉,并按bit形式显示,配置如图(原文件名:5.jpg)第六步,点“GO”按钮进入全速运行,OK,PWM波形出来了,用IN和OUT可以调扫描时间,如下图STM32学习心得笔记憨牛电子时钟篇在STM32中,有五个时钟源,为HSI、HSE、LSI、LSE、PLL。
①、HSI是高速内部时钟,RC振荡器,频率为8MHz。
②、HSE是高速外部时钟,可接石英/陶瓷谐振器,或者接外部时钟源,频率范围为4MHz~16MHz。
③、LSI是低速内部时钟,RC振荡器,频率为40kHz。
④、LSE是低速外部时钟,接频率为32.768kHz的石英晶体。
⑤、PLL为锁相环倍频输出,其时钟输入源可选择为HSI/2、HSE或者HSE/2。
倍频可选择为2~16倍,但是其输出频率最大不得超过72MHz。
其中40kHz的LSI供独立看门狗IWDG使用,另外它还可以被选择为实时时钟RTC的时钟源。
另外,实时时钟RTC的时钟源还可以选择LSE,或者是HSE的128分频。
RTC的时钟源通过RTCSEL[1:0]来选择。
STM32中有一个全速功能的USB 模块,其串行接口引擎需要一个频率为48MHz的时钟源。
该时钟源只能从PLL输出端获取,可以选择为1.5分频或者1分频,也就是,当需要使用USB 模块时,PLL必须使能,并且时钟频率配置为48MHz或72MHz。
另外,STM32还可以选择一个时钟信号输出到MCO脚(PA8)上,可以选择为PLL输出的2分频、HSI、HSE、或者系统时钟。
系统时钟SYSCLK,它是供STM32中绝大部分部件工作的时钟源。
系统时钟可选择为PLL输出、HSI或者HSE。
系统时钟最大频率为72MHz,它通过AHB分频器分频后送给各模块使用,AHB分频器可选择1、2、4、8、16、64、128、256、512分频。
其中AHB分频器输出的时钟送给5大模块使用:①、送给AHB 总线、内核、内存和DMA使用的HCLK时钟。
②、通过8分频后送给Cortex的系统定时器时钟。
③、直接送给Cortex的空闲运行时钟FCLK。
④、送给APB1分频器。
APB1分频器可选择1、2、4、8、16分频,其输出一路供APB1外设使用(PCLK1,最大频率36MHz),另一路送给定时器(Timer)2、3、4倍频器使用。
该倍频器可选择1或者2倍频,时钟输出供定时器2、3、4使用。
⑤、送给APB2分频器。
APB2分频器可选择1、2、4、8、16分频,其输出一路供APB2外设使用(PCLK2,最大频率72MHz),另一路送给定时器(Timer)1倍频器使用。
该倍频器可选择1或者2倍频,时钟输出供定时器1使用。
另外,APB2分频器还有一路输出供ADC分频器使用,分频后送给ADC模块使用。
ADC分频器可选择为2、4、6、8分频。
在以上的时钟输出中,有很多是带使能控制的,例如AHB总线时钟、内核时钟、各种APB1外设、APB2外设等等。
当需要使用某模块时,记得一定要先使能对应的时钟。
需要注意的是定时器的倍频器,当APB的分频为1时,它的倍频值为1,否则它的倍频值就为2。
连接在APB1(低速外设)上的设备有:电源接口、备份接口、CAN、USB、I2C1、I2C2、UART2、UART3、SPI2、窗口看门狗、Timer2、Timer3、Timer4。
注意USB模块虽然需要一个单独的48MHz时钟信号,但它应该不是供USB模块工作的时钟,而只是提供给串行接口引擎(SIE)使用的时钟。
USB模块工作的时钟应该是由APB1提供的。
连接在APB2(高速外设)上的设备有:UART1、SPI1、Timer1、ADC1、ADC2、所有普通IO口(PA~PE)、第二功能IO口。
下图是STM32用户手册中的时钟系统结构图,通过该图可以从总体上掌握STM32的时钟系统。
管脚篇我们操作STM32过程中对管脚的操作是比较频繁的工作之一,我们一般用提供的封装库来进行操作,因为它直观方便。
我们常用的有:GPIO_SetBits();GPIO_Writebit();GPIO_ResetBits();GPIO_ReadInputBit();GPIO_ReadOutputBit();等等它们具体怎么操作的我们是不用管的给我们一个接口就足够了,但是想学好STM32下一步最好使用它的原子操作,下面我们先学习一下关于管脚端口的一些寄存器。
由于上述命令操作是调用的一些函数故可能在调用的过程中可能被中断所打断产和想不到的后果但是如果调用寄存器函可以在一个时钟周期内完成,所以在一些关键的场合要使用对原子的直接访问。
要用到的寄存器有置位复位寄存器GPIOx_BSRR和复位寄存器GPIOx_BRR,后者是前者的一个子功能,GPIOx_BSRR包括置和复位二功能, 高16位是复位功能低16位是置位功能,高16位中对应位置1表示要复位这一管脚,其它写入0的位不改变原有的电平,而低16位置1是真的要使其位输出置1。
对于GPIOx_BRR寄存器写入对应位1时表示要复位输出这一管脚,复位时用哪个寄存器随你便好了,但是要使其置1时只能使用GPIOx_BSRR了。
说到这里你可能要说了:GPIOx_ODR不可以嘛?是真的可以,但是这里的输出0和1都是要反映到管脚是的,对于我们仅需要操作1个管脚时还要兼顾其它不需要改变的PIN,所以我们最好不要用这个寄存器来进行直接的操作。
常用的几个寄存器:上面的二个寄存器是设置寄存器的是输入还是输出,输入中包括模拟输入、上拉/下拉输入、还是悬空输入。
输出包括:推挽输出、开漏输出、复用推挽输出、复用开漏输出。
这个一个在程序初始化时要做的工作,利用封装的函数还是挺好的这点要是利用寄存器操作就划不来了。
读取端口管脚就是读取ch = GPIOx->IDR; 就是这么简单。
就是把一个16位的管脚值送给这个寄存器如:GPIOx->ODR=ch,如果只改变其中一管脚原来的不变,置1时没有问题可以这样做GPIOx->ODR |=1<<n但是使某一位清0时怎么办呢?可以这样来做GPIOx->ODR &= `(1<<n); 当然还可以用另外的二个寄存器来达到目的。
用GPIOx->BRR=0x00008000方便些。
前面的0x00008000只第15脚而已。
下面贴出复位/置位寄存器和复位寄存器来不说了。
下面通过宏命令,使控制GPIO来的更加方便#define BITBAND(addr bitnum) ((addr &0xF0000000)+0x2000000+((addr&0xFFFFF)<<5)+(bitnum<<2))#define MEM_ADDR(addr) *((volatile unsigned long *)(addr))#define BIT_ADDR(addr bitnum) MEM_ADDR(BITBAND(addr bitnum)) //IO#define GPIOA_ODR_Addr (GPIOA_BASE+12) //0x4001080C#define GPIOB_ODR_Addr (GPIOB_BASE+12) //0x40010C0C#define GPIOC_ODR_Addr (GPIOC_BASE+12) //0x4001100C#define GPIOD_ODR_Addr (GPIOD_BASE+12) //0x4001140C#define GPIOE_ODR_Addr (GPIOE_BASE+12) //0x4001180C#define GPIOF_ODR_Addr (GPIOF_BASE+12) //0x40011A0C#define GPIOG_ODR_Addr (GPIOG_BASE+12) //0x40011E0C#define GPIOA_IDR_Addr (GPIOA_BASE+8) //0x40010808#define GPIOB_IDR_Addr (GPIOB_BASE+8) //0x40010C08#define GPIOC_IDR_Addr (GPIOC_BASE+8) //0x40011008#define GPIOD_IDR_Addr (GPIOD_BASE+8) //0x40011408#define GPIOE_IDR_Addr (GPIOE_BASE+8) //0x40011808#define GPIOF_IDR_Addr (GPIOF_BASE+8) //0x40011A08#define GPIOG_IDR_Addr (GPIOG_BASE+8) //0x40011E08//IO IO!//n 16!#define PAout(n) BIT_ADDR(GPIOA_ODR_Addrn) //#define PAin(n) BIT_ADDR(GPIOA_IDR_Addrn) //#define PBout(n) BIT_ADDR(GPIOB_ODR_Addrn) //#define PBin(n) BIT_ADDR(GPIOB_IDR_Addrn) //#define PCout(n) BIT_ADDR(GPIOC_ODR_Addrn) //#define PCin(n) BIT_ADDR(GPIOC_IDR_Addrn) //#define PDout(n) BIT_ADDR(GPIOD_ODR_Addrn) //#define PDin(n) BIT_ADDR(GPIOD_IDR_Addrn) //#define PEout(n) BIT_ADDR(GPIOE_ODR_Addrn) //#define PEin(n) BIT_ADDR(GPIOE_IDR_Addrn) //#define PFout(n) BIT_ADDR(GPIOF_ODR_Addrn) //#define PFin(n) BIT_ADDR(GPIOF_IDR_Addrn) //#define PGout(n) BIT_ADDR(GPIOG_ODR_Addrn) //#define PGin(n) BIT_ADDR(GPIOG_IDR_Addrn) //#define led0=PAout(8)使用时可以led0=0; 或者led0=1; 像不像51中的控制。