嵌入式养成计划-52----ARM--开发板介绍--相关硬件基础内容介绍--GPIO讲解

一百三十一、开发板介绍

131.1 核心板介绍

在这里插入图片描述

131.2 拓展板

在这里插入图片描述

一百三十二、相关硬件基础内容介绍

132.1 PCB

PCB( Printed Circuit Board),中文名称为印制电路板,又称印刷线路板,
是重要的电子部件,是电子元器件的支撑体,是电子元器件电气相互连接的载体。
由于它是采用电子印刷术制作的,故被称为“印刷”电路板。

在这里插入图片描述

132.2 电路板丝印

  • 可以通过不同元器件的丝印标号在电路原理图中对应的硬件原理图
    电路板丝印是用丝网bai印刷技术来制作印刷电路板。
    丝印指得是丝印层,画pcb的时候是分层的,其中包含文字的那一层,用来标注元件或者添加其他信息,这一层叫丝印层。通过丝网印刷方式将元件外形、序号以及其他说明性文字印制在元件面或焊锡面上,
    以方便电路板生产过程的插件(包括表面封装元件的贴片)以及日后产品的维修操作。
    
  • 不同的电路元件的丝印图:
    Ux	:	常作为开发板上芯片的标号
    Rx	:	电阻
    Cx	:	电容
    Dx	:	二极管
    Qx	:	三极管
    
  • 标准器件的丝印的编号:
    U? --> 芯片  C? --> 电容   R? --> 电阻  L? --> 电感
    D? --> 二极管  Q? --> 三极管 J? --> 接插件 CON? --> 接插件
    
  • 非标准器件的丝印编号:器件的编号的名字可以自定义
    FAN1 --> 风扇
    LD1  --> LED1灯
    KEY1 --> 按键1
    
  • 网络标号
    在原理图上,器件引脚上边红色的字,就是网络标号,
    网络标号相同的两个引脚说明具有相同的电器连接属性,
    即在PCB板上两个引脚通过导线进行连接。网络标号(net label)是一个电气连接点,一般由字母或数字组成,
    具有相同网络标号的电气连接线、管脚、及网络是连接在一起的
    

一百三十三、GPIO讲解

133.1 GPIO概念

GPIO,英文全称为General-Purpose IO ports,也就是通用IO口。
在嵌入式系统中常常有数量众多,但是结构却比较简单的外部设备/电路,对这些设备/电路,有的需要CPU为之提供控制手段,有的则需要被CPU用作输入信号。
而且,许多这样的设备/电路只要求一位,即只要有开/关两种状态就够了,
比如:控制某个LED灯亮与灭;或者通过获取某个管脚的电平属性来达到判断外围设备的状态。对这些设备/电路的控制,使用传统的串行口或并行口都不合适。所以在微控制器芯片上一般都会提供一个“通用可编程IO接口”,即GPIO。 

133.2 LED灯电路原理图分析

133.2.1 在开发板上找到LED1的丝印

  • 通过查看资源拓展板,发现LED1的丝印为LD1

133.2.2 根据LED1丝印找到LED1在拓展板上的原理图

在这里插入图片描述

这个LED1电路原理图种有一个3.3v的电源,右边接地,
在LED1发光二极管左边接了一个电阻,用于分压限流,保护电路,右边接到一个三极管的集电极,三级管的基极网络标号为LED1

在这里插入图片描述

133.2.3 根据网络标号找转接板电路原理图

在这里插入图片描述
在这里插入图片描述

133.2.4 分析核心板电路原理图

在这里插入图片描述
在这里插入图片描述
通过分析,发现led1接的三极管的基极最终连接在SOC(stm32mp157aaa)的PE10管脚。

133.3 LED1工作原理分析

133.3.1 LED1工作原理

在这里插入图片描述

根据电路原理图分析,想要让LED1亮,只需要有电流流经发光二极管即可,需要形成闭合回路,
即需要三极管的集电极和发射极导通,这里需要三极管基极控制。

133.3.2 三极管分析

