ARM day5 (点灯实验 汇编&C)

这篇具有很好参考价值的文章主要介绍了ARM day5 (点灯实验 汇编&C)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

汇编

.text 
.global _start
_start: 
	/**********LED1点灯**************/
	/**********RCC草节初始化**************/

	//1.通过RCC_MP_AHB4ENSETR寄存器使能GPIOE组控制器0x50000A28[4] = 1
	ldr r0,=0x50000A28
	ldr r1,[r0]
	orr r1,r1,#(0x1 << 4)
	str r1,[r0]

	//1.通过RCC_MP_AHB4ENSETR寄存器使能GPIOF组控制器0x50000A28[5] = 1
	ldr r0,=0x50000A28
	ldr r1,[r0]
	orr r1,r1,#(0x1 << 5)
	str r1,[r0]

	/*********GPIO章节初始化*************/

LED1_INIT:

	@1.通过GPIOE_MODER寄存器设置PE10引脚为输出模式0x50006000[21:20] = 01
	ldr r0,=0x50006000
	ldr r1,[r0]
	and r1,r1,#(~(0x3 << 20))
	orr r1,r1,#(0x1 << 20)
	str r1,[r0]

	@2.通过GPIOE_OTYPER寄存器设置PE10引脚为推挽输出类型0x50006004[10]= 0
	ldr r0,=0x50006004
	ldr r1,[r0]
	and r1,r1,#(~(0x1 << 10))
	str r1,[r0]


	@3.通过GPIOE_OSPBEDR寄存器设置PE10引脚为低速输出模式0x50006008[21:20] = 00
	ldr r0,=0x50006008
	ldr r1,[r0]
	and r1,r1,#(~(0x3 << 20))
	str r1,[r0]


	@4.通过GPIOE_PUPDR寄存器设置PE10引脚禁止上下拉电阻0x5000600C[21:20] = 00
	ldr r0,=0x5000600c
	ldr r1,[r0]
	and r1,r1,#(~(0x3 << 20))
	str r1,[r0]

LED2_INIT:

	@1.通过GPIOF_MODER寄存器设置PF10引脚为输出模式0x50007000[21:20] = 01
	ldr r0,=0x50007000
	ldr r1,[r0]
	and r1,r1,#(~(0x3 << 20))
	orr r1,r1,#(0x1 << 20)
	str r1,[r0]

	@2.通过GPIOF_OTYPER寄存器设置PF10引脚为推挽输出类型0x50007004[10]= 0
	ldr r0,=0x50007004
	ldr r1,[r0]
	and r1,r1,#(~(0x1 << 10))
	str r1,[r0]


	@3.通过GPIOF_OSPBEDR寄存器设置PF10引脚为低速输出模式0x50007008[21:20] = 00
	ldr r0,=0x50007008
	ldr r1,[r0]
	and r1,r1,#(~(0x3 << 20))
	str r1,[r0]


	@4.通过GPIOF_PUPDR寄存器设置PF10引脚禁止上下拉电阻0x5000700C[21:20] = 00
	ldr r0,=0x5000700c
	ldr r1,[r0]
	and r1,r1,#(~(0x3 << 20))
	str r1,[r0]
	
LED3_INIT:

	@1.通过GPIOE_MODER寄存器设置PE8引脚为输出模式0x50006000[17:16] = 01
	ldr r0,=0x50006000
	ldr r1,[r0]
	and r1,r1,#(~(0x3 << 16))
	orr r1,r1,#(0x1 << 16)
	str r1,[r0]

	@2.通过GPIOE_OTYPER寄存器设置PE8引脚为推挽输出类型0x50006004[8]= 0
	ldr r0,=0x50006004
	ldr r1,[r0]
	and r1,r1,#(~(0x1 << 8))
	str r1,[r0]


	@3.通过GPIOE_OSPBEDR寄存器设置PE8引脚为低速输出模式0x50006008[17:16] = 00
	ldr r0,=0x50006008
	ldr r1,[r0]
	and r1,r1,#(~(0x3 << 16))
	str r1,[r0]


	@4.通过GPIOE_PUPDR寄存器设置PE8引脚禁止上下拉电阻0x5000600C[17:16] = 00
	ldr r0,=0x5000600c
	ldr r1,[r0]
	and r1,r1,#(~(0x3 << 16))
	str r1,[r0]
loop:
	bl LED1_ON
	bl delay_1s
	bl LED1_OFF
	
	bl LED2_ON
	bl delay_1s
	bl LED2_OFF

	bl LED3_ON
	bl delay_1s
	bl LED3_OFF



	b loop



