广州大学 汇编语言与接口技术实验2 简单接口应用实验 2020.12

本文主要是介绍广州大学 汇编语言与接口技术实验2 简单接口应用实验 2020.12,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章提到的用户手册,下载地址:提取码:9jsv

一、 实验目的

1、熟练使用ubuntu Linux操作系统。
2、掌握常用的汇编命令,如mov、sub、add、ldr、str等。
3、掌握阅读原理图技巧,实现跑马灯的效果。
4、熟练掌握arm-linux-gcc编译程序的方法。
5、熟练掌握使用串口下载文件到开发板的方法。

二、 实验原理

一、分析原理图,了解LED灯控制原理

S5P6818处理器有四个GPIO引脚控制四个LED灯。
GPIO引脚输出高电平(3.3V),LED灯灭。
GPIO引脚输出低电平(0V),LED灯亮。

二、分析S5P6818处理器中的GPIO

S5P6818处理器GPIO分成了5组,分别是:A、B、C、D、E,每个组32个引脚,共160个引脚。
GPIOE13 —— 控制D7灯
GPIOC17 —— 控制D8灯
GPIOC8 —— 控制D9灯
GPIOC7 —— 控制D10灯

三、LED的控制流程

1、将GPIO引脚配置成IO功能。
2、将这个GPIO再设置成Output
3、设置GPIO引脚输出低电平,LED灯亮
4、设置GPIO引脚输出高电平,LED灯灭

四、分析寄存器
1、GPIOxALTFN0/GPIOxALTFN1 —— 配置一个引脚为I/O

其中GPIOxALTFN0 —— 配置Pin0~Pin15
GPIOxALTFN1 —— 配置Pin0~Pin31

以:GPIOE13为例子
应该使用GPIOEALTFN0为寄存器配置GPIOE13作为GPIO功能。
GPIOEALTFNO寄存器地址为:0xC001000 + 0xE020
在这里插入图片描述GPIOEALTFN0寄存器有32个位,每个位为1组,每个组控制一个引脚的复用功能,我们先找到13号引脚。

在这里插入图片描述
需要配置的是第27和第26位。
一个引脚的复用功能有四个,要找到GPIOE13,需要到SEC_S5P6818用户手册查找第二章

在这里插入图片描述
可以看到是Function0,则需要将GPIOEALTFN0的第26和27位置00即把引脚配置成GPIOE13功能。

2、GPIOxOUTENB —— 将一个GPIO配置成输入或者输出功能

每个位对应一个引脚,通过寄存器的位设置GPIO位输入还是输出。
首先可以在手册中找到GPIOEOUTENB的位置

在这里插入图片描述地址为:0xC001000 + 0xE004

在这里插入图片描述
其中,0为输入,1为输出。
因此需要将第13位置为1。

3、GPIOxOUT —— 设置GPIO输出的电平

找到GPIOEOUT的寄存器地址为:0xC001000 + 0xE000
在这里插入图片描述
在这里插入图片描述

其中,0为低电平,1为高电平。
因此,可以将13位置0或1来控制灯的点亮或者熄灭。

三、 实验仪器、材料

三星S5P6818开发板(ARM Cortex-A53架构)
手提电脑

四、 实验步骤

1、编写流水灯控制的汇编代码