在这里插入图片描述

  • 三极管一般有两种应用场景:
    1.可以在电路里设计放大电路
    2.可以充当开关
    三极管分为NPN和PNP
    NPN:当基极有一个高电平的输入时,集电极和发射极导通当基极有一个低电平的输入时,集电极和发射极截止
    PNP:当基极有一个高电平的输入时,集电极和发射极截止当基极有一个低电平的输入时,集电极和发射极导通所以在LED1电路中,只需要三极管的基极有一个高电平的输入,集电极和发射极就能导通,电流就能够顺利流经发光二极管,发光二极管就能正常工作而三极管的基极接在SOC的PE10管脚,所以只要PE10管脚输出高电平,LED1就可以亮
    

133.4 软件编程控制硬件原理

133.4.1 SOC对于GPIO控制的工作框图

在这里插入图片描述

133.4.2 软件编程控制硬件的原理

在芯片的生产厂商生产出芯片之后,会在内存空间中固化一段内存,这段内存占用了0-4G的内存寻址空间,对于这段内存中有一段内存专门用于进行硬件外设的控制,想要让外设进行工作,只需要向外设对应的这片内存中写0或者写1即可。这段空间是是属于外设的特殊功能寄存器组织

  • 软件编程控制硬件的思想:
    通过编程操作特殊功能寄存器,向特殊功能寄存器中写入特定的数据,就可以间接控制外设进行工作
    
  • 通用寄存器(R0-R15 CPSR)
    1.存在于CPU内部
    2.cpu想要读写数据,不需要寻址,只需要基于寄存器编号操作即可
    3.由ARM公司设计
    
  • 特殊功能寄存器:
    1.存在于SOC内部(内存中)
    2.操作这些寄存器需要使用内存读写指令,也需要这些内存的地址
    3.特殊功能寄存器由芯片厂商来实现
    4.特殊功能寄存器负责完成外设功能的实现
    

在这里插入图片描述

133.5 GPIO相关数据手册分析

133.5.1 GPIO章节

  • GPIO功能描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  • GPIO输出功能框图分析
    GPIO输出可以通过,两种模式实现

    • 推挽输出
    • 开漏输出+上拉/下拉电阻
  • mos管特性介绍
    在这里插入图片描述

    • 推挽输出
      由两个互补的mos管相互配合完成高低电平的输出,推挽输出既可以输出高电平,也可以输出低电平
      在这里插入图片描述
    • 开漏输出
      在输出框图种只有一个Nmos管起作用,所以只能输出低电平,想要输出高电平必须外接上拉电阻
      或者
      在输出框图种只有一个Pmos管起作用,所以只能输出高电平,想要输出低电平必须外接下拉电阻
      在这里插入图片描述
  • GPIO相关寄存器介绍
    在这里插入图片描述

    • GPIOX_MODER寄存器
      GPIO模式选择寄存器,一组GPIO有16个管脚,这个寄存器两位管理一个管脚功能
      在这里插入图片描述
    • GPIOx_OTYPER
      用于设置GPIO的输出方式

    在这里插入图片描述

    • GPIOx_OSPEEDR
      用于设置GPIO端口的输出速度
      在这里插入图片描述
    • GPIOx_PUPDR
      设置上拉下拉电阻
      在这里插入图片描述
    • GPIOx_ODR
      GPIO数据输出寄存器
      在这里插入图片描述
    • GPIOx_BSRR
      管脚置位/复位寄存器
      在这里插入图片描述
      在这里插入图片描述
    • GPIOX_BRR
      在这里插入图片描述
  • GPIOE基地址的确定
    在这里插入图片描述

    GPIOE_MODER->0X50006000
    GPIOE_OTYPER->0X50006004
    GPIOE_OSPEEDR->0X50006008
    GPIOE_PUPDR->0X5000600C
    GPIOE_ODR->0X50006014
    

133.5.2 RCC章节

在这里插入图片描述

后面就根据这些编写汇编代码了

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

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

相关文章

【JUC】三、集合的线程安全

文章目录 1、ArrayList集合线程安全问题分析2、解决方式一:Vector或synchronizedList( )3、解决方式二:CopyOnWriteArrayList 写时复制4、HashSet集合线程不安全的分析与解决5、HashMap集合线程不安全的分析与解决 1、ArrayList集合线程安全问题分析 对…

el-table实现单选和隐藏全选框和回显数据

