ARM X210开发板的软开关按键问题

news2024/9/21 2:37:24

一、X210 开发板的软启动电路详解

在这里插入图片描述
《x210bv3.pdf》


(1) 210 供电需要的电压比较稳定,而外部适配器的输出电压不一定那么稳定,因此板载了一个文稳压器件 MP1482. 这个稳压芯片的作用就是外部适配器电压在一定范围内变化时稳压芯片的输出电压都是 5V。
(2) MP1482芯片有一个EN(Enable)引脚,这个引脚可以让稳压芯片输出或关闭输出。EN 为高电平时有输出电压,EN 引脚为低电平时稳压芯片无输出。
(3) 两个因素可以影响 EN 引脚的电平:第一个是 POWER 按键(SW1),POWER 按键按下时 EN 为高电平,POWER 按键弹起时 EN 为低电平;第二个是 POWER_LOCK(EINT0)引脚,这个引脚为 POWER_LOCK 模式下高电平,则 EN 为高;若这个引脚为 EINT0 模式或者为POWER_LOCK 模式但输出为低电平,则 EN 为低。
(4) 图中还有 EINT1 引脚,这个引脚的作用是用来做中断,提供给 CPU 用来唤醒的。


二、为什么要软启动

(1) 一般的电路设计都是用拨码开关来做电源开关的(打到一侧则接通,打到另一侧则关闭)。这种方式的优点是设计简单,缺点是电路太简单,整个主板要么有电要么没电无法做休眠模式、低功耗模式等。
(2) 软启动电路是比较接近于实际产品的,其他开发板的硬开关其实是简化版的,和实际产品还有差异。


《x210v3s开发板裸机教程.pdf》

市面上绝大多数开发板都是给整个系统直接上电,通过拨码开关实现硬件开关机,这种设计开发板将无法休眠唤醒。x210 开发板独特的软件开关机功能,可实现轻触开关实现软件开关机,休眠唤醒等,让开发板更接近产品。

上述电路图中,EINT0 用于置锁整个开发板的 5V 电源,EINT0 为高时,5V 电源被使能,为低时 5V 电源关闭。在实现休眠唤醒时,配合 EINT1 中断,通过 POWER 键实现中断响应,继而实现休眠唤醒。

EINT0 管脚和 PS_HOLD 管脚复用,当 PS_HOLD_CONTROL 寄存器的第 0 位设置为高时,使 能 PS_HOLD 管 脚 , 这 时 , EINT0 的 相 关 寄 存 器 设 置 将 无 效 , 该 管 脚 将 完 全 由PS_HOLD_CONTROL 寄存器控制。
在这里插入图片描述

我们将 PS_HOLD_CONTROL 的第 8,9 位设置为 1 时,该 IO 口为高,设置为 0 时,为低。
在 tester_powerlock 函数中,经 5 秒延时后,执行如下指令:

writel(S5PV210_PS_HOLD_CONTROL, (readl(S5PV210_PS_HOLD_CONTROL) & ~( 0x00000301 )) | ((0x1<<0) | (0x0<<8) | (0x0<<9)));

即将 PS_HOLD_CONTROL 的第 8,9 位清零,这时,EINT0 管脚被拉低,整个开发板的 5V
电源被关闭,开关板断电关机。

在整个 main 函数中,我们并没有对该寄存器做过任何设置,而上面的寄存器表格显示,在
芯片的初始化状态,PS_HOLD_CONTROL 的第 0 位是 0,即默认为普通 GPIO 口,复位时电平
为 0,那么开发板为什么还能运行起来呢?

在 start.s 中,有如下程序段:

ldr r0, =0xe010e81c
ldr r1, [r0]
orr r1, r1, #0x300
orr r1, r1, #0x1
str r1, [r0]

上面程序将 PS_HOLD_CONTROL 的第 0,8,9 位置高,即将该 IO 设置为 PS_HOLD 的模
式的同时,将 IO 口拉高,实现 5V 电源置锁。如果在 start.s 中去掉上面语句,那么开发板只
能长按住 POWER 键不放,才能维持电平。


三 、开发板供电置锁原理和分析

(1) 软开关在设计时有一个置锁电路,用 EINT0(也就是GPH0_2)引脚来控制的。

(2) EINT0 这个引脚是有复用设计(两个完全不相干的功能挤在同一个引脚上,同时我们只能让这个引脚用于其中一种功能,这就叫复用)的,一个是 GPIO(也就是GPH0_2引脚)、一个是PS_HOLD_CONTROL。(注意:EINT0 功能算是 GPIO 下的一个子功能)。

(3) PS_HOLD 在Section2.4 Power Management章节下的 4.10.5.8 节下。
在这里插入图片描述

(4) PS_HOLD_CONTROL 寄存器(0xE010E81C),共有 3 个位有用。
bit0, 0 表示这个引脚为 GPIO 功能,1表示这个引脚为 PS_HOLD 功能;
bit9,0 表示这个引脚方向为输入,1 表示这个引脚方向为输出。
bit8,0 表示这个引脚输出为低电平,1 表示输出为高电平。

