ARM实验 LED流水灯

.text 
.global _start
_start: @使能GPIOE GPIOF的外设时钟  RCC_MP_AHB4ENSETR的第[4][5]设置为1即可使能GPIOE GPIOF时钟
LDR R0,=0X50000A28   @指定寄存器地址
LDR R1,[R0]  @将寄存器原来的数值读取出来,保存到R1中
ORR R1,R1,#(0x3<<4)   @将第4位设置为1
STR R1,[R0]  @将修改后的数值写回@设置PE10为输出  将GPIOE_MODER[21:20]设置为01,就能够让PE10为输出工作模式
LDR R0,=0X50006000   @指定寄存器地址
LDR R1,[R0]  @将寄存器原来的数值读取出来,保存到R1中
BIC R1,R1,#(0x3<<20)   @将第21:20清0
ORR R1,R1,#(0x1<<20)   @将第21:20设置为01
STR R1,[R0]  @将修改后的数值写回@设置PE10为推晚输出  将GPIOE_OTYPER寄存器[10]设置为0,就能够让PE10以推挽输出模式进行工作
LDR R0,=0X50006004   @指定寄存器地址
LDR R1,[R0]  @将寄存器原来的数值读取出来,保存到R1中
BIC R1,R1,#(0x1<<10)   @将第10清0
STR R1,[R0]  @将修改后的数值写回@设置PE10为低速输出
LDR R0,=0X50006008   @指定寄存器地址
LDR R1,[R0]  @将寄存器原来的数值读取出来,保存到R1中
BIC R1,R1,#(0x3<<20)   @将第21:20清0
STR R1,[R0]  @将修改后的数值写回@设置无上拉下拉电阻 
LDR R0,=0X5000600C   @指定寄存器地址
LDR R1,[R0]  @将寄存器原来的数值读取出来,保存到R1中
BIC R1,R1,#(0x3<<20)   @将第21:20清0
STR R1,[R0]  @将修改后的数值写回@设置PF10为输出  将GPIOF_MODER[21:20]设置为01,就能够让PF10为输出工作模式
LDR R0,=0X50007000   @指定寄存器地址
LDR R1,[R0]  @将寄存器原来的数值读取出来,保存到R1中
BIC R1,R1,#(0x3<<20)   @将第21:20清0
ORR R1,R1,#(0x1<<20)   @将第21:20设置为01
STR R1,[R0]  @将修改后的数值写回@设置PF10为推晚输出  将GPIOF_OTYPER寄存器[10]设置为0,就能够让PF10以推挽输出模式进行工作
LDR R0,=0X50007004   @指定寄存器地址
LDR R1,[R0]  @将寄存器原来的数值读取出来,保存到R1中
BIC R1,R1,#(0x1<<10)   @将第10清0
STR R1,[R0]  @将修改后的数值写回@设置PF10为低速输出
LDR R0,=0X50007008   @指定寄存器地址
LDR R1,[R0]  @将寄存器原来的数值读取出来,保存到R1中
BIC R1,R1,#(0x3<<20)   @将第21:20清0
STR R1,[R0]  @将修改后的数值写回@设置无上拉下拉电阻 
LDR R0,=0X5000700C   @指定寄存器地址
LDR R1,[R0]  @将寄存器原来的数值读取出来,保存到R1中
BIC R1,R1,#(0x3<<20)   @将第21:20清0
STR R1,[R0]  @将修改后的数值写回@设置PE8为输出  将GPIOE_MODER[17:16]设置为01,就能够让PE8为输出工作模式
LDR R0,=0X50006000   @指定寄存器地址
LDR R1,[R0]  @将寄存器原来的数值读取出来,保存到R1中
BIC R1,R1,#(0x3<<16)   @将第17:16清0
ORR R1,R1,#(0x1<<16)   @将第17:16设置为01
STR R1,[R0]  @将修改后的数值写回@设置PE8为推晚输出  将GPIOE_OTYPER寄存器[8]设置为0,就能够让PE8以推挽输出模式进行工作
LDR R0,=0X50006004   @指定寄存器地址
LDR R1,[R0]  @将寄存器原来的数值读取出来,保存到R1中
BIC R1,R1,#(0x1<<8)   @将第8清0
STR R1,[R0]  @将修改后的数值写回@设置PE8为低速输出
LDR R0,=0X50006008   @指定寄存器地址
LDR R1,[R0]  @将寄存器原来的数值读取出来,保存到R1中
BIC R1,R1,#(0x3<<16)   @将第17:16清0
STR R1,[R0]  @将修改后的数值写回@设置无上拉下拉电阻 
LDR R0,=0X5000600C   @指定寄存器地址
LDR R1,[R0]  @将寄存器原来的数值读取出来,保存到R1中
BIC R1,R1,#(0x3<<16)   @将第17:16清0
STR R1,[R0]  @将修改后的数值写回loop:
@设置LED1亮BL LED1_ONBL LED2_OFFBL LED3_OFFBL DELAY@设置LED2亮BL LED2_ONBL LED1_OFFBL LED3_OFFBL DELAY@设置LED3亮BL LED3_ONBL LED1_OFFBL LED2_OFFBL DELAYb loopLED1_ON:LDR R0,=0X50006014   @指定寄存器地址LDR R1,[R0]  @将寄存器原来的数值读取出来,保存到R1中ORR R1,R1,#(0x1<<10)   @将第10设置为1STR R1,[R0]  @将修改后的数值写回 MOV PC,LR
LED1_OFF:LDR R0,=0X50006014   @指定寄存器地址LDR R1,[R0]  @将寄存器原来的数值读取出来,保存到R1中BIC R1,R1,#(0x1<<10)   @将第10设置为0STR R1,[R0]  @将修改后的数值写回 MOV PC,LRLED2_ON:LDR R0,=0X50007014   @指定寄存器地址LDR R1,[R0]  @将寄存器原来的数值读取出来,保存到R1中ORR R1,R1,#(0x1<<10)   @将第10设置为1STR R1,[R0]  @将修改后的数值写回 MOV PC,LR
LED2_OFF:LDR R0,=0X50007014   @指定寄存器地址LDR R1,[R0]  @将寄存器原来的数值读取出来,保存到R1中BIC R1,R1,#(0x1<<10)   @将第10设置为0STR R1,[R0]  @将修改后的数值写回 MOV PC,LRLED3_ON:LDR R0,=0X50006014   @指定寄存器地址LDR R1,[R0]  @将寄存器原来的数值读取出来,保存到R1中ORR R1,R1,#(0x1<<8)   @将第8设置为1STR R1,[R0]  @将修改后的数值写回 MOV PC,LR
LED3_OFF:LDR R0,=0X50006014   @指定寄存器地址LDR R1,[R0]  @将寄存器原来的数值读取出来,保存到R1中BIC R1,R1,#(0x1<<8)   @将第8设置为0STR R1,[R0]  @将修改后的数值写回 MOV PC,LRDELAY:LDR R3,=0x10000000
MM:CMP R3,#0SUBNE R3,R3,#1BNE MMMOV PC,LR.end

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/765560.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux网络协议栈从应用层到内核层②

