OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3647|回复: 11

倾家荡产+17年积分~~~悬赏STM32F105软件仿真出错的问题

[复制链接]

1

主题

4

帖子

0

精华

新手入门

积分
8
金钱
8
注册时间
2016-12-1
在线时间
1 小时
发表于 2016-12-1 20:31:38 | 显示全部楼层 |阅读模式
6金钱
本人小白,第一次使用STM32F105芯片,现在硬件平台还没有搭好,源代码是网上找的,之前coide平台,现在我已经移植到mdk编译通过了,我想用mdk软件仿真一下,看一下代码执行过程,但是遇到一点问题,在网上搜了一下,了解到有两种办法,但是这两种我都试了,都没有成功,请大神指点一下,两种方法如下:

我要选择的型号是105RC,所以先用105的默认配置试一把
方法1:(增加没有权限的地址)
1.JPG 2.JPG
以上配置,debug后报0x0000000c没有“读”权限,如下
3.JPG

在网上查资料有人说把没有权限的地址加上就可以,然后就把0x0000000c的读权限加上,结果又报另外的地址没有“读”权限,一直不断的加,还是一直再报新的地址没有“读/写/执行”的权限,程序根本有跑起来,所以我个人觉得不是这个地址的权限问题,换网上大神说的另一种方法,香菇。。。
8.JPG
方法2:(修改debug选项中Dialogue DLL和Parameter的值)
5.JPG
修改后可以跑程序了,但是一直在SetSysClockTo72(void)这个函数的while((RCC->CR & RCC_CR_PLL2RDY) == 0)循环中出不来,无法进入到main()函数中
6.JPG
7.JPG



请大神指点一下,是我设置的不对,还是什么原因,小弟在这里先谢过了,6分有点少,但这是我的全部家当,如果解决了这个问题,小弟以后1年的积分全部奉上

4.JPG

最佳答案

