1 /*************************************************/
2 /* 串口中端接受函数 */
3 /*************************************************/
4 #pragma CODE_SEG __NEAR_SEG NON_BANKED //将接下来的代码(一般是中断函数)置于非分页区
5 interrupt void recievedata(void) {
6 data_recieve = SCI_recieve();
7 if(data_recieve == 'O') {
8 SCI_send('Y');
9 LEDCPU = LED_ON;
10 }
11 if(data_recieve == 'C') {
12 LEDCPU = LED_OFF;
13 }
14 }
15 #pragma CODE_SEG DEFAULT
#pragma CODE_SEG __NEAR_SEG NON_BANKED //中断函数置于非分页区内代码段
#pragma CODE_SEG DEFAULT //后续代码置于默认区域内
freescale16位的板子中断向量位是16位,中断函数只有被置于非分页区内才能被寻址到,这就是第一行的作用。由于单片机内部非分页区大小有限,非中断函数一般置于分页区内,最后一行即为此作用。
这里要从FLASH分页和非分页的区别说起, FLASH里非分页工作机制如下:
FLASH一共为128K,一页是16K,那么应该有8页才是,但是实际只有6个分页。有2个非分页放在4000-7FFF,和C000-FFFF两个逻辑地址窗里。那么,当程序的寻址在64K之内(2^16=64K,16位机的寻址能力是64K)时,就不用分页了,直接使用那两个非分页的数据。实际上,3E页 3F页是可见的,其实他们就是那2个非分页的映射。因此,使用非分页FLASH,就不须设置PPAGE寄存器,直接使用逻辑地址即可。
这点我们可以从以下看出:
/* non-paged FLASHs */
ROM_4000 =
READ_ONLY 0x4000 TO 0x7FFF;
ROM_C000 =
READ_ONLY 0xC000 TO 0xFEFF;
PLACEMENT
NON_BANKED, INTO ROM_C000/*,
ROM_4000*/;
NON_BANKED一般位于0xc000-0xffff区域,而这个区域是16位单片机cpu可以直接寻址的区域,那么中断函数放在 NON_BANKED里,就可以把函数放在64K的寻址程序段中。这么一来,进中断就方便多了,效率也高很多(因为中断函数要求的就是实时性)...而 __NEAR_SEG告诉编译器函数放在固定页中,只有固定页中的函数才能访问其他页的数据,同时CODE_SEG定义了一个代码段.
作者: 李肖遥, 来源:面包板社区
链接: https://mbb.eet-china.com/blog/uid-me-3912462.html
版权声明:本文为博主原创,未经本人允许,禁止转载!
文章评论(0条评论)
登录后参与讨论