文章目录 1、bind 源码剖析2、listen 源码剖析3、accept 源码剖析4、connect 源码剖析客户端调用connect成功&#xff0c;但三次握手并未完成&#xff0c;进程是如何阻塞自己客户端在connect时&#xff0c;如何选择源端口客户发送syn封包以及重传服务端收到syn封包&#xff0c;…

AIGC摩尔定律

关于AIGC(Artificial Intelligence Generated Content,人工智能生成内容)领域的“摩尔定律”,这是一个比喻性的概念,用来描述AI模型尤其是深度学习模型在算力、效率以及能力方面的指数级增长趋势。传统的摩尔定律是指集成电路上可容纳的晶体管数量大约每两年翻一番,从而带…

算法公式汇总

文章目录 三角函数定义式诱导公式平方关系两角和与差的三角函数积化和差公式和差化积公式倍角公式半角公式万能公式其他公式反三角函数恒等式 三角函数定义式 三角函数 定义式 余切&#xff1a; c o t A 1 t a n A \text { 余切&#xff1a;} \ cotA \frac{1}{tanA} 余切&a…

Java面向对象编程面试题

序号问题详细答案1什么是类与对象&#xff1f;类和对象实例之间的关系&#xff1f; 类具有继承、数据隐藏和多态三种主要特性。类是同一类对象实例的共性的抽象&#xff0c;对象是类的实例化&#xff1b;类是静态的&#xff0c;对象是动态的&#xff0c;对象可以看作是运行中…

微店获得店铺的所有商品 API 返回值说明

一、应用场景 店铺的所有商品API接口具有广泛的应用场景&#xff0c;主要涉及到电商平台的运营、数据分析、用户体验提升以及第三方应用集成等方面。 首先&#xff0c;对于电商平台而言&#xff0c;店铺的所有商品API接口是获取商品信息的核心途径。通过调用这个接口&#xf…

x-zse-96安卓端纯算,魔改AES还原

两天前发了一个x-zse-96的文章,当时遇到了点问题,只分析到了最后一个白盒AES函数里面,并且当时用dfa攻击还原出了秘钥,IV也确定了,但是加密结果不对,本来打算把下文鸽掉的,因为当时unidbg没跑起来,用frida去hook白盒AES中的每一行汇编有点麻烦,没有unidbg方便.后来小白大佬说un…

内网渗透(一)必须了解Windows工作组

★★免责声明★★ 文章中涉及的程序(方法)可能带有攻击性&#xff0c;仅供安全研究与学习之用&#xff0c;读者将信息做其他用途&#xff0c;由Ta承担全部法律及连带责任&#xff0c;文章作者不承担任何法律及连带责任。 1、内网渗透测试简介 内网也叫局域网&#xff0c;是指在…

代码随想录学习Day 14