分析:我们要使用软启动置锁,则需要将 bit0、8、9 都置为 1 即可。


四、写代码+实验验证

(1) 要想让开发板和普通的开发板一样,一按下按键程序运行后即可松手不会断电,则只要在程序的开头部分添加代码去置锁开关板即可。

文件名: BL1/start.S

 cat BL1/start.S

/*
 * 文件名:     start.s
 * 描述:       演示重定位(在SRAM内部重定位)
 */

#define WTCON           0xE2700000

#define SVC_STACK       0xd0037d80

.global _start                                  // 把_start链接属性改为外部,这样其他文件就可以看见_start了
_start:
        //第0步:开发板置锁
        ldr r0, =0xe010e81c
        ldr r1, [r0]
        orr r1, r1, #0x300
        orr r1, r1, #0x1
        str r1, [r0]

        // 第1步:关看门狗(向WTCON的bit5写入0即可)
        ldr r0, =WTCON
        ldr r1, =0x0
        str r1, [r0]

        // 第2步:设置SVC栈
        ldr sp, =SVC_STACK

        // 第3步:开/关icache
        mrc p15,0,r0,c1,c0,0;                   // 读出cp15的c1到r0中
        //bic r0, r0, #(1<<12)                  // bit12 置0  关icache
        orr r0, r0, #(1<<12)                    // bit12 置1  开icache
        mcr p15,0,r0,c1,c0,0;

        // 第4步:初始化ddr
        bl sdram_asm_init

        // 第5步:重定位,从SD卡第45扇区开始,复制32个扇区内容到DDR的 0x23E0,0000
        bl copy_bl2_2_ddr


// 汇编最后的这个死循环不能丢
        b .

(2) 置锁代码的方法是:给 PS_HOLD_CONTROL 寄存器的 bit0、8、9 均写入 1 即可。

(3) 注意:此时开发板已经置锁,POWER 按键已经失效,关机时需要按下复位按键。


源自朱有鹏老师.

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

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

相关文章

Redis 主从复制

目录一、简介二、复制功能三、将服务器设置为从服务器3.1、手动设置3.2、REPLICAOF 配置选项3.3、取消复制四、查看服务器的角色4.1、查看主服务器4.2、查看从服务器五、其他配置5.1、无硬盘复制5.2、降低数据不一致情况出现的概率5.3、可写的从服务器5.4、选择性命令传播六、w…

SpringBoot统一功能处理

目录 一、统一用户的登录验证 1.1 Spring AOP 实现用户统一登录验证 1.2Spring拦截器实现统一用户的登录验证 1.3 实例演示&#xff08;通过url访问controller层的方法&#xff09; 二、统一异常处理 三、统一数据格式返回 3.1 统一数据返回格式的优点 3.2 统一数据返回…

旺季到来,跨境电商卖家年末冲刺!

又是一年年末时&#xff0c;随着新年的到来&#xff0c;在年底这段时间里&#xff0c;对于跨境电商卖家来说&#xff0c;又是一个关键节点。而现在&#xff0c;卖家们也将迎来一年一度的旺季收官&#xff0c;在此过程中卖家需要做好哪些准备做好年末冲刺呢&#xff1f; 在许多…

量化策略——准备3 数据、Backtrader回测框架与quantstats评价指标

我们一般使用AKShare这个库来获取股票数据或策略中用得到的数据&#xff1a; AKShare github主页&#xff1a;https://github.com/akfamily/akshare 使用Backtrader框架作为回测的框架&#xff1a; Backtrader github主页&#xff1a;https://github.com/mementum/backtrader …

【CTF】git源码泄露和代码审计

目录 源码获取 函数绕过 解法一&#xff1a; 解法二&#xff1a; 参考文章&#xff1a; 源码获取 这里做的web题目是buuctf中的&#xff1a;[GXYCTF2019]禁止套娃 打开页面&#xff0c;查看源码是没有可以利用的点的。开始进行目录扫描 这里使用的工具是dirsearch。直接…

前端js实现多次添加累加文件上传和选择删除(django+js)- 编辑回显文件并上传 (二)

前言 后端返回的是文件地址&#xff0c;并不是文件流或base64编码字符串&#xff0c;而修改数据的接口又只接受文件。 本篇文章主要是基于累加文件上传介绍的。 添加上传文件文章链接&#xff1a;https://blog.csdn.net/qq_43030934/article/details/128726549?spm1001.2014.…

jmeter 压测java代码

一、背景 直接压测、调用java工程中的方法。&#xff08;没有http等的入口&#xff09; 二、java项目改造 一个java项目&#xff0c;想要压测其中的几个方法。我们需要在该工程中&#xff0c;添加一个压测入口的类&#xff0c; 这个类必须继承或者实现jmeter提供的接口/类。…

C语言萌新如何使用scanf函数?

&#x1f40e;作者的话 如果你搜索输入输出函数&#xff0c;那么你会看到输入输出流、Turbo标准库、标准输出端、stdout什么什么乱七八糟的&#xff0c;作为一个萌新&#xff0c;哪懂这些&#xff1f; 本文介绍萌新在前期的学习中&#xff0c;常用的输入输出函数及其功能~ 跳…