//GPIOE
#define GPIOEOUT	 0xC001E000
#define GPIOEOUTENB  0xC001E004
#define GPIOEALTFN0	 0xC001E020
#define GPIOEALTFN1	 0xC001E024//GPIOC
#define GPIOCOUT	 0xC001C000
#define GPIOCOUTENB  0xC001C004
#define GPIOCALTFN0	 0xC001C020
#define GPIOCALTFN1	 0xC001C024.text	//代码段的开始
.global _start_start:
//配置GPIOE13为输出模式
//GPIOEALTFN0 &= ~(3<<26);ldr r1,=GPIOEALTFN0ldr r0,[r1]ldr r2,=~(3<<26)and r0,r0,r2str r0,[r1]
//GPIOEOUTENB |= 1<<13;ldr r1,=GPIOEOUTENBldr r0,[r1]ldr r2,=(1<<13)orr r0,r0,r2str r0,[r1]//配置GPIOC17为输出模式
//GPIOCALTFN1 &= ~(3<<2);ldr r1,=GPIOCALTFN1ldr r0,[r1]ldr r2,=~(3<<2)and r0,r0,r2str r0,[r1]
//GPIOCALTFN1 |= 1<<2;ldr r1,=GPIOCALTFN1ldr r0,[r1]ldr r2,=(1<<2)orr r0,r0,r2str r0,[r1]
//GPIOCOUTENB |= 1<<17;ldr r1,=GPIOCOUTENBldr r0,[r1]ldr r2,=(1<<17)orr r0,r0,r2str r0,[r1]//配置GPIOC7、GPIOC8为输出模式
//GPIOCALTFN0 &= ~((3<<16)|(3<<14));ldr r1,=GPIOCALTFN0ldr r0,[r1]
//取反ldr r3,=(3<<16)ldr r4,=(3<<14)orr r3,r3,r4ldr r4,=0xFFFFFFFFeor r2,r3,r4
//取反and r0,r0,r2str r0,[r1]
//GPIOCALTFN0 |= (1<<16)|(1<<14);ldr r1,=GPIOCALTFN0ldr r0,[r1]
//连续或ldr r3,=(1<<16)ldr r4,=(1<<14)orr r2,r3,r4
//连续或orr r0,r0,r2str r0,[r1]
//GPIOCOUTENB |= (1<<8)|(1<<7);ldr r1,=GPIOCOUTENBldr r0,[r1]
//连续或ldr r3,=(1<<8)ldr r4,=(1<<7)orr r2,r3,r4
//连续或orr r0,r0,r2str r0,[r1]//while循环
loop:
//点亮D7,其他灯熄灭
//GPIOEOUT &= ~(1<<13);ldr r1,=GPIOEOUTldr r0,[r1]ldr r2,=~(1<<13)and r0,r0,r2str r0,[r1]
//GPIOCOUT |= 1<<17;ldr r1,=GPIOCOUTldr r0,[r1]ldr r2,=(1<<17)orr r0,r0,r2str r0,[r1]
//GPIOCOUT |= 1<<8;ldr r1,=GPIOCOUTldr r0,[r1]ldr r2,=(1<<8)orr r0,r0,r2str r0,[r1]
//GPIOCOUT |= 1<<7;ldr r1,=GPIOCOUTldr r0,[r1]ldr r2,=(1<<7)orr r0,r0,r2str r0,[r1]
//delay();bl delay
//点亮D8,其他灯熄灭
//GPIOEOUT |= 1<<13;ldr r1,=GPIOEOUTldr r0,[r1]ldr r2,=(1<<13)orr r0,r0,r2str r0,[r1]
//GPIOCOUT &= ~(1<<17);ldr r1,=GPIOCOUTldr r0,[r1]ldr r2,=~(1<<17)and r0,r0,r2str r0,[r1]
//GPIOCOUT |= 1<<8;ldr r1,=GPIOCOUTldr r0,[r1]ldr r2,=(1<<8)orr r0,r0,r2str r0,[r1]
//GPIOCOUT |= 1<<7;ldr r1,=GPIOCOUTldr r0,[r1]ldr r2,=(1<<7)orr r0,r0,r2str r0,[r1]
//delay();bl delay
//点亮D9,其他灯熄灭
//GPIOEOUT |= 1<<13;ldr r1,=GPIOEOUTldr r0,[r1]ldr r2,=(1<<13)orr r0,r0,r2str r0,[r1]
//GPIOCOUT |= 1<<17;ldr r1,=GPIOCOUTldr r0,[r1]ldr r2,=(1<<17)orr r0,r0,r2str r0,[r1]
//GPIOCOUT &= ~(1<<8);ldr r1,=GPIOCOUTldr r0,[r1]ldr r2,=~(1<<8)and r0,r0,r2str r0,[r1]
//GPIOCOUT |= 1<<7;ldr r1,=GPIOCOUTldr r0,[r1]ldr r2,=(1<<7)orr r0,r0,r2str r0,[r1]
//delay();bl delay
//点亮D10,其他灯熄灭
//GPIOEOUT |= 1<<13;ldr r1,=GPIOEOUTldr r0,[r1]ldr r2,=(1<<13)orr r0,r0,r2str r0,[r1]
//GPIOCOUT |= 1<<17;ldr r1,=GPIOCOUTldr r0,[r1]ldr r2,=(1<<17)orr r0,r0,r2str r0,[r1]
//GPIOCOUT |= 1<<8;ldr r1,=GPIOCOUTldr r0,[r1]ldr r2,=(1<<8)orr r0,r0,r2str r0,[r1]
//GPIOCOUT &= ~(1<<7);ldr r1,=GPIOCOUTldr r0,[r1]ldr r2,=~(1<<7)and r0,r0,r2str r0,[r1]
//delay();bl delayb loopdelay:push {r0,lr}ldr r0,=0x2FF0000delay_loop:sub r0,r0,#1cmp r0,#0bne delay_loopbx lr//代码段的结束
.end

