资源预览内容
第1页 / 共30页
第2页 / 共30页
第3页 / 共30页
第4页 / 共30页
第5页 / 共30页
第6页 / 共30页
第7页 / 共30页
第8页 / 共30页
第9页 / 共30页
第10页 / 共30页
亲,该文档总共30页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述
实实 验验 报报 告告课程名称 嵌入式系统实验 学生学院 计算机学院 专业班级 08 级软件工程 2 班 学 号 3108006864 学生姓名 陈键灿 指导教师 林 伟 2011 年 6 月 29 日实验实验 1:ADS 开发环境和开发环境和 GPIO 的使用的使用1 1 、实验目的、实验目的 熟悉 ADS 开发环境、 AXD 及 Multi_ICE 调试环境。 掌握简单的 ARM 汇编指令的使用方法。 掌握 S3C2440A 的 I/O 控制寄存器的配置。 掌握 ARM 汇编指令和 C 语言相互调用的方法2 2 、实验设备、实验设备 PC 机、 ARM 仿真器、 2440 实验箱、串口线、 USB 传输线。3 3 、实验内容、实验内容 熟悉 ARM 开发环境的建立。 使用 ARM 汇编和 C 语言设置 GPIO 口的相应寄存器。 编写跑马灯程序。4 4 、实验原理、实验原理C 程序与汇编程序相互调用规则 为了使单独编译的 C 语言程序和汇编程序之间能够相互调用,必须为子程序 间的调用规 定一定的规则 。 ATPCS , 即 ARM , Thumb 过程调用标准 (ARM/Thumb Procedure Call Standard) ,是 ARM 程序和 Thumb 程序中子程序调用的基本规 则,它规定了一些子程序间调用 的基本规则,如子程序调用过程中的寄存器的使 用规则,堆栈的使用规则,参数的传递规则等。 基本 ATPCS 基本 ATPCS 规定了在子程序调用时的一些基本规则,包括下面 3 方面的内容: (1) 各寄存器的使用规则及其相应的名称。 (2) 数据栈的使用规则。 (3) 参数传递的规则。 相对于其它类型的 ATPCS ,满足基本 ATPCS 的程序的执行速度更快,所占用 的内存更少 。 但是它不能提供以下的支持 : ARM 程序和 Thumb 程序相互调用 , 数 据以及代码的位置无关的支持 , 子程序的可重入性 , 数据栈检查的支持 。 而派生的 其他几种特定的 ATPCS 就是在基本 ATPCS 的基础上再添加其他的规则而形成 的。其目的就是提供上述的功能。 寄存器的使用规则 寄存器的使用必须满足下面的规则:(1) 子程序间通过寄存器 R0 R3 来传递参数。这时,寄存器 R0 R3 可以记作 A0 A3 。 被调用的子程序在返回前无需恢复寄存器 R0 R3 的内容。 (2) 在子程序中 , 使用寄存器 R4 Rll 来保存局部变量 。 这时 , 寄存器 R4 R11 可 以 记作 V1 V8 。 如果在子程序中使用到了寄存器 V1 V8 中的某些寄存器 , 子程 序进入时必须 保存这些寄存器的值,在返回前必须恢复这些寄存器的值;对于子 程序中没有用到的寄存器 则不必进行这些操作 。 在 Thumb 程序中 , 通常只能使用 寄存器 R4 R7 来保存局部变量。 (3) 寄存器 R12 用作子程序间 scratch 寄存器,记作 IP 。在子程序间的连接代 码段中 常有这种使用规则。 (4) 寄存器 R13 用作数据栈指针,记作 SP 。在子程序中寄存器 R13 不能用作其 他用途。 寄存器 SP 在进入子程序时的值和退出子程序时的值必须相等。 (5) 寄存器 R14 称为连接寄存器 , 记作 LR 。 它用于保存子程序的返回地址 。 如 果 在 子程序中保存了返回地址,寄存器 R14 则可以用作其他用途。 (6) 寄存器 R15 是程序计数器,记作 PC 。它不能用作其他用途。 参数传递规则 根据参数个数是否固定可以将子程序分为参数个数固定的 (nonvariadic) 子程 序和参数个数可变的 (variadic) 子程序。这两种子程序的参数传递规则是不同的 。 ( 1 )参数个数可变的子程序参数传递规则 对于参数个数可变的子程序,当参数不超过 4 个时,可以使用寄存器 R0 R3 来传递参 数;当参数超过 4 个时,还可以使用数据栈来传递参数。 在参数传递时 , 将所有参数看作是存放在连续的内存字单元中的字数据 。 然后 , 依次将 各字数据传送到寄存器 R0 、 R1 、 R2 、 R3 中 , 如果参数多于 4 个 , 将剩余 的字数据传送到数 据栈中,入栈的顺序与参数顺序相反,即最后一个字数据先入 栈。按照上面的规则,一个浮 点数参数可以通过寄存器传递,也可以通过数据栈 传递,也可能一半通过寄存器传递,另一 半通过数据栈传递。 (2) 参数个数固定的子程序参数传递规则 对于参数个数固定的子程序 , 参数传递与 参数个数可变的子程序参数传递规则不同。 如果系统包含浮点运算的硬件部件,浮点参数将按照下面的规则传递: 各个浮点参数按顺序处理。 为每个浮点参数分配 FP 寄存器。 分配的方法是,满足该浮点参数需要的且编号最小的一组连续的 FP 寄存器 。 第一 个整数参数,通过寄存器 R0 R3 来传递。其他参数通过数据栈传递。 结果为一个 32 位的整数时,可以通过寄存器 R0 返回。 结果为一个 64 位整数时,可以通过寄存器 R0 和 Rl 返回,依次类推。 结果为一个浮点数时 , 可以通过浮点运算部件的寄存器 f0 、 d0 或者 s0 来返 回。 结果为复合型的浮点数 ( 如复数 ) 时 , 可以通过寄存器 f0 fN 或者 d0 dN 来 返回。 对于位数更多的结果,需要通过内存来传递。 C 语言函数和 ARM 汇编语言函数间相互调用 高级语言函数与汇编语言函数的混合调用也要遵循 ATPCS 规则,保证程序调 用时参数的正确传递 。 在汇编程序中使用 EXPORT 伪指令声明本子程序 , 使其它程 序可以调用此子程 序,而在 C 语言程序中使用 extern 关键字声明外部函数 ( 声 明要调用的汇编子程序 ) , 即可调 用此汇编子程序 。 下面给出两个例子来介绍函数 相互调用。 例 C 函数中调用汇编 示例中汇编子程序 strcopy 使用两个参数,一个表示目标字符串地址,一个 表示源字符 串的地址,参数分别存放 R0 , R1 寄存器中。 #include extern void strcopy(char*d , const char*s) / 声明外部函数。即要调用的 汇编子程序 int mian (void) const char *srcstr= “First string-source“ ; / 定义字符串常量 char dstsrt = “Second string-destination“ ; / 定义字符串变量 printf( “Before copying : /n“ ) ; printf ( “%s n %s/n , “ srcstr , dststr) ; / 显示源字符串和目标字符 串的内容 strcopy(dststr , srcstr) ; / 调用汇编子程序, R0=dststr , R1=srcstr printf( “After copying : n“ ) printf ( “ %s n %sn , “ srcstr , dststr) ; / 显示 strcopy 复制 字符串结果 return(0) ; 被调用汇编子程序: AREA SCopy , CODE , READONLY EXPORT strcopy ;声明 strcopy ,以便外部程序引用 strcopy ; R0 为目标字符串的地址 ; R1 为源字符串的地址 LDRB R2 , R1 , #1 ;读取字节数据,源地址加 l STRB R2 , R0 , #1 ;保存读取的 1 字节数据,目标地 CMP r2 , #0 ;判断字符串是否复制完毕 BNE st 毕,继续循环 MOV pc , 1r ;返回 END 例 汇编程序调用 C 程序 汇编程序的设置要遵循 ATPCS 规则,保证程序调用时 编程序中 使用 IMPORT 伪指令声明将要调用的 C 程序函数 要正确设置入口参数 , 然后使用 BL 调用 。 示例程序中使用 用寄存器 R0 存储第 1 个参数 , R1 存储第 2 个数 , R2 存 储第 4 个参数,第 5 个参数利用堆栈传送。由于 利用了 调用结果后要调整堆栈指针。 汇编调用 C 程序的汇编程序/* 函数 sum () 返回 5 个整数的和 */ int sum (int a , lit b , int c , int d , int e) return(a+b+c+d+e) ; / 返回 5 个变量的和 EXPORT CALLSUM AREA Example , CODE , READONLY IMPORT sum ; 声明外部标号 sum5 , 即 C 函数 sum5() CAL STMFD SP!LR ; LR 寄存器堆栈 ADD R1 , R0 , R0 ; 设置 sum 函数入口参数 , R0 为参数 ADD R2 , R1 , R0 ; R1 为参数 b , R2 为参数 c ADD R3 , R1 , R2 , STR R3 , SP , #-4! ; 参数 e 要通过堆栈传递 ADD R3 , R1 , R1 ; R3 为参数 d BL sum ; 调用 sum() , 结果保存在 R0 ADD SP , SP#4 ; 修正 SP 指针 LDMFD SP , PC ; 子程序返回 END5 5 、实验相关寄存器、实验相关寄存器6 6、参考程序、参考程序利用 C 语言实现跑马灯程序 /* led_asm_c.c */ /*C 语言函数 */ /* 定义端口寄存器 */ #define rGPBCON (*(volatile unsigned *)0x56000010) /Port B control #define rGPBDAT (*(volatile unsigned *)0x56000014) /Port B data #define rGPBUP (*(volatile unsigned *)0x56000018) /Pull-up control B /* 延迟程序 */ extern void delay(int times); /* 主程序 */ void xmain(void) rGPBCON= (rGPBCON rLCDSADDR2=M5D( (U32)LCD_BUFER+(SCR_XSIZE_TFT_800480*LCD_YSIZE_TFT 800480*2)1 ); rLCDSADDR3=(SCR_XSIZE_TFT_800480-LCD_XSIZE_TFT_800480)/1)11)|(L D_XSIZE_TFT_800480/1); rLCDINTMSK|=(3); / MASK LCD Sub Interrupt rTCONSEL / Disable LPC3600 rTPAL=0; / Disable Temp Palette 6.3 LCD 开关函数 * LCD 视频 和控制信号输出或者停止, 1 开启视频输出 */ static void Lcd_EnvidOnOff(int onoff) if(onoff=1)rLCDCON1|=1; / ENVID=ON else rLCDCON1 =rLCDCON1 /
网站客服QQ:2055934822
金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号