试论将μC/OS-II用于单片机教学
关键词:单片机 嵌入式 RTOS μC/OS 教学 培训
引 言
??在2003年天津举行的“全国单片机及嵌入式系统学术年会”上,来自全国各地几十所大学的教师对单片机与嵌入式系统教学展开了热烈的讨论。这里,就我们的认识介绍如下,以达到抛砖引玉的目的。
1 单片机与嵌入式系统应用类课程的转型期
当前,单片机与嵌入式系统应用类课程正处在转型期。过去的20年中,单片机市场与需求都是以8位机为主的。最近几年来,16位、32位单片机的嵌入式应用呈迅速增长的趋势。在一两年后,数量上虽然仍会以8位为多,但32位单片机在产值上会超过8位单片机,如图1、图2所示。今后,单片机应用将呈现8位、16位、32位单片机并举的格局。
由于单片机系统的需求越来越复杂、集成电路技术发展又非常快,片上存储器容量不断扩大,使得在片上系统的开发中,使用嵌入式实时操作系统(RTOS)成为可能。计算机对于90%以上的学生都不能是他的专业,而只是一种工具。同各行各业开发单片机应用的工程师一样,非计算机专业的学生来自各个领域,他们不可能将主要精力花在研究操作系统上,而是要把主要精力放在所研究的专业上,他们需要的是把计算机专家们研究的成果直接拿来使用。RTOS可以将一个复杂的应用分解成多个任务,从而简化应用程序的设计;RTOS可以保证系统的实时性达到或接近理论上可以达到的最好水平。而多任务本身会带来一系列的问题,主要是任务间的竞争、死锁、优先级反转、任务间同步与通信等。这些问题有RTOS为用户考虑,只要知道RTOS的原理,会使用就可以了。故单片机教学的这次转型,引入RTOS概念是一大特点。
2 单片机教学史的回顾与思考
回忆过去我国单片机教学走过的路,大多数院校都是从8051走过来的。故8051在国内普及单片机应用方面功不可没。而总结一下由8051教学模式带来的副作用,将有利于目前的转型。
图1
一个副作用是,教学中以一片8051配以不同的外围电路去适应各种不同的应用。这就忽略了单片机应用的多样性和单片机应用的个性化定位。单片机姓“单”,世界上的单片机至少有上千种,每种单片机都有各自的定位。我们强调的是SoC,即片上系统,只有将整个系统都集成在一个集成电路芯片上,才能做到低成本、高可靠性。只有在不得已的情况下,才扩充额外的接口芯片。故应告诉学生,虽然学的是某种单片机,但针对不同的应用要选择最适宜的单片机。单片机教学要求教师教会学生一种方法,会用这种单片机,自然也会用其它单片机。
过去8051教学引入的另一误区是使用仿真器。如果说过去开发掩膜型单片机使用仿真器属不得已,则如今单片机都采用了可以反复擦写十万次以上的Flash存储器,实在没有必要使用仿真器。本人在过去20年的单片机应用开发中,就从来没有用过仿真器,并非没有仿真器可用,只是不主张使用仿真器,特别不主张使用仿真器教学。仿真器使单片机开发变得不直观,高价的仿真器增加了开发成本,也增加了教学的负担。开发者不可能为每一类单片机买一种仿真器,只好以自己有仿真器的那种单片机去适应所有的应用,从而误入歧途。
3 是教学还是培训
我们这里讲的是教学,不是培训,教学不同于培训。俗话说,“授之以鱼不如授之以渔”。教学是“授之以渔”,授之以解决问题的方法,培养解决问题的能力,是引导学生入门。通过授课与实验,要求学生能做到三个看懂,看懂原文手册、看懂硬件原理图、看懂别人写的程序。在此基础上学会如何掌握一种自己不熟悉的单片机。我们讲CPU硬件结构,讲汇编指令集,教学生如何初始化串行口,从而实现与单片机的CPU“对话”,进而学会写监控程序,然后将如何与C语言接口,以μC/OS-II为例,讲RTOS基本概念,进而移植μC/OS-II。
培训的目的是让用户尽快上手,一周乃至三天后就可以开始写应用程序。培训是“授之以鱼”,培训的典型例子是教学生如何使用某单片机的仿真器。
教学,强调的是引导学生入门,只要我们能正确地引导学生入门,告诉他们什么是正确的方法,后面的路他们会自己走。
4 将μC/OS用于RTOS教学
1995年以后,我们逐渐将μC/OS、μC/OS-II引进单片机应用的科研与教学,证明是成功的。μC/OS、 μC/OS-II是专门为嵌入式应用设计的实时内核,适用于几乎所有8位、16位、32位单片机;90%以上与硬件无关的代码用C语言写成,用汇编语言写的与硬件相关的代码不足200行;有PC机上可运行的范例;有针对数十种知名CPU的移植范例可直接从网上下载;有注解清晰、书写规范的全部源代码。有一部600页的书对RTOS基本概念、内核原理做了详尽的描述,随书所附光盘上的μC/OS-II V2.52通过了美国航空航天管理局的安全认证,可用在与人性命攸关的控制系统中,是一部科学、实用的好教材。该内核的前身是μC/OS,最早的版本是为M
《试论将μC/OS-II用于单片机教学》