LED1_ON:
	@通过GPIOE_ODR寄存器设置PE10引脚输出高电平0x50006014[10] = 1
	ldr r0,=0x50006014
	ldr r1,[r0]
	orr r1,r1,#(0x1 << 10)
	str r1,[r0]
	mov pc,lr


LED1_OFF:

	@通过GPIOE_ODR寄存器设置PE10引脚输出低电平0x50006014[10] = 0
	ldr r0,=0x50006014
	ldr r1,[r0]
	and r1,r1,#(~(0x1 << 10))
	str r1,[r0]
	mov pc,lr


LED2_ON:
	@通过GPIOF_ODR寄存器设置PF10引脚输出高电平0x50007014[10] = 1
	ldr r0,=0x50007014
	ldr r1,[r0]
	orr r1,r1,#(0x1 << 10)
	str r1,[r0]
	mov pc,lr


LED2_OFF:

	@通过GPIOF_ODR寄存器设置PF10引脚输出低电平0x50007014[10] = 0
	ldr r0,=0x50007014
	ldr r1,[r0]
	and r1,r1,#(~(0x1 << 10))
	str r1,[r0]
	mov pc,lr


LED3_ON:
	@通过GPIOE_ODR寄存器设置PE8引脚输出高电平0x50006014[8] = 1
	ldr r0,=0x50006014
	ldr r1,[r0]
	orr r1,r1,#(0x1 << 8)
	str r1,[r0]
	mov pc,lr


LED3_OFF:

	@通过GPIOE_ODR寄存器设置PE8引脚输出低电平0x50006014[8] = 0
	ldr r0,=0x50006014
	ldr r1,[r0]
	and r1,r1,#(~(0x1 << 8))
	str r1,[r0]
	mov pc,lr

	@ 大概1s的延时函数
delay_1s:
mov r3, #0x10000000
mm:
cmp r3, #0
subne r3, r3, #1
bne mm
mov pc, lr


.end

C语言

led.h

#ifndef __LED_H__
#define __LED_H__

//声明一个结构体
typedef struct pio
{
	unsigned int MODER;   //00
	unsigned int OTYPER;  //04
	unsigned int OSPEEDR; //08
	unsigned int PUPDR;   //0C
	unsigned int IDR;     //10
	unsigned int ODR;     //14
}gpio_t;

#define GPIOE ((volatile gpio_t*)0x50006000)
#define GPIOF ((volatile gpio_t*)0x50007000)


void led1_init();
void LED1_on();
void led1_off();


void led2_init();
void LED2_on();
void led2_off();


void led3_init();
void LED3_on();
void led3_off();

#endif

led.c

#include "led.h"

void led1_init()
{
	GPIOE->MODER &= (~(0x3 << 20));
	GPIOE->MODER |= (0x1 << 20);
	GPIOE->OTYPER &=(~(0x1 << 10));
	GPIOE->OSPEEDR &= (~(0x3 << 20));
	GPIOE->PUPDR &= (~(0X3 << 20));
}

void LED1_on()
{

	GPIOE->ODR |= (0x1 << 10);
}

void led1_off()
{
	GPIOE->ODR &= (~(0x1 << 10));
}



void led2_init()
{
	GPIOF->MODER &= (~(0x3 << 20));
	GPIOF->MODER |= (0x1 << 20);
	GPIOF->OTYPER &=(~(0x1 << 10));
	GPIOF->OSPEEDR &= (~(0x3 << 20));
	GPIOF->PUPDR &= (~(0X3 << 20));
}

void LED2_on()
{
	GPIOF->ODR |= (0x1 << 10);
}

void led2_off()
{

	GPIOF->ODR &= (~(0x1 << 10));
}




void led3_init()
{
	GPIOE->MODER &= (~(0x3 << 16));
	GPIOE->MODER |= (0x1 << 16);
	GPIOE->OTYPER &=(~(0x1 << 8));
	GPIOE->OSPEEDR &= (~(0x3 << 16));
	GPIOE->PUPDR &= (~(0X3 << 16));

}

void LED3_on()
{

	GPIOE->ODR |= (0x1 << 8);
}

void led3_off()
{

	GPIOE->ODR &= (~(0x1 << 8));
}



main.c文章来源地址https://www.toymoban.com/news/detail-517345.html

#include "led.h"

extern void printf(const char *fmt, ...);
void delay_ms(int ms)
{
	int i,j;
	for(i = 0; i < ms;i++)
		for (j = 0; j < 1800; j++);
}