查看完整内容[请看2#楼]

你是不是 软仿真, 然后 芯片用的 外部高速时钟了, 自己对一下. 要内部高速晶振的 你都没有实际的 外部晶振, 当然程序 停在 等待外部晶振OK 上了. 定义 HSI 而不是HSE
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

1

主题

43

帖子

0

精华

初级会员

Rank: 2

积分
152
金钱
152
注册时间
2015-10-8
在线时间
32 小时
发表于 2016-12-1 20:31:39 | 显示全部楼层
本帖最后由 lavion 于 2016-12-2 01:16 编辑

你是不是 软仿真, 然后  芯片用的 外部高速时钟了,   自己对一下.   要内部高速晶振的

你都没有实际的 外部晶振,    当然程序 停在  等待外部晶振OK 上了.   定义 HSI  而不是HSE
回复

使用道具 举报

27

主题

711

帖子

0

精华

版主

Rank: 7Rank: 7Rank: 7

积分
12491
金钱
12491
注册时间
2015-11-5
在线时间
2142 小时
发表于 2016-12-1 22:06:22 | 显示全部楼层
倾家荡产还不够,得把媳妇也压上
拿来长岛冰茶换我半晚安睡
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2016-12-1 22:49:39 | 显示全部楼层
别折腾了,用硬件仿真。。。
回复

使用道具 举报

120

主题

7878

帖子

13

精华

资深版主

Rank: 8Rank: 8

积分
12012
金钱
12012
注册时间
2013-9-10
在线时间
427 小时
发表于 2016-12-2 08:53:43 | 显示全部楼层
来硬的,别软的
现在,程序把烂铜烂铁变得智能化了,人呢,一旦离开了这烂铜烂铁就不知道干啥了
回复

使用道具 举报

4

主题

290

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1130
金钱
1130
注册时间
2015-8-4
在线时间
107 小时
发表于 2016-12-2 08:57:56 | 显示全部楼层
4楼的应该是真的。
一般模拟你也搞不出来啥,还要改代码,很麻烦。
活到老,学到老。
回复

使用道具 举报

30

主题

1170

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1993
金钱
1993
注册时间
2016-2-16
在线时间
527 小时
发表于 2016-12-2 09:34:35 | 显示全部楼层
为什么要弄软件仿真呢,直接硬的啊
回复

使用道具 举报

17

主题

344

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1280
金钱
1280
注册时间
2013-12-14
在线时间
567 小时
发表于 2016-12-2 09:50:59 | 显示全部楼层
感觉四楼说的对,楼主去看一下手册,搞明白RCC->CR这个寄存器每个位的含义。

我猜测那个SetSysClockTo72中的那个while是检测HSE的,软仿没有HSE,所以你的程序就死到那里了。
半导体->模拟电路->数字电路->单片机->汇编->C->操作系统->java
回复

使用道具 举报

17

主题

344

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1280
金钱
1280
注册时间
2013-12-14
在线时间
567 小时
发表于 2016-12-2 09:52:41 | 显示全部楼层
软件仿真还是有意义的,楼主没有硬件平台,先软仿一下,熟悉一下大致功能,板子出来以后,上手还是会快一点的。
半导体->模拟电路->数字电路->单片机->汇编->C->操作系统->java
回复

使用道具 举报

1

主题

4

帖子

0

精华

新手入门

积分
8
金钱
8
注册时间
2016-12-1
在线时间
1 小时
 楼主| 发表于 2016-12-2 10:23:40 | 显示全部楼层
http://blog.sina.com.cn/s/blog_46d528490101qadk.html这个帖子的办法可以解决这楼主的问题,注意read和write的前后都要有空格

MDK软件在模拟仿真时,不能很好地支持各种STM32系列芯片,目前对STM32F103系列芯片支持模拟仿真,但对于其他系列芯片不支持或只是部分支持。主要存在的问题是:PC和SP不能自动装载,存储器不能访问,中断服务程序不能执行或触发,外设寄存器不能修改或观察。要解决上述问题,必须通过相应的设置和相关的操作,才能完成模拟仿真。
1 模拟仿真的实现及PC和SP的自动装载
  在MDK软件中,只有部分STM32芯片支持模拟仿真(如STM32F103),大部分芯片都不支持模拟仿真。主要的问题是,当进入调试界面后,R15 (PC)的值为0x00000000,不能进行调试操作(如单步、全速等)。要能对STM32进行模拟仿真,必须使PC的值不能为0。通过分析STM32芯片的存储器结构可知,在存储器地址0x00000000处保存的是堆栈指针SP的值,程序加载时自动把该值送给SP,在存储器地址0x00000004处保存的是程序指针PC的值,程序加载时自动把该值送给PC,程序从该PC值取指令执行程序,而不是从地址0x00000000处执行程序。而STM32芯片的Flash程序存储器地址是从0x08000000处开始的,当进入模拟仿真时,MDK软件不能把Flash的地址送给PC和SP。可通过以下操作步骤完成PC和SP的自动装载。
①打开MDK自带的工程文件,如C:\\Keil\\ARM\\Boards\\ST\\STM3240GEVAL\\Blinky\\Blinky.uvproj。
②单击“编译”工具栏上面的下拉菜单,选择“STM32F407 Flash”。
③单击,打开“Options”对话框,切换到“Output”选项卡,勾选“Debug Information”和“Browse Information”,用以产生调试信息。再切换到“Debug”选项卡,单击“Use Simulator”,选择模拟仿真,确保勾选“Load Application at Startup”,其他为默认设置。
④单击,编译程序,并保证编译成功。
⑤单击,开始调试,进入调试界面后,观察“Registers”寄存器选项卡中的R15 (PC)的值,如果值为0,则说明不能进行模拟仿真,“单步”调试等无效,须进行步骤⑥的操作,否则可不进行步骤⑥的操作。
⑥停止调试,再次单击,打开“Options”对话框,切换到“Target”选项卡,将IROM1的值[0x08000000,0x100000]修改为[0x0,0x100000],以使Flash的起始地址从0x0开始。单击重新编译程序,再次单击,开始调试,PC的值将不再为0,即可进入模拟仿真,“单步”调试等有效。
2 存储器的访问
  当进入模拟仿真界面后,按“全速”F5或“单步”F10调试键后,在“command”窗口中将会出现类似如下的错误提示:“***  error 65: access violation at 0x40023800 : no ′read′ permission”,意思是在地址0x40023800处访问违例,没有“读”的权限。地址0x40023800是外设寄存器地址。要使外设寄存器地址具有相应的“读”、“写”、“执行”权限,可在命令窗口中输入MAP命令(不区分大小写)。命令格式为:
  MAP 起始地址,结束地址 READ WRITE EXEC其中,READ表示“读”权限,WRITE表示“写”权限,EXEC表示“执行”权限,结束地址与起始地址的空间尺寸不超过128 MB,即不超过0x08000000字节。外设寄存器的存储空间分布较广,不可能在每次调试时都通过命令窗口输入MAP指令,可通过如下的操作步骤进行。
①新建一个文本文件,打开该文件,执行文件菜单命令“另存为”,在打开的“另存为”对话框中,文件名输入为initmap.ini,保存类型选择为“所有文件”,并保存。在文件中输入如下内容并保存:
map 0x40000000,0x47ffffffreadwrite
map 0x50000000,0x57ffffffreadwrite
map 0xa0000000,0xa7ffffffreadwrite
map 0xf0000000,0xf7f00000 readwrite
根据需要,可在该文件中输入包含所有外设寄存器的MAP命令,使所有外设寄存器都具有“读”、“写”权限。但注意映射空间不要超过0x08000000,否则调试时会提示错误:“***  error 129: MapMemmap size truncated to 128MB”。
②单击,打开“Options”对话框,切换到“Debug”,在“Initialization File”的右边单击,打开“选择仿真初始化文件”对话框,选择上一步保存的initmap.ini文件。单击“Edit”按扭,可打开文件再次修改。
3 中断服务程序的执行与触发
  当解决以上的两个问题后,可以进行模拟仿真调试。但这时中断服务程序不能执行,如系统定时中断程序;或者不能触发中断,如不能自动触发SPI中断程序等。由于已经把Flash存储器的起始地址调到了0x00000000处,所以也需要把中断向量偏移量地址设为0x00000000,即把SCB-﹥VTOR设为0。可通过如下方法解决。
①对于通过访问SCB-﹥VTOR寄存器来修改中断向量的,可通过“Edit”菜单命令中的“Find in Files”命令查找SCB-﹥VTOR,查找并修改宏定义FLASH_BASE的值为0X00000000。
②如果不能通过以上的方法修改SCB-﹥VTOR,可以在进入仿真界面后,执行中断程序前,选择“Peripherals”→“Core Peripherals”→“Nested Vectored Interrupt Controller”命令,打开中断向量对话框,修改VTO的值为0x00000000。当然也可以通过如下的方法完成对外设寄存器SCB-﹥VTOR的修改,使它的值为0x00000000:当进入仿真后,在主函数main()前设置一个断点,全速运行程序,程序在断点处暂停执行,通过下节介绍的方法把外设寄存器SCB-﹥VTOR添加到观察窗口1,修改SCB-﹥VTOR外设寄存器的值,使它的值为0x00000000即可。
③对于SysTick定时器,可以自动触发中断,并执行中断程序,但对于其他的中断则不能自动触发中断。可按如下方法操作:在中断程序中设一个断点,并“全速”运行程序,通过选择“Peripherals”→“Core Peripherals”→“Nested Vectored Interrupt Controller”命令,打开中断向量对话框,单击选择相应的中断,然后勾选Pending复选框,此时会自动执行相应的中断服务程序,并在断点处暂停执行程序。
4 外设寄存器的修改
  在模拟仿真时,一般要对外设寄存器进行修改,有些外设寄存器可直接修改,有些外设寄存器不能直接修改,如只读位不能直接修改。要实现对外设寄存器的修改,可通过如下的方法进行操作。
①对于要修改的寄存器,可通过鼠标选择外设寄存器,如选择RCC-﹥CR,然后再鼠标右键,弹出右键菜单,执行“Add‘RCC-﹥CR ’to…”→“Watch 1”菜单命令,把RCC-﹥CR外设寄存器添加到观察窗口1中,如下所示。
  此时可在编辑框中修改该外设寄存器的值。当然也可在观察窗口中,直接输入外设寄存器的名称“RCC-﹥CR”,但此种方法对某些芯片会失效。
②用以上方法也不能完成外设寄存器的修改时,可通过如下方法完成修改。停止仿真,单击,打开“Options”对话框,切换到“Target”选项卡,确保特殊功能寄存器(sfr)文件已被添加。然后单击的下拉箭头,选择并添加所要观察的外设,如RCC等,可添加观察多个外设。单击添加的外设寄存器,可在下方显示该外设寄存器的存储器地址,如RCC-﹥CR外设寄存器的地址为0x40023800。最后再选择“ View”→“Memory Windows”→“Memory 1”打开存储器观察窗口,在地址栏中输入地址“0x40023800”,按回车键确认输入,在数据区双击数据可直接修改。STM32的存储器采用小端模式,即低地址存放数据的低位,高地址存放数据的高位。在存储器窗口中,可通过右键修改显示方式。
结语
  目前最新的MDK版本也未能解决在模拟仿真时出现的上述问题,通过本文介绍的方法则可以解决,这对于学习STM32,以及使用MDK软件都有一定的帮助。以上介绍的方法是一个全面的描述,不是所有的芯片都需要通过以上步骤来完成,有的只需要部分操作即可完成
回复

使用道具 举报

1

主题

4

帖子

0

精华

新手入门

积分
8
金钱
8
注册时间
2016-12-1
在线时间
1 小时
 楼主| 发表于 2016-12-2 10:28:13 | 显示全部楼层
今天早上起来看到一个微博里的方法(参见10楼),按照里边的介绍可以进入main函数了,2楼所说的方法稍后再试一下,不过还是先把悬赏奉上,多谢了
回复

使用道具 举报

1

主题

4

帖子

0

精华

新手入门

积分
8
金钱
8
注册时间
2016-12-1
在线时间
1 小时
 楼主| 发表于 2016-12-2 10:33:26 | 显示全部楼层
FreeRTOS 发表于 2016-12-1 22:06
倾家荡产还不够,得把媳妇也压上

媳妇不行,压我自己可以考虑
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-5-25 18:23

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表