0 效果 1 单选 <el-table ref"clientTableRef" selection-change"clientChangeHandle"><el-table-column fixed type"selection" width"50" align"center" /><el-table-column label"客户名称" a…

使用GPT-4训练数据微调GPT-3.5 RAG管道

原文&#xff1a;使用GPT-4训练数据微调GPT-3.5 RAG管道 - 知乎 OpenAI在2023年8月22日宣布&#xff0c;现在可以对GPT-3.5 Turbo进行微调了。也就是说&#xff0c;我们可以自定义自己的模型了。然后LlamaIndex就发布了0.8.7版本&#xff0c;集成了微调OpenAI gpt-3.5 turbo的…

c语言:解决谁是凶手的问题。

题目&#xff1a; 思路&#xff0b;代码&#xff1a; #define _CRT_SECURE_NO_WARNINGS //假设全部人说的话都为真&#xff0c;那结果就为4&#xff0c;现在已知三真一假&#xff0c;且说假话的人为凶手 // 现在将全部情况相加&#xff0c;满足三真一假的情况即为凶手。 #incl…

数据结构-二叉树的前、中、后序遍历

目录 1. 二叉树的遍历 1.1 前序 1.2 中序 1.3 后序 1.4 遍历的复杂度 2.二叉树节点个数及高度的计算 2.1 二叉树节点个数 2.2 二叉树叶子节点的个数 2.3 二叉树高度 2.4 二叉树第k层节点个数 1. 二叉树的遍历 前面的章节中&#xff0c;我们学习了二叉树的顺序结构&am…

LeetCode18-四数之和

注意!其中nums数值的范围,四个加一起会导致INT溢出,long类型则是64位的整数,因此不会导致溢出,这也是本题难点之一! 大佬解法(拿捏offer的解法) 经过反复的代码比对和Debug,发现大佬解法的速度之快体现在足足7个if语句的剪枝,其中包括了2个关键性的去重的if语句以及2个关键性…

SpringCloudalibaba2

一、nacos简介 Nacos&#xff08;全称为"Nano Service"&#xff09;是一个用于动态服务发现、配置管理和服务元数据的开源平台。它由阿里巴巴集团于2018年开源&#xff0c;并逐渐成为云原生应用中的重要组件之一。 Nacos提供了以下主要功能&#xff1a; 1. 服务发…

ctf之流量分析学习

链接&#xff1a;https://pan.baidu.com/s/1e3ZcfioIOmebbUs-xGRnUA?pwd9jmc 提取码&#xff1a;9jmc 前几道比较简单&#xff0c;是经常见、常考到的类型 1.pcap——zip里 流量分析里有压缩包 查字符串或者正则表达式&#xff0c;在包的最底层找到flag的相关内容 我们追踪…

Flutter笔记:关于Flutter中的大文件上传(上)

Flutter笔记 关于Flutter中的大文件上传&#xff08;上&#xff09; 大文件上传背景与 Flutter 端实现文件分片传输 作者&#xff1a;李俊才 &#xff08;jcLee95&#xff09;&#xff1a;https://blog.csdn.net/qq_28550263 邮箱 &#xff1a;291148484163.com 本文地址&#…

Go利用反射实现一个ini文件的解析器程序

package mainimport ("bufio" // 逐行读取配置文件"fmt""log""os""reflect""strconv""strings" )type Config struct { // 定义配置结构体Section1 Section1 ini:"section1" // 嵌套结构体1…

【milkv】1、光感bh1750驱动添加及测试

前言 本章介绍在milkv-duo开发板上添加光感bh1750&#xff0c;并实现应用层测试。 一、电路图查看 1.1 duo开发板i2c引脚 https://github.com/milkv-duo/duo-files 这些都是可以作为i2c使用的引脚 注意&#xff1a;电路图中的gpio0、1对应的是芯片上的gpio28、29&#…

基于springboot的教学在线作业管理系统(源码+调试)

项目描述 临近学期结束&#xff0c;还是毕业设计&#xff0c;你还在做java程序网络编程&#xff0c;期末作业&#xff0c;老师的作业要求觉得大了吗?不知道毕业设计该怎么办?网页功能的数量是否太多?没有合适的类型或系统?等等。你想解决的问题&#xff0c;今天给大家介绍…