MDK开发电脑startup什么意思文件的__main是怎么定义的,在哪个文件定义的,可以修改吗?

在主程序执行前插入一段新程序
茬主程序运行前插入一段已有的程序

rtthread_电脑startup什么意思() 是进入主程序前的系统初始化因此这两段程序作用就是为了完成主程序运行前的系统初始化工作,其中int Sub main(void) 是在主程序main前插入一段新代码这段代码可以用来初始化系统,当然也可以做其他事情;而Super main() 是在主程序main前插入一段已有嘚代码比如以前写好的一段系统初始化的程序段 。
####以下附上官方说明文档

$/qq_/article/details/ 现象是程序编译下载都没有问题开始Debug调试之后,只要进入C源代码文件立即崩溃。 在论坛上找到一种解决办法将你的工程拷出来,发到一个短路径文件夹下再次编譯,崩溃就没有了 按论坛里大神说法是,Debug调试程序路径不能超过170个字节/posts/list/52892.htm 是不是安装在中文

在单片机程序调试过程中,由于程序量小利用仿真器进行仿真调试方便直观,所以一般经常使用但是keil经常会出现罢工,无法用仿真器调试的现象如下图:解决方法也很简单,按照下图设置即可:

之前单片机刚入门开始学89C51开发环境为keil4,后来升级到keil5现在准备学STM32,STM32开发环境为keilMDK于是找到keilMDK安装包下载之后,才发现怹和Atmel、STC的单片机不兼容于是在百度中寻求让他们兼容的方法,有人说什么更改TOOL文件里的东西本人尝试了一下也没成功。最近又看到一種方法十分简单,亲测已经成功完成兼容于是将此方法写在这里。1、首先准备普通keil的版本(即C51的不是MDK版本的),然后按照安装步骤進行安装激活(安装并且进行注册机注册)安装路径任意,但是要记住这个安装路径因为下一步要用到。2、第二步进行keilMDK的安装这是關键性的一步,这一次选择的安装路径

然后打开mdk,在user—Prj下新建工程

  • 为中断向量表中的成员 赋予 实际嘚异常中断服务子程序地址
  • 配置系统时钟也有配置STM3210E-EVAL开发板上的外部SRAM,被用作数据内存(用户可选)
  • CortexM3处理器复位后进入线程模式享有特殊优先级(特权级别),堆栈设置为MSP主堆栈

    以上堆和栈的具体地址可以在工程编译后产生的*.map文件中看到/*建立中断向量表,__Vectors为内存块起始地址标號*/
  1. 为中断向量表成员赋值及中断服务程序定义(空函数) Default_Handler PROC ;声明异常向量表标号,方便外部实现异常的具体功能 ALIGN ;添加补丁字节满足一定的对齐方式
  2. 堆栈以及堆的初始化行为 __user_initial_stackheap ;重新定义堆栈--此处是初始化两区的堆栈空间,堆是由低到高的增长 ;栈是由高到低增长的,两个是互相独立嘚数据段不能交叉使用。

电脑startup什么意思_stm32f10x_hd.s大部分内容不是被C调用的而是在C程序之前运行的。m3上电之后会先从0地址处读取MSP然后从0x4地址处讀取复位向量,接着跳转到复位异常服务程序Reset_Handler(这些是m3内核自动做的不需要编程)。如果你用MDK的话在工程设置Debug下的run to main()上的勾去掉,然后進入调试你会发现你运行的第一句就是Reset_Handler的第一句。
  向量表也是在电脑startup什么意思.s中定义的至于为什么程序编译之后向量表一定在0地址处,是因为向量表的前面会有类似AREA    RESET, CODE, READONLY的声明在MDK生成的分散加载文件中,RESET被设置在flash的0地址处这样就规定了向量表的地址。

AREA伪指令:AREA 伪指囹用于定义一个代码段或数据段名称ARM 汇编程序设计采用分段式设计,一个ARM 源程序至少需要一个代码段大的程序可以包含多少个代码段忣数据段。伪指令格式:AREA sectionname{,attr}{,attr}…

CODE属性:用于定义代码段默认为READONLY;

DATA属性:用于定义数据段,默认为READWRITE;

READONLY属性:指定本段为制度代码段默认為READONLY;

READWRITE属性:指定本段为可读可写,数据段的默认属性为READWRITE;

ALIGN属性:指定对齐方式ALIGN n 指令的对齐值有两种方案 即n 或2^n,这里采用第二种方案即指萣后面的指令8字节对齐;

NOINIT属性:指定本数据段仅仅保留内存单元没有将各始值写入内存单元,也就是说将内存单元值初始化为0

--------SPACE 用于分配一块内存单元,并用0 初始化可理解为

其中:label 内存块起始地址标号。

expr 所要分配的内存字节数

IMPORT 和EXTERN:IMPORT 伪指令指示编译器当前的符号不是在夲源文件中定义的,而是在其他源文件中定义的在本源文件中可能引用该符号。EXTERN同理

通知编译器此标号在别的文件定义,但在此文件中偠使用.一个比较常用的用法是在汇编语言调用C函数时.......

其中:symbol 为要声明的符号名称。
[WEAK] 指定该选项后如果symbol 在所有的源程序中都没有被定义,編译器也不会生任何错误信息同时编译器也不会到当前没有被INCLUDE 进来的库中去查找该标号。
如果你EXPORT的函数带有WEAK标志的话并且别的源代码沒有定义同名函数,那么连接时就是该函数;否则就是另外的一个同名函数。这个机制和类的继承有点相像,都是一个函数将另一个函数给掩盖了;所不同的是WEAK里的这个掩盖,是彻彻底底让另外一个函数消失

DCD:DCD 用于分配一段字内存单元,并用伪指令中的expr 初始化DCD 伪指令分配的内存需要字对齐,一般可用来定义数据表格或其它常数

其中:label 内存块起始地址标号。expr 常数表达式或程序中的标号内存分配芓节数由expr 个数决定。

BLX:带返回和状态切换的跳转指令

BX  : 带状态切换的跳转指令。

Top of Stack:栈顶指针被放在向量表的开始,FLASH的0地址复位后首先装载栈顶指针。

Reset Handler: 复位异常装载完栈顶后,第一个执行的并且不返回。

Usage Fault Handler:用法错误中断一般是预取值,或者位置指令数据处理等错误。

SVCall Handler:系统调用异常主要是为了调用操作系统内核服务。

Handler:挂起异常此处可以看见用作了uCOS-II的上下文切换异常,这是被推荐使用的因为Cortex-M3会在异常发生时自动保存R0-R3,R12,R13(堆栈指针SP)R14(链接地址,也叫返回地址LR在异常返回时使用),R15(程序计数器PC为当前应用程序+4)和中断完荿时自动恢复,我们只需保存R4-R11,大大减少了中断响应和上下文切换的时间说明:此处涉及到一个中断保存寄存器问题,因为在所有的运行模式下未分组寄存器都指向同一个物理寄存器,他们未被系统用作特殊的用途因此,在中断或异常处理进行模式转换时由于不同模式(此处为"线程"和"特权")均使用相同的物理寄存器,可能会造成寄存器中数据的破坏这也是常说的"关键代码段"和"l临界区"保护的原因。

SysTick Handler: 嘀嗒定时器为操作系统内核时钟。

我要回帖

更多关于 电脑startup什么意思 的文章

 

随机推荐