流浪的天空
流浪的天空
-
单片机温度检测课程设计,和步进电机课程设计下载
2008-02-03
单片机温度检测课程设计,和步进电机课程设计下载
http://weblook.blogbus.com/files/12020155622.doc
http://weblook.blogbus.com/files/12020155621.doc
http://weblook.blogbus.com/files/12020155620.doc -
机械夹具课程设计 机械系统设计课程设计下载
2008-02-03
网上资源有设计指导书.:http://www.gfxy.com/jpkc/jiaju/sheji/夹具课程设计指导书.doc 机械夹具课程设计 机械系统设计课程设计下载
http://weblook.blogbus.com/files/12020146310.rar
全部课程设计在www.csdn.net 下载频道里面搜索夹具课程设计 有2个部分。自己下吧
http://do... -
长春一汽实习报告
2008-02-03
长春一汽实习报告下载长春一汽实习报告下载长春一汽实习报告下载长春一汽实习报告下载
以上传到csdn上了
http://download.csdn.net/source/308335
长春一汽实习报告下载长春一汽实习报告下载长春一汽实习报告下载长春一汽实习报告下载长春一汽实习报告下载
-
我 的资源
2008-02-03
研华PCL818中文手册 研华PCL818中文手册
Tag: 研华PCL818中文手册 发布日期:2007-12-14 18:33:02
有人下载
pdf 绿色软件 pdf 绿色软件 pdf 绿色软件
Tag: pdf 绿色软件 发... -
搜索引擎
2008-02-01
登录搜索引擎是推广网站很重要的一步。为了方便大家,整理了主要搜索引擎,希望对大家有帮助。以下地址都经过了测试,可以使用,若您在使用时发现死链接,请通知我们,以便更好的为大家服务。同时也欢迎大家推荐好的搜索引擎。另外要指出的是,贡献流量的主要是几个著名的搜索引擎,其它的对流量贡献微乎其微。如果您时间不多,大可不必全部登录。当然,如果时间充足,又没有很多推广经费,登录一下也大有好处。
1、百度免费推广(baidu)。登陆页面http:... -
C51内核-原创
2007-10-12
10月份开始写,大约1000行代码吧,第一次自己写个,心没有低。 <
>由于C51内核很小 <
>暂时有:任务调度,任务切换,信号量处理,延时及超时服务,消息邮箱管理。 <
>一定要坚持写完。。。。<
>概念:>> >><
>>> 后 >> >> >>台系统 >> >>应用程序是一个无限的循环循环中调用相应的函数完成相应的操作这部分可以看成后台行为(background).也可以叫做任务级. >> >><
>>> 前台系统 >>中断服务程序处理异步事件这部分可以看成前台行为(foreground).也可以叫做中断级. >><
>>> 代码的临界区 >>指处理时不可分割的代码.一旦这部分代码开始执行则不允许任何中断打入.为确保临界区代码的执行在进入临界区之前要关中断而临界区代码执行完以后要立即开中断. >><
>>> 资源 >>任何为任务所占用的实体都可称为资源.资源可以是输入输出设备例如键盘显示器等.资源也可以是一个变量一个结构或一个数组等. >><
>>> 共享资源 >>可以被一个以上任务使用的资源叫做共享资源.为了防止数据被破坏每个任务在与共享资源大交道时必须独占该资源.这叫做互斥. >><
>>> 多任务 >>多任务运行的实现实际上是靠CPU在许多任务之间的转换调度. >><
>>> 任务 >>一个任务也称为一个线程是一个简单的程序该程序可以认为CPU完全只属于该程序自己.每个任务都是一个无限的循环. >><
>>> 每个任务都处在以下5种状态之一的状态下这5中状态分别是休眠态就绪态运行态挂起态和被中断态. >><
>>> 休眠态 >>相当于该任务驻留在内存中但并不被多任务内核所调度. >><
>>> 就绪态 >>意味着该任务已经准备好可以运行了但由于该任务的优先级比正在运行的任务的优先级低还暂时不能运行. >><
>>> 运行态 >>是指该任务掌握了CPU的控制权正在运行中. >><
>>> 挂起态 >>指该任务在等待等待某一事件的发生. >><
>>> 被中断态 >>发生中断时CPU提供相应的中断服务原来正在运行的任务暂不能运行. >><
>>>文章引用自: >><
>>> >>内核 >> >>多任务系统中内核负责管理各个任务或者说为每个任务分配CPU时间并且负责任务之间的通信.内核提供的基本服务是任务切换.实时内核可以大大简化应用系统的设计它允许将应用分成若干个任务由实时内核来管理他们.(非占先式占先式)<
>>>调度 >> >>是内核的主要职责之一就是决定该论到哪个任务运行了.多数实时内核是基于优先级调度法的.<
>>>任务切换 >> >>当多任务内核决定运行另外的任务时它保存正在运行任务的当前状态即CPU寄存器中的全部内容.这些内容保存在任务的当前状态保存区也就是任务自己的栈区之中.入栈工作完成以后就把下一个将要运行的任务的当前状态从该任务的栈中从新装入CPU的寄存器并开始下一个任务的运行.这个过程就成为任务切换.<
>>>静态优先级 >> >>应用程序执行过程中诸任务优先级不变则称之为静态优先级.在静态优先级系统中诸任务以及它们的时间约束在程序编译时是已知的.<
>>>动态优先级 >> >>应用程序执行过程中任务的优先级是可变的则称之为动态优先级. -
C51内核-原创
2007-10-12
10月份开始写,大约1000行代码吧,第一次自己写个,心没有低。 <
>由于C51内核很小 <
>暂时有:任务调度,任务切换,信号量处理,延时及超时服务,消息邮箱管理。 <
>一定要坚持写完。。。。<
>概念:>> >><
>>> 后 >> >> >>台系统 >> >>应用程序是一个无限的循环循环中调用相应的函数完成相应的操作这部分可以看成后台行为(background).也可以叫做任务级. >> >><
>>> 前台系统 >>中断服务程序处理异步事件这部分可以看成前台行为(foreground).也可以叫做中断级. >><
>>> 代码的临界区 >>指处理时不可分割的代码.一旦这部分代码开始执行则不允许任何中断打入.为确保临界区代码的执行在进入临界区之前要关中断而临界区代码执行完以后要立即开中断. >><
>>> 资源 >>任何为任务所占用的实体都可称为资源.资源可以是输入输出设备例如键盘显示器等.资源也可以是一个变量一个结构或一个数组等. >><
>>> 共享资源 >>可以被一个以上任务使用的资源叫做共享资源.为了防止数据被破坏每个任务在与共享资源大交道时必须独占该资源.这叫做互斥. >><
>>> 多任务 >>多任务运行的实现实际上是靠CPU在许多任务之间的转换调度. >><
>>> 任务 >>一个任务也称为一个线程是一个简单的程序该程序可以认为CPU完全只属于该程序自己.每个任务都是一个无限的循环. >><
>>> 每个任务都处在以下5种状态之一的状态下这5中状态分别是休眠态就绪态运行态挂起态和被中断态. >><
>>> 休眠态 >>相当于该任务驻留在内存中但并不被多任务内核所调度. >><
>>> 就绪态 >>意味着该任务已经准备好可以运行了但由于该任务的优先级比正在运行的任务的优先级低还暂时不能运行. >><
>>> 运行态 >>是指该任务掌握了CPU的控制权正在运行中. >><
>>> 挂起态 >>指该任务在等待等待某一事件的发生. >><
>>> 被中断态 >>发生中断时CPU提供相应的中断服务原来正在运行的任务暂不能运行. >><
>>>文章引用自: >><
>>> >>内核 >> >>多任务系统中内核负责管理各个任务或者说为每个任务分配CPU时间并且负责任务之间的通信.内核提供的基本服务是任务切换.实时内核可以大大简化应用系统的设计它允许将应用分成若干个任务由实时内核来管理他们.(非占先式占先式)<
>>>调度 >> >>是内核的主要职责之一就是决定该论到哪个任务运行了.多数实时内核是基于优先级调度法的.<
>>>任务切换 >> >>当多任务内核决定运行另外的任务时它保存正在运行任务的当前状态即CPU寄存器中的全部内容.这些内容保存在任务的当前状态保存区也就是任务自己的栈区之中.入栈工作完成以后就把下一个将要运行的任务的当前状态从该任务的栈中从新装入CPU的寄存器并开始下一个任务的运行.这个过程就成为任务切换.<
>>>静态优先级 >> >>应用程序执行过程中诸任务优先级不变则称之为静态优先级.在静态优先级系统中诸任务以及它们的时间约束在程序编译时是已知的.<
>>>动态优先级 >> >>应用程序执行过程中任务的优先级是可变的则称之为动态优先级. -
嵌入式C语言位操作的移植与优化
2007-10-11
嵌入式C语言位操作的移植与优化 作者: 上海芯兆电子科技有限公司 王东征 引言 单片机的应用越来越广泛,种类也越来越多。由于嵌入式C语言可读性强、移植性好,与汇编语言相比大大减轻了软件工程师的劳动强度,因而越来越多的单片机工程师开始使用C语言编程。但C语言的可移植性仅限于与硬件无关的子程序,而与具体硬件有关的子程序则无法移植。在单片机应用中,位操作(特别是对引脚的位操作)非常普遍,如EEPROM数据和IC卡数据的读写、字段式LCD显示等,很多带串口的集成电路都需要单片机用软件来做I/O口读写程序。如何让这些子程序既有很好的通用性,生成代码的效率又高,是很多软件工程师都在考虑的问题。这里介绍两种C语言位操作的移植方法。 1 用逻辑运算实现位操作 请看下面这个子程序: INT8U Card102RdByte(void) <
> INT8U Temp8U n = 8<
> do Temp8U ltlt= 1<
> if( PIN_CARD_SDA_RD() ) Temp8U = 0x01<
> PIN_CARD_CLK_H()PIN_CARD_CLK_L()<
> while(--n)<
> return Temp8U<
> 这是通过单片机引脚从88SC102卡中读一个字节的子程序。程序采用μC/OSII中的书写风格,即变量和函数采用“驼峰”写法,由define定义的常量和内联函数采用全部大写加下划线的写法。 此程序驱动一个引脚输出CARD_CLK高低信号,从另一个引脚一位一位读取CARD_SDA数据。 1.1 用于MSP430系列单片机 此程序应用到MSP430单片机上(本文用的是MSP430F413单片机),头文件中要有如下定义: typedefunsigned charINT8U<
>#i ncludeltmsp430x41x.hgt<
>definePIN_CARD_SDA_RD()(P6IN amp 0x01)<
>definePIN_CARD_CLK_H()P6OUT =0x04<
>definePIN_CARD_CLK_L()P6OUT amp= ~0x04 汇编结果如下: In segment CODE align 2 keep with next<
>__code unsigned char Card102RdByte(void)<
> Card102RdByte<
>0000007E42MOV.B0x8 R14<
> Card102RdByte_0<
>0000024C5CRLA.<
/>12<
>000004D2B33400BIT.B0x1 amp0x34<
>0000080128JNCCard102RdByte_1<
>00000A5CD3BIS.B0x1 R12<
> Card102RdByte_1<
>00000CE2D23500BIS.B0x4 amp0x35<
>000010E2C23500BIC.B0x4 amp0x35<
>0000147E53ADD.B0xff R14<
>0000164E93CMP.B0x0 R14<
>000018F423 JNECard102RdByte_0<
>00001A3041RET 这与手工汇编编程的结果几乎一样,代码效率很高。 1.2 用于51系列单片机 在51系列单片机中应用此程序,头文件要加入以下定义: #i ncludeReg932.h//Philips LPC932单片机<
>sbitCradClk=P01<
>sbitCardSDA=P00<
>definePIN_CARD_SDA_RD()CardSDA<
>definePIN_CARD_CLK_H()CradClk=1<
>definePIN_CARD_CLK_L()CradClk=0 原来的程序不作任何改动汇编结果如下: FUNCTION Card102RdByte (BEGIN)<
>-- Variable emp8U __xassigned to Register 7 __x--<
>-- Variable __xassigned to Register 6 __x--<
>00007E08MOVR608H<
>0002C0007<
>0002EFMOVAR7<
>000325E0ADDAACC<
>0005FFMOVR7A<
>0006308003JNBCardSDAC0008<
>0009430701ORLAR701H<
>000CC0008<
>000CD281SETBCradClk<
>000EC281CLRCradClk<
>0010DEF0DJNZR6C0007<
>0012C0009<
>001222RET<
> FUNCTION Card102RdByte (END) 由汇编结果可知,对位的直接清零和置位已达到最简,只是读位值不够理想。 1.3 用于196/296系列单片机 在80C196MC、80C296SA等单片机中,片上I/O口是可以窗口映射到低端地址的。采用这种方式,I/O口可以直接寻址,因而程序代码最短,执行速度也最快,但这样做C程序就无法移植了。若不用窗口技术,则片上I/O口是内存地址映射的,与普通内存地址一样操作。头文件中加入如下定义即可利用原来的程序: INT8UPOUTPIN<
>pragmalocate(POUT=0x880)<
>pragmalocate(PIN=0x881)//外扩I/O口地址定位<
>definePIN_CARD_SDA_RD()(PIN amp 0x01)<
>definePIN_CARD_CLK_H()POUT =0x04<
>definePIN_CARD_CLK_L()POUT amp= ~0x04 汇编后的代码是56字节,代码效率也很高。 采用逻辑运算实现位操作,C程序简单明了,移植性好,可读性更好。但96系列单片机无法利用JBC和JBS位操作指令,51系列单片机也无法利用JB和JNB等其特有的位操作指令来提高代码效率。用位段结构实现位操作可以弥补这个不足。 2 用位段结构实现位操作 把原来的程序改写如下: INT8U Card102RdByte(void)①<
>②<
> INT8U n = 8③<
> ifndef C51_ASM④<
> bdata ACCImg⑤<
> endif⑥<
> do ACC ltlt= 1⑦<
> GET_CARD_SDA()⑧<
> PIN_CARD_CLK_H() PIN_CARD_CLK_L() ⑨<
> while(--n) ⑩<
> return ACC <
> 2.1 在51系列单片机中的应用 在C51中使用ACC是不必在每个子程序中定义的,所以要在文件的开头加上 define C51_ASM。这样,第④、⑤、⑥句会被忽略。在头文件中加上以下定义 sbitACC_0=ACC0 <
>defineGET_CARD_SDA()ACC_0 = CardSDA 其余定义如本文第一部分所述。结果第⑧句汇编变为“MOV CCardSDA”和“MOV ACC_0C”两句。句,函数要通过R7返回参数,程序已达到最简。 FUNCTION Card102RdByte (BEGIN)<
>-- Variable __xassigned to Register 7 -<
>00007F08MOVR708H<
>0002C0007<
>000225E0ADDAACC<
>0004A281MOVCCardSDA<
>000692E0MOVACC_0C<
>0008D280SETBCardClk<
>000AC280CLRCardClk<
>000CDFF4DJNZR7C0007<
>000EFFMOVR7A<
>000FC0008<
>000F22RET<
> FUNCTION Card102RdByte (END) 还可以像196/296那样定义一个位段结构,使用JB指令,有兴趣的读者可以自己试一下。 2.2 在196/296系列单片机中的应用 在196/296中应用这段程序,要增加一个局部变量ACCImg的定义,就是前面程序中的第④、⑤、⑥三句。再在头文件中增加一个如下的位段结构定义: typedef struct unsigned Bit01<
> unsigned Bit11<
> unsigned Bit21<
> unsigned Bit31<
> unsigned Bit41<
> unsigned Bit51<
> unsigned Bit61<
> unsigned Bit71<
> Divide_to_bit<
>typedef union INT8U Byte<
> Divide_to_bit DivBit<
> bdata 端口地址变量要定义成以下数据类型: bdata PIN 同时,在头文件中加上宏定义: defineACC ACCImg.Byte<
>defineACC_0 ACCImg.DivBit.Bit0<
>defineGET_CARD_SDA() if(PIN.DivBit.Bit0) ACC =0x01 这样ACCImg就定义成了一个低端寄存器ACC是它的字节访问形式。源程序中的第⑧句读引脚,汇编的结果使用了JBC指令,整个程序比不用位段减少了字节,达到了优化代码的目的。 cseg<
>0000Card102RdByte<
> Statement3<
>0000B10800Rldbn8<
> Statement7<
>0003 0004 <
>0003740101RaddbACCImgACCImg<
> Statement8<
>0006B30181081CldbTmp0PIN<
>000B 331C03jbcTmp030005<
>000E 910101 RorbACCImg1<
>0011 0005 <
> Statement9<
>0011 B30180081CldbTmp0POUT<
>0016 91041CorbTmp04<
>0019 C70180081CstbTmp0POUT<
>001E 71FB1C andbTmp00FBH<
>0021 C70180081C stbTmp0POUT<
> Statement10 <
>00261500Rdecbn<
>0028980000RcmpbR0n<
>002BD7D6bne 0004<
> Statement11<
>002DB0011C RldbTmp0ACCImg<
>00302000
0001<
> Statement12<
>0032 0001 <
>0032F0ret 2.3 在MSP430系列单片机中的应用 MSP430系列单片机没有位操作指令,所以不必定义位段结构,直接把ACC定义成一个无符号8位数即可。头文件中是这样定义的: ifndef C51_ASM//此句使头文件也可以与C51的共用<
> typedef INT8U bdata <
> define ACC ACCImg<
> define GET_CARD_SDA() if(P6IN amp 0x01) ACC =0x01<
>endif 汇编的结果与用逻辑运算的方法进行位操作竟完全一样。 结语 对引脚的位操作有3种: 直接置位或清零,从端口输入数据和从端口输出数据。前两种上文已介绍过了。从端口输出数据的C程序如下: do<
> OUT_SIO_DA()<
> CLK_H()<
> ACC ltlt= 1//移位可扩展时钟脉冲宽度<
> CLK_L()<
>while 其中: 第一句OUT_SIO_DA(),51系列可定义成位操作SIO_SDA = ACC_7;196/296和430系列可如上文定义成一个if语句。 位段操作程序中采用了ACC这个名字作为一个局部变量。在C51中这刚好是主累加器,对于2401、IC卡等半双工器件的程序很实用,但当SPI总线输入/输出同时操作时,就没这么方便了。 用逻辑运算实现位操作不存在任何移植的障碍。μC/OS-II中的位操作就是全用逻辑运算实现的。位段定义可能存在不同编译器分配顺序不同的问题,但考虑到32位高速CPU不会用软件模拟这种串口的操作,这样的程序只会用在51、196/296、MSP430等无片内Cache的中低速单片机中,所以用位段操作引脚的方法仍有意义。具体是使用逻辑运算还是使用位段进行位操作,完全看个人喜好。本文程序采用的编译器是Keil C51 V7.03、IAR C430 V2.10A和 Tasking C96 V5.0。 参考文献 1 程军. Intel 80C196单片机应用实践与C语言开发M. 北京 北京航空航天大学出版社2000.<
>2 美 La
osse J. 嵌入式实时操作系统μC/OS-IIM. 第2版. 邵贝贝,等译. 北京 北京航空航天大学出版社2003. 王东征主要研究方向为SoC应用。 -
嵌入式C语言位操作的移植与优化
2007-10-11
嵌入式C语言位操作的移植与优化 作者: 上海芯兆电子科技有限公司 王东征 引言 单片机的应用越来越广泛,种类也越来越多。由于嵌入式C语言可读性强、移植性好,与汇编语言相比大大减轻了软件工程师的劳动强度,因而越来越多的单片机工程师开始使用C语言编程。但C语言的可移植性仅限于与硬件无关的子程序,而与具体硬件有关的子程序则无法移植。在单片机应用中,位操作(特别是对引脚的位操作)非常普遍,如EEPROM数据和IC卡数据的读写、字段式LCD显示等,很多带串口的集成电路都需要单片机用软件来做I/O口读写程序。如何让这些子程序既有很好的通用性,生成代码的效率又高,是很多软件工程师都在考虑的问题。这里介绍两种C语言位操作的移植方法。 1 用逻辑运算实现位操作 请看下面这个子程序: INT8U Card102RdByte(void) <
> INT8U Temp8U n = 8<
> do Temp8U ltlt= 1<
> if( PIN_CARD_SDA_RD() ) Temp8U = 0x01<
> PIN_CARD_CLK_H()PIN_CARD_CLK_L()<
> while(--n)<
> return Temp8U<
> 这是通过单片机引脚从88SC102卡中读一个字节的子程序。程序采用μC/OSII中的书写风格,即变量和函数采用“驼峰”写法,由define定义的常量和内联函数采用全部大写加下划线的写法。 此程序驱动一个引脚输出CARD_CLK高低信号,从另一个引脚一位一位读取CARD_SDA数据。 1.1 用于MSP430系列单片机 此程序应用到MSP430单片机上(本文用的是MSP430F413单片机),头文件中要有如下定义: typedefunsigned charINT8U<
>#i ncludeltmsp430x41x.hgt<
>definePIN_CARD_SDA_RD()(P6IN amp 0x01)<
>definePIN_CARD_CLK_H()P6OUT =0x04<
>definePIN_CARD_CLK_L()P6OUT amp= ~0x04 汇编结果如下: In segment CODE align 2 keep with next<
>__code unsigned char Card102RdByte(void)<
> Card102RdByte<
>0000007E42MOV.B0x8 R14<
> Card102RdByte_0<
>0000024C5CRLA.<
/>12<
>000004D2B33400BIT.B0x1 amp0x34<
>0000080128JNCCard102RdByte_1<
>00000A5CD3BIS.B0x1 R12<
> Card102RdByte_1<
>00000CE2D23500BIS.B0x4 amp0x35<
>000010E2C23500BIC.B0x4 amp0x35<
>0000147E53ADD.B0xff R14<
>0000164E93CMP.B0x0 R14<
>000018F423 JNECard102RdByte_0<
>00001A3041RET 这与手工汇编编程的结果几乎一样,代码效率很高。 1.2 用于51系列单片机 在51系列单片机中应用此程序,头文件要加入以下定义: #i ncludeReg932.h//Philips LPC932单片机<
>sbitCradClk=P01<
>sbitCardSDA=P00<
>definePIN_CARD_SDA_RD()CardSDA<
>definePIN_CARD_CLK_H()CradClk=1<
>definePIN_CARD_CLK_L()CradClk=0 原来的程序不作任何改动汇编结果如下: FUNCTION Card102RdByte (BEGIN)<
>-- Variable emp8U __xassigned to Register 7 __x--<
>-- Variable __xassigned to Register 6 __x--<
>00007E08MOVR608H<
>0002C0007<
>0002EFMOVAR7<
>000325E0ADDAACC<
>0005FFMOVR7A<
>0006308003JNBCardSDAC0008<
>0009430701ORLAR701H<
>000CC0008<
>000CD281SETBCradClk<
>000EC281CLRCradClk<
>0010DEF0DJNZR6C0007<
>0012C0009<
>001222RET<
> FUNCTION Card102RdByte (END) 由汇编结果可知,对位的直接清零和置位已达到最简,只是读位值不够理想。 1.3 用于196/296系列单片机 在80C196MC、80C296SA等单片机中,片上I/O口是可以窗口映射到低端地址的。采用这种方式,I/O口可以直接寻址,因而程序代码最短,执行速度也最快,但这样做C程序就无法移植了。若不用窗口技术,则片上I/O口是内存地址映射的,与普通内存地址一样操作。头文件中加入如下定义即可利用原来的程序: INT8UPOUTPIN<
>pragmalocate(POUT=0x880)<
>pragmalocate(PIN=0x881)//外扩I/O口地址定位<
>definePIN_CARD_SDA_RD()(PIN amp 0x01)<
>definePIN_CARD_CLK_H()POUT =0x04<
>definePIN_CARD_CLK_L()POUT amp= ~0x04 汇编后的代码是56字节,代码效率也很高。 采用逻辑运算实现位操作,C程序简单明了,移植性好,可读性更好。但96系列单片机无法利用JBC和JBS位操作指令,51系列单片机也无法利用JB和JNB等其特有的位操作指令来提高代码效率。用位段结构实现位操作可以弥补这个不足。 2 用位段结构实现位操作 把原来的程序改写如下: INT8U Card102RdByte(void)①<
>②<
> INT8U n = 8③<
> ifndef C51_ASM④<
> bdata ACCImg⑤<
> endif⑥<
> do ACC ltlt= 1⑦<
> GET_CARD_SDA()⑧<
> PIN_CARD_CLK_H() PIN_CARD_CLK_L() ⑨<
> while(--n) ⑩<
> return ACC <
> 2.1 在51系列单片机中的应用 在C51中使用ACC是不必在每个子程序中定义的,所以要在文件的开头加上 define C51_ASM。这样,第④、⑤、⑥句会被忽略。在头文件中加上以下定义 sbitACC_0=ACC0 <
>defineGET_CARD_SDA()ACC_0 = CardSDA 其余定义如本文第一部分所述。结果第⑧句汇编变为“MOV CCardSDA”和“MOV ACC_0C”两句。句,函数要通过R7返回参数,程序已达到最简。 FUNCTION Card102RdByte (BEGIN)<
>-- Variable __xassigned to Register 7 -<
>00007F08MOVR708H<
>0002C0007<
>000225E0ADDAACC<
>0004A281MOVCCardSDA<
>000692E0MOVACC_0C<
>0008D280SETBCardClk<
>000AC280CLRCardClk<
>000CDFF4DJNZR7C0007<
>000EFFMOVR7A<
>000FC0008<
>000F22RET<
> FUNCTION Card102RdByte (END) 还可以像196/296那样定义一个位段结构,使用JB指令,有兴趣的读者可以自己试一下。 2.2 在196/296系列单片机中的应用 在196/296中应用这段程序,要增加一个局部变量ACCImg的定义,就是前面程序中的第④、⑤、⑥三句。再在头文件中增加一个如下的位段结构定义: typedef struct unsigned Bit01<
> unsigned Bit11<
> unsigned Bit21<
> unsigned Bit31<
> unsigned Bit41<
> unsigned Bit51<
> unsigned Bit61<
> unsigned Bit71<
> Divide_to_bit<
>typedef union INT8U Byte<
> Divide_to_bit DivBit<
> bdata 端口地址变量要定义成以下数据类型: bdata PIN 同时,在头文件中加上宏定义: defineACC ACCImg.Byte<
>defineACC_0 ACCImg.DivBit.Bit0<
>defineGET_CARD_SDA() if(PIN.DivBit.Bit0) ACC =0x01 这样ACCImg就定义成了一个低端寄存器ACC是它的字节访问形式。源程序中的第⑧句读引脚,汇编的结果使用了JBC指令,整个程序比不用位段减少了字节,达到了优化代码的目的。 cseg<
>0000Card102RdByte<
> Statement3<
>0000B10800Rldbn8<
> Statement7<
>0003 0004 <
>0003740101RaddbACCImgACCImg<
> Statement8<
>0006B30181081CldbTmp0PIN<
>000B 331C03jbcTmp030005<
>000E 910101 RorbACCImg1<
>0011 0005 <
> Statement9<
>0011 B30180081CldbTmp0POUT<
>0016 91041CorbTmp04<
>0019 C70180081CstbTmp0POUT<
>001E 71FB1C andbTmp00FBH<
>0021 C70180081C stbTmp0POUT<
> Statement10 <
>00261500Rdecbn<
>0028980000RcmpbR0n<
>002BD7D6bne 0004<
> Statement11<
>002DB0011C RldbTmp0ACCImg<
>00302000
0001<
> Statement12<
>0032 0001 <
>0032F0ret 2.3 在MSP430系列单片机中的应用 MSP430系列单片机没有位操作指令,所以不必定义位段结构,直接把ACC定义成一个无符号8位数即可。头文件中是这样定义的: ifndef C51_ASM//此句使头文件也可以与C51的共用<
> typedef INT8U bdata <
> define ACC ACCImg<
> define GET_CARD_SDA() if(P6IN amp 0x01) ACC =0x01<
>endif 汇编的结果与用逻辑运算的方法进行位操作竟完全一样。 结语 对引脚的位操作有3种: 直接置位或清零,从端口输入数据和从端口输出数据。前两种上文已介绍过了。从端口输出数据的C程序如下: do<
> OUT_SIO_DA()<
> CLK_H()<
> ACC ltlt= 1//移位可扩展时钟脉冲宽度<
> CLK_L()<
>while 其中: 第一句OUT_SIO_DA(),51系列可定义成位操作SIO_SDA = ACC_7;196/296和430系列可如上文定义成一个if语句。 位段操作程序中采用了ACC这个名字作为一个局部变量。在C51中这刚好是主累加器,对于2401、IC卡等半双工器件的程序很实用,但当SPI总线输入/输出同时操作时,就没这么方便了。 用逻辑运算实现位操作不存在任何移植的障碍。μC/OS-II中的位操作就是全用逻辑运算实现的。位段定义可能存在不同编译器分配顺序不同的问题,但考虑到32位高速CPU不会用软件模拟这种串口的操作,这样的程序只会用在51、196/296、MSP430等无片内Cache的中低速单片机中,所以用位段操作引脚的方法仍有意义。具体是使用逻辑运算还是使用位段进行位操作,完全看个人喜好。本文程序采用的编译器是Keil C51 V7.03、IAR C430 V2.10A和 Tasking C96 V5.0。 参考文献 1 程军. Intel 80C196单片机应用实践与C语言开发M. 北京 北京航空航天大学出版社2000.<
>2 美 La
osse J. 嵌入式实时操作系统μC/OS-IIM. 第2版. 邵贝贝,等译. 北京 北京航空航天大学出版社2003. 王东征主要研究方向为SoC应用。 -
vim 下tags文 件适用windows
2007-10-11
如果在多个目录中都有文件,你可以在每一个目录下创建一个标签文件。Vim 只能跳转到<
>那个目录下的标签。<
>通过设定 ags __x选项,你可以使用多个相关的标签文件。 比如:set tags=./tags./../tags./*/tags这会使 Vim 找到当前文件所在目录及其父目录和所有子目录下的标签文件。<
>这已经是不少的标签文件了,但也许仍不够。比如,当编辑 ~/proj/src 目录下的<
>一个文件时,你无法找到 ~/proj/sub/tags 目录下的标签文件。对这种情况,Vim<
>提供了一个查找整个目录树下标签文件的方法,比如:set tags=~/proj/**/tags单 个 标 记 文 件当 Vim 在多个地方查找标签文件时,你会听到硬盘在格格作响。这样会有点慢。在这种<
>情况下,你最好将这些时间花在生成一个大的标签文件上。你可以要等一会儿。<
>这得借助上面提到的 Exuberant ctags 程序。它有一个选项可以搜索整个目录树:cd ~/proj<
>ctags -R .这样做的好处是 Exuberant ctags 可以识别多种文件类型,它不仅适用于 C 和 C <
>程序,还适用于 Eiffel 甚至 Vim 脚本。请参考 ctags 文档进行调整所用参数。<
>现在你只需要告诉 Vim 你的标签文件在何处:set tags=~/proj/tags<
> -
vim 下tags文 件适用windows
2007-10-11
如果在多个目录中都有文件,你可以在每一个目录下创建一个标签文件。Vim 只能跳转到<
>那个目录下的标签。<
>通过设定 ags __x选项,你可以使用多个相关的标签文件。 比如:set tags=./tags./../tags./*/tags这会使 Vim 找到当前文件所在目录及其父目录和所有子目录下的标签文件。<
>这已经是不少的标签文件了,但也许仍不够。比如,当编辑 ~/proj/src 目录下的<
>一个文件时,你无法找到 ~/proj/sub/tags 目录下的标签文件。对这种情况,Vim<
>提供了一个查找整个目录树下标签文件的方法,比如:set tags=~/proj/**/tags单 个 标 记 文 件当 Vim 在多个地方查找标签文件时,你会听到硬盘在格格作响。这样会有点慢。在这种<
>情况下,你最好将这些时间花在生成一个大的标签文件上。你可以要等一会儿。<
>这得借助上面提到的 Exuberant ctags 程序。它有一个选项可以搜索整个目录树:cd ~/proj<
>ctags -R .这样做的好处是 Exuberant ctags 可以识别多种文件类型,它不仅适用于 C 和 C <
>程序,还适用于 Eiffel 甚至 Vim 脚本。请参考 ctags 文档进行调整所用参数。<
>现在你只需要告诉 Vim 你的标签文件在何处:set tags=~/proj/tags<
> -
毕业后...
2007-10-11