104.二叉树的最大深度 题目链接 讲解链接 本题很容易想到采用层次遍历的思路来解决&#xff0c;因为要求的是二叉树的最大深度&#xff0c;那么在进行层次遍历的时候设置一个变量count用来记录当前遍历的层数&#xff0c;count初始为0&#xff0c;每遍历完一层将其值1&#…

《自动机理论、语言和计算导论》阅读笔记:p1-p4

《自动机理论、语言和计算导论》学习第1天&#xff0c;p1-p4&#xff0c;总计4页。这只是个人的学习记录&#xff0c;因为很多东西不懂&#xff0c;难免存在理解错误的地方。 一、技术总结 1.有限自动机(finite automata)示例 1.software for checking digital circuits。 …

工作需求,Vue实现登录

加油&#xff0c;新时代打工人&#xff01; vue 2.x Element UI <template><div class"body" :style"{background-image: url(${require(/assets/images/login.png)})}"><el-form :rules"rules" ref"loginForm" :mode…

MySQL 中的索引

MySQL 中的索引 一、索引的创建和删除1.主键会自动添加索引2.unique 约束的字段自动添加索引3.给指定的字段添加索引4.删除指定索引5.查询表上的索引 二、索引的分类三、MySQL索引采用了B树数据结构1.B树的经典面试题 四、其他索引及相关调优1.Hash索引2.聚集索引和非聚集索引3…

【linux线程(四)】初识线程池手撕线程池

&#x1f493;博主CSDN主页:杭电码农-NEO&#x1f493;   ⏩专栏分类:Linux从入门到精通⏪   &#x1f69a;代码仓库:NEO的学习日记&#x1f69a;   &#x1f339;关注我&#x1faf5;带你学更多操作系统知识   &#x1f51d;&#x1f51d; Linux线程池 1. 前言2. 什么是…

Python 从0开始 一步步基于Django创建项目(3)使用Admin site管理数据模型

本文内容建立在《Python 从0开始 一步步基于Django创建项目&#xff08;2&#xff09;创建应用程序&数据模型》的基础上。 Django提供的admin site&#xff0c;使得网站管理员&#xff0c;能够轻松管理网站的数据模型。 本文首先创建‘管理员账户’&#xff0c;即超级用户…

最长上升子序列的动态规划:暴力dfs + 记忆化搜索 + dp

LIS &#xff0c;&#xff08;Longest Increasing Subsequence&#xff09;本题链接&#xff1a;895. 最长上升子序列 - AcWing题库 给定一个长度为 N的数列&#xff0c;求数值严格单调递增的子序列的长度最长是多少。 目录 方法一&#xff1a;暴力dfs 方法二&#xff1a;记忆…

华为OD机22道试题

华为OD机试题 2.查找小朋友的好朋友位置 在学校中&#xff0c;N 个小朋友站成一队&#xff0c;第 i 个小朋友的身高为 height[i]&#xff0c;第 i 个小朋友可以看到第一个比自己身高更高的小朋友j&#xff0c;那么 j 是 i 的好朋友 (要求&#xff1a;j>i) 。 请重新生成一个…

202305 CSP认证

202305-1 重复局面 第一题直接干 #include<bits/stdc.h> using namespace std; unordered_map<string, int> chess; int main() {ios::sync_with_stdio(false); cin.tie(0); cout.tie(0);string line, str ""; int n;cin >> n;while(n --){str …

数据结构:链式队列

1.设计思想&#xff1a; 我们可以设计出以上五种队列&#xff0c;但是基于时间复杂度&#xff0c;和空间复杂度的最优解&#xff0c;我们选择入队和出队均为O(1)的&#xff0c;也就是第五种 2.结构设计 typedef struct LPNode//数据节点 {int data;//数据struct LPNode* next…

Redis消息队列与thinkphp/queue操作

业务场景 场景一 用户完成注册后需要发送欢迎注册的问候邮件、同时后台要发送实时消息给用户对应的业务员有新的客户注册、最后将用户的注册数据通过接口推送到一个营销用的第三方平台。 遇到两个问题&#xff1a; 由于代码是串行方式&#xff0c;流程大致为&#xff1a;开…

基于STC12C5A60S2系列1T 8051单片机可编程计数阵列CCP/PCA/PWM模块的捕获模式(外部中断)应用

基于STC12C5A60S2系列1T 8051单片机可编程计数阵列CCP/PCA/PWM模块的捕获模式(外部中断)应用 STC12C5A60S2系列1T 8051单片机管脚图STC12C5A60S2系列1T 8051单片机I/O口各种不同工作模式及配置STC12C5A60S2系列1T 8051单片机I/O口各种不同工作模式介绍STC12C5A60S2系列1T 805…

【leetcode】动态规划专题

70.爬楼梯 假设你正在爬楼梯。需要 n 阶你才能到达楼顶。 每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢&#xff1f; 示例 1&#xff1a; 输入&#xff1a;n 2 输出&#xff1a;2 解释&#xff1a;有两种方法可以爬到楼顶。 1. 1 阶 1 阶 2. 2 阶 示…