MC68K CPU简介 μC-OS-II向MC68K的移值.doc

上传人:白大夫 文档编号:3256000 上传时间:2019-08-06 格式:DOC 页数:4 大小:19KB
返回 下载 相关 举报
MC68K CPU简介 μC-OS-II向MC68K的移值.doc_第1页
第1页 / 共4页
亲,该文档总共4页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《MC68K CPU简介 μC-OS-II向MC68K的移值.doc》由会员分享,可在线阅读,更多相关《MC68K CPU简介 μC-OS-II向MC68K的移值.doc(4页珍藏版)》请在三一文库上搜索。

1、MC68K CPU简介 C/OS-II向MC68K的移值一、MC68K CPU简介MC68K及68020、68040等的著名的MOTOROLA32位微处理器,和与之兼容的68K、CPU32、CPU32+等CPU扩充定时处理单元TPU、队列串行模块QSM、系统控制模块和RAM等组成MC683xx系列单片机。CPU32 内部有8个32位通用数据寄存器,8个32位通用地址寄存器。8个通用数据寄存器可作为累加器使用,也可看成C语言中各种类型的变量;8个通用地址寄存器,可作为变址寄存器使用,也可看成C语言中的指针型变量。CPU32有独立的用户堆栈指针和系统堆栈指针,可区分程序区、数据区、系统区、用户区等

2、存储空间,有7级中断。要实现C/OS-II向MC68K的移值,需要有MC68K的C编译器。我们使用的HIWARE公司的C编译器。该C编译器允许嵌入行汇编。二、移植中所需修改的文件和CPU相关的文件主要有三个:C语言文件OS_CPU32.C、头文件OS_CPU32.H和汇编文件OS_CPU32.ASM。1.INCLUDES.H文件INCLUDES.H 是主头文件,在所有后缀名为.C文件的开始都包含INCLUDES.H文件。对于不同类型的处理器,用户需要改定INCLUDES.H文件,增加自己的头文件,但必须加在文件末尾。在安装C/OS-II的时候,附带了几个移植实例,例如,针对Intel 80x8

3、6的代码安装到IIL目录。我们为MC68K编写的移植实例都放在II下,在INCLUDES.H文件中增加有:#include iiK_CPU32.ASM#include iiK_CPU32.C#include iiK_CPU32.H2.OS_CPU32.H文件OS_CPU32.H文件中定义了与硬件相关的基本信息:typedef unsigned char INT8U; /*无符号8位数*/typedef signed char INT8S; /*带符号8位数*/typedef unsigned int INT16U; /*无符号16位数*/typedef signed int INT16S; /

4、*带符号16位数*/typedef signed long INT32S; /*带符号32位数*/typedef unsigned int OS_STK; /*堆栈入口宽度为16位*/#define OS_STK_GROWTH1 /*堆栈由高地址向低地址增长*/#define UCOS 0 /*用于任务切换的软中断*/define OS_TASK_SW() _TRAP(UCOS)#define OS_ENTER_CRITICAL() move.w#$2700,SR /*进入临界区*/#define OS_EXIT_CRITICAL() move.w #$2000,SR /*退出临界区*/(1)

5、数据类型由于不同的处理器有不同的字长,C/OS-II的移植需要重新定义一系列的数据结构。由于 MC68K为32位MCU,整数(int)类型数据为16位,长整开有(long)为32位。在MC68K中堆栈都是按字进行操作的,所以堆栈数据类型 OS_STK声明为16位。所有的堆栈必须用OS_STK声明。(2)代码临界区C/OS -II在进入系统临界代码区之间要关中断,等到退出临界区后再打开,从而保护核心数据不被多任务环境下的其他任务或中断破坏。在MC68K中,开关中断可以通过设置状态寄存器SR中的中断屏蔽位来实现。C/OS-II中的宏OS_ENTER_CRITICAL()定义将状态寄存器的中断屏蔽位

6、置位,屏蔽所有的七级中断;OS_EXIT_CRITICAL()定义将状态寄存器的中断屏蔽位清零,打开所有的七级中断。这种处理方法非常简单,但CPU32提供分级中断机制得不到使用。如果要使用分级中断,必须改写一些相关的函数,将在第4节中阐明。(3)堆栈方向MC68K处理器的堆栈是由高地址向低地址递减的,所以OS_STK_GROWTH必须设置为1。(4)OS_TASK_SW()函数的定义在C/OS -II中,OS_TASK_SW()用来实现任务切换。就绪任务的堆栈初始化应该模拟一次中断发生后的样子,椎栈中应该按入栈次序设置好各个寄存器。 OS_TASK_SW()函数模拟一次断过程,在中断返回的进修

7、进行任务切换。CPU32有16个软中断可供选用,称为陷阱TRAP调用。中断程序程序的入口必须指向汇编函数OSCtxSw()。我们在C/OS-II所提供的例程中使用的0号陷阱调用,由下面的语句完成定义:#define OS_TASK_SW() -TRAP(UCOS)3.OS_CPU32.ASM文件C/OS-II的移植需要用户改写OS_CPU_A.ASM中的4个函数:OSStartHighRdy()、OSCtxSw()、OSINTCtxSw()和OSTICkISR()。(1)OSStartHighRdy()函数该函数由OSStart()函数调用,功能是运行优先级最高的就绪态任务。在调用OSStar

8、t() 之前,用户必须先调用OSInit(),并且已经至少创建了一个任务。为启动任务,OSStartHighRdy()首先找到当前就绪的优先级最高的任务,OSTCBHighRdy中保存有优先级最高任务的任务控制块(TCB)的地址,并从任务的任务控制块中找到指向堆栈的指针,然后运行指令 MOVEM.L(A7)+,A0-A6/D0-D7,从堆栈中弹出全部寄存器的内容,运行RTE中断返回。由于任务创建时堆栈的结构就是按中断捕捞堆栈结构初始化的,执行RET指令后就切换到了新任务。有关C/OS- II的任务切换机制,请参考系列计座(3).OSStartHighRdy的汇编代码如下:_OSStarHighRdyMOVE.L(_OSTCBHighRdy),A1;获取最高优先级就绪任务的TCB地址MOVE.L A1,(_OSTCBCur)MOVE.L (A1),A7 ;取得堆栈指针MOVEM.L (A7)+,A0-A6/D0-D7RTE ;中断返回,切换任务(2)OSCtxSw( )函数

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 其他


经营许可证编号:宁ICP备18001539号-1