2.保存,并在ubuntu操作系统中使用编译代码
arm-linux-gcc -c led.S -o led.o -nostdlib
arm-linux-ld -Ttext 0x40000000 -o led.elf led.o
arm-linux-objcopy -O binary led.elf led.bin
获得.bin文件。

3.将.bin文件通过串口下载到开发板中。
将开发板运行在uboot状态
在命令行输入
loady 0x40000000

4.执行程序
go 0x40000000

五、实验结果及分析

1、D7、D8、D9、D10四盏灯轮流点亮。

2、当其中一盏灯灯亮的时候,其余灯熄灭。

3、其中一盏灯到下一盏灯的时长是可以由delay函数来控制的,在本次实验中,将delay中设置了一个数0x2FF0000,当此数归0时,下一盏灯灯亮。如果想要流水灯变慢,可以扩大这个16进制数。

4、原理是通过GPIOxOUT的轮换变化来控制灯的灯亮和熄灭。

这篇关于广州大学 汇编语言与接口技术实验2 简单接口应用实验 2020.12的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/351180

相关文章

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu2289(简单二分)

虽说是简单二分,但是我还是wa死了  题意:已知圆台的体积,求高度 首先要知道圆台体积怎么求:设上下底的半径分别为r1,r2,高为h,V = PI*(r1*r1+r1*r2+r2*r2)*h/3 然后以h进行二分 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#includ

hdu1394(线段树点更新的应用)

题意:求一个序列经过一定的操作得到的序列的最小逆序数 这题会用到逆序数的一个性质,在0到n-1这些数字组成的乱序排列,将第一个数字A移到最后一位,得到的逆序数为res-a+(n-a-1) 知道上面的知识点后,可以用暴力来解 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#in

zoj3820(树的直径的应用)

题意:在一颗树上找两个点,使得所有点到选择与其更近的一个点的距离的最大值最小。 思路:如果是选择一个点的话,那么点就是直径的中点。现在考虑两个点的情况,先求树的直径,再把直径最中间的边去掉,再求剩下的两个子树中直径的中点。 代码如下: #include <stdio.h>#include <string.h>#include <algorithm>#include <map>#

usaco 1.3 Prime Cryptarithm(简单哈希表暴搜剪枝)

思路: 1. 用一个 hash[ ] 数组存放输入的数字,令 hash[ tmp ]=1 。 2. 一个自定义函数 check( ) ,检查各位是否为输入的数字。 3. 暴搜。第一行数从 100到999,第二行数从 10到99。 4. 剪枝。 代码: /*ID: who jayLANG: C++TASK: crypt1*/#include<stdio.h>bool h

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、

uva 10387 Billiard(简单几何)

题意是一个球从矩形的中点出发,告诉你小球与矩形两条边的碰撞次数与小球回到原点的时间,求小球出发时的角度和小球的速度。 简单的几何问题,小球每与竖边碰撞一次,向右扩展一个相同的矩形;每与横边碰撞一次,向上扩展一个相同的矩形。 可以发现,扩展矩形的路径和在当前矩形中的每一段路径相同,当小球回到出发点时,一条直线的路径刚好经过最后一个扩展矩形的中心点。 最后扩展的路径和横边竖边恰好组成一个直

AI行业应用(不定期更新)

ChatPDF 可以让你上传一个 PDF 文件,然后针对这个 PDF 进行小结和提问。你可以把各种各样你要研究的分析报告交给它,快速获取到想要知道的信息。https://www.chatpdf.com/