HTML5+CSS3小实例:炫彩的发光字特效

前言&#xff1a; 今天我们向大家精选了一款HTML5CSS3文字特效&#xff0c;文字特效有超酷的动画类型&#xff0c;不多说&#xff0c;一起来看看。 描述&#xff1a; 这款文字特效既有倒影的效果&#xff0c;又有随机的颜色&#xff0c;看起来非常的炫酷。全文基于 HTML5CSS3 完…

log4j.properties自定义日志配置

一、通用的写法log4j.properties# 设置root logger等级为ALL&#xff0c;且appender有A1和FILE log4j.rootLoggerALL, A1,A3#设置com.example.test logger log4j.logger.com.example.testDEBUG,A1,A3 # 取消继承父类 log4j.additivity.com.example.testfalse# 设置个控制台输出…

即时通讯开发之TCP 连接的建立与中止

TCP 是一个面向连接的协议,所以在连接双方发送数据之前,都需要首先建立一条连接。这和前面讲到的协议完全不同。前面讲的所有协议都只是发送数据 而已,大多数都不关心发送的数据是不是送到,UDP 尤其明显,从编程的角度来说,UDP 编程也要简单 的多----UDP 都不用考虑数据分片。 书…

Ubuntu下源码编译VirtualBox一 —— 源码下载

VirtualBox想必大家都不陌生&#xff0c;做Linux开发的尤其是嵌入式Linux开发的人应该基本都知道或玩过VMware和VirtualBox。但通常都是为了在Windows电脑上能够使用Linux环境、即在Windows环境下通过下载可执行文件安装的VirtualBox。本文介绍在Linux环境&#xff08;Ubuntu 2…

系分 - 论文 - 总览知识点

个人总结&#xff0c;仅供参考&#xff0c;欢迎加好友一起讨论 文章目录系分 - 论文 - 总览往年论文一览论文考点考试时间考试过程论文技巧论文写作论文扣分与加分系分 - 论文 - 总览 往年论文一览 一般情况下&#xff0c;往下数5、6年的题目出题形式&#xff0c;具有参考意义…

痞子衡嵌入式:盘点国内Cortex-M内核MCU厂商高主频产品(2023)

大家好&#xff0c;我是痞子衡&#xff0c;是正经搞技术的痞子。今天痞子衡给大家介绍的是国内Cortex-M内核MCU厂商高主频产品。 在 2021 年初痞子衡写了篇 《盘点国内Cortex-M内核MCU厂商高性能产品》&#xff0c;搜罗了当时市面上主频不低于 96MHz 的 CM 核国产 MCU。如今过去…

LSTM MultiheadAttention 输入维度

最近遇到点问题&#xff0c;对于模块的输入矩阵的维度搞不清楚&#xff0c;这里在学习一下&#xff0c;记录下来&#xff0c;方便以后查阅。 LSTM & Attention 输入维度LSTM记忆单元门控机制LSTM结构LSTM的计算过程遗忘门输入门更新记忆单元输出门LSTM单元的pytorch实现Pyt…

Spring Security in Action 第七章 配置授权:限制访问

本专栏将从基础开始&#xff0c;循序渐进&#xff0c;以实战为线索&#xff0c;逐步深入SpringSecurity相关知识相关知识&#xff0c;打造完整的SpringSecurity学习步骤&#xff0c;提升工程化编码能力和思维能力&#xff0c;写出高质量代码。希望大家都能够从中有所收获&#…

[leetcode 72] 编辑距离

题目 题目&#xff1a;https://leetcode.cn/problems/edit-distance/description/ 类似题目&#xff1a;[leetcode 583] 两个字符串的删除操作 解法 动态规划 这题应该是字符串dp的终极形态了吧&#x1f923;&#xff0c;不看答案完全不会…看了答案发现原来还是dp… 以例题…

未来的竞争是认知和执行力的竞争,只有认知高,强执行才能赚钱

之前很火的一句话是&#xff1a;你永远赚不到认知范围之外的钱所以只有持续不断地提升认知才能持续成长&#xff0c;持续提升&#xff0c;持续赚钱。未来的竞争从另一方面来说也是认知的竞争。不同的认知对待同一事物、信息有不同的理解&#xff1b;不同的认知对待同一事物、信…

固高科技在创业板提交注册:业绩开始下滑,实控人均为“学院派”

近日&#xff0c;固高科技股份有限公司&#xff08;下称“固高科技”&#xff09;在深圳证券交易所创业板递交注册。据贝多财经了解&#xff0c;固高科技于2021年12月在创业板递交上市申请&#xff0c;2022年8月17日获得上市委会议通过。 本次冲刺创业板上市&#xff0c;固高科…

【一道面试题】说一下Synchronized?

说一下Synchronized&#xff1f; Synchronized锁是Java中为了解决线程安全问题的一种方式&#xff0c;是一种悲观锁Synchronized可以用来修饰方法或者以代码块&#xff0c;用来保证线程执行方法或代码块时的原子性Java中任何一个类的对象都可以用来作为锁对象&#xff0c;但是…