int main()
{

	*(volatile unsigned int *)0x50000A28 |= (0x3 << 4);

	led1_init(); // LED灯初始化
	led2_init();
	led3_init();
	while(1)
	{
		LED1_on();
		delay_ms(500);
		led1_off();
		LED2_on();
		delay_ms(500);
		led2_off();
		LED3_on();
		delay_ms(500);
		led3_off();

	}
	return 0;
}

到了这里,关于ARM day5 (点灯实验 汇编&C)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • ARM day5、day6 硬件编程

    fs4412  sd卡  串口线  电源           点灯(亮 or 灭)         2.1 外设原理图 devboard                  查找LED2-CHG_COK(核心板)         2.2 核心板原理图 coreboard                 查找CHG_COK- XEINT23/KP_ROW7/ALV_DBG19/GPX2_7         2.3 看芯片手册                 GPIO控制(第六

    2024年01月19日
    浏览(29)
  • Keil MDK配置ARM汇编/C语言混合开发环境

    1. 安装Keil MDK 安装方法这里不再说明,懂得都懂!🐶 2. 安装ARM开发包 在Keil MDK5之后,不再原生支持ARM7/9,需要自行安装软件包,链接在这,注意安装与自己MDK版本对应的那个包 我的版本是5.18,下载之后傻瓜式安装,因为它会自动检测你MDK所在的位置。 3. 新建工程 注意:选

    2024年02月02日
    浏览(51)
  • ARM day2、day3 汇编

    @ 注释 # 注释(放在行首表示注释一行) /*    */ 注释 #+数字 立即数 : 一种标号(比如main:        loop:) .text        .end+换行 固定格式 ARM指令构成 ARM 指令包含操作码和一些其他的信息,只剩下8 位存放数据 具体来说,一个 ARM 指令通常由以下部分组成: 操作码(Opcode)

    2024年01月19日
    浏览(36)
  • ARM day4 汇编及硬件编程

    load -- 加载 读 store -- 存储 写  在ARM 架构下, 数据从内存到cpu 直接的移动只能通过 LDR/STR来完成      mov 只能在寄存器之间移动数据 ,或把立即数移动到寄存器 ,并且数据长度不能超过 8 位 str  r2,  [r0]   //把r2 的数据  存储(写)到 r0 地址      *((int *) r0)  = r2 往

    2024年01月20日
    浏览(34)
  • ARM汇编语言(2)

    ARM汇编语言是一种低级别的计算机指令集架构(ISA)语言,它是ARM处理器上的一种指令集架构,用于编写底层的系统软件,例如操作系统、驱动程序和嵌入式系统应用程序。 ARM汇编语言使用基于寄存器的指令集,其中指令操作的数据通常存储在处理器的寄存器中,而不是内存

    2024年02月02日
    浏览(46)
  • [ARM 汇编]高级部分—ARM汇编编程实战—3.3.2 嵌入式开发环境搭建

    搭建一个嵌入式开发环境主要包括以下几个部分: 安装交叉编译器 配置集成开发环境(IDE) 安装调试工具 下载和烧录程序 接下来,我们将详细介绍每个部分,并提供相应的实例。 安装交叉编译器 交叉编译器是用于将您编写的ARM汇编代码编译成可执行文件的工具。在本教程

    2024年02月11日
    浏览(38)
  • ARM 体系结构与汇编语言

    Load/Store 架构,CPU 不能直接处理内存中的数据,需要先将内存中的数据加载到寄存器中才能操作,然后将处理结果存储到内存中。 固定的指令长度、单周期指令。 倾向于使用更多的寄存器来存储数据,而不是使用内存中的堆栈、效率更高。 ARM 有桶型移位寄存器,单周期内可

    2024年02月16日
    浏览(29)
  • 嵌入式:ARM汇编语言程序设计基础教程

    ① 合理地分配存储器资源,将前述的目标系统‘数据结构模型’表示到各存储器单元。 ② CPU寄存器数量有限,在程序中,大多数操作都要使用寄存器;并且有的操作使用特定的寄存器(如堆栈操作使用SP/R13等),程序中要合理分配各寄存器的用途。 用计算机语言,对数据结

    2023年04月23日
    浏览(71)
  • 用ARM进行汇编语言编程(4)带有分支的循环和条件指令执行

    ARM 编程模拟器网站地址: 在arm里也有和高级语言一样的for和while循环,可以根据条件来判断是否执行 首先我们创建一个data标签,然后在里面写一个分支,存放一些数值,然后使这些存放的数值依次相加 然后我们要将list加载到内存里 然后使用直接寻址,将r0寄存器里的值放

    2024年02月06日
    浏览(36)
  • arm点灯

    2.  

    2024年02月16日
    浏览(23)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包