武汉理工大学嵌入式系统应用之临时抱佛脚复习

news2025/1/16 5:43:46

其实大学很多课程的期末冲刺复习非常简单,就是在大脑中构建一个redis数据库就行了,缓存下一大堆键值对,然后考试的时候输出,很没意思。

嵌入式系统的定义

应用为中心,以计算机技术为基础,软件硬件可裁剪,适应应用系统对功能、可靠性、成本、体积、重量、功耗严格要求的专用计算机系统。

处理器的分类

(1)微控制器(Microcontroller Unit, MCU):推动嵌入式计算机系统走向独立发展道路的芯片,也叫单片机。

(2)嵌入式DSP(Embedded Digital Signal Processor, EDSP):在微控制器的基础上对系统结构和指令系统进行了特殊设计,使其适合执行DSP算法并提高了编译效率和指令执行速度。

(3)嵌入式微处理器(Embedded Microprocessor Unit, EMPU):为通用计算机的微处理器演变而来,芯片内部没有存储器,IO电路也很少。去除了多余的功能部件,只保留与嵌入式应用紧密相关的功能部件,保证以最低的资源和功耗实现嵌入式的应用需求。

(4)嵌入式片上系统(System on a Chip, Soc):是ASIC设计方法学中产生的一种新技术,是以嵌入式系统为核心,以IP复用技术为基础,集软件、硬件与一体,并追求产品系统最大包容的集成芯片。

主流嵌入式微处理器

有以下四个特点:

(1)大量使用寄存器,对实时多任务有很强的支持功能。

(2)具有功能很强的存储区保护功能。

(3)可扩展的处理器结构。

(4)小体积,低功耗,低成本,高性能。

嵌入式系统的体系结构

在这里插入图片描述
中间层:中间层为上层软件提供了设备的操作接口,将系统软件与底层硬件的部分进行了分离,完成底层硬件的初始化、数据的输入输出操作、硬件的配置等功能。

嵌入式系统的应用举例

嵌入式系统可应用在工业控制、交通管理、信息家电、家庭智能管理系统、物联网、电子商务、环境监测和机器人等众多方面。

在这里插入图片描述
(1)嵌入式应用的开发需要更加强大的开发工具与操作系统的支持。
(2)嵌入式系统与物联网的深度融合。
(3)可穿戴设备与嵌入式系统的密切结合。
(4)更加友好的UI设计。

嵌入式操作系统举例

嵌入式Linux:

(1)RT-Linux(Real-Time Linux):是美国墨西哥理工学院开发的嵌入式Linux操作系统,具有很好的实时性,广泛应用在航空航天、科学仪器、图像处理等众多领域。

(2)μ-Linux:一个代码紧凑,高度优化的嵌入式Linux。

(3)红旗嵌入式Linux:国内做的比较好的一款嵌入式操作系统,重点支持p-Java。

WindowsCE,Symbian,Android都是嵌入式操作系统。

ARM简介

全称 Advanced RISC Machines,其特点有:

(1)体积小、功耗低、成本低、性能高。
(2)支持Thumb(16位)/ARM(32位)双指令集,具有很好的兼容性。
(3)大量使用寄存器,指令执行速度更快。
(4)大多数数据操作都在寄存器中完成。
(5)寻址方式简单灵活,执行效率高。
(6)指令长度固定。

ARM7采用普林斯顿(冯诺依曼)结构,ARM9及以后采用哈佛结构。

在这里插入图片描述
哈佛结构通过将程序指令存储和数据存储分开,采用独立编址和独立访问的方式,提高了数据吞吐量和执行效率。

ARM7采用三级流水线技术(取指、译码、执行
),ARM9及以后采用五级流水线(取指、译码、访存、回写)。

ARM9采用哈佛架构,避免了数据访问和取指令之间的总线冲突,采用更为高效的五级流水线设计。这种五级流水线技术把三级流水线中的执行单元进一步细化,减少了在每个时钟周期内必须完成的工作量,进而允许使用较高的时钟频率,解决了三级流水线中存储器访问指令在指令执行阶段的延迟问题。

Cotrex-A8处理器架构

(1)指令读取单元。
(2)指令译码单元。
(3)指令执行单元。
(4)数据存取单元。
(5)L2缓存单元。
(6)NEON媒体处理引擎。
(7)ETM单元。
(8)外部接口。

ARM处理器工作模式

一共有七种工作模式:

(1)用户模式(usr)。
(2)系统模式(sys)。
(3)快中断模式(fiq):用于高速数据传输及通道处理。
(4)外部中断模式(irq):用于通用中断处理。

(5)管理模式(svc)。
(6)数据访问中止模式(abt)。
(7)未定义模式(und)。

除了用户模式以外,都是特权模式。

除了用户模式和系统模式以外,都是异常模式。

ARM微处理器共有37个32位的寄存器,其中31个通用寄存器:PC、堆栈以及其他通用寄存器;6个状态寄存器。

R0~R7:未分组的寄存器。

R8~R14:分组寄存器。

R13:堆栈指针。

R14:链接寄存器(LR),保存子程序返回地址,发生异常时,将R14对应的异常模式版本设置为异常返回地址。

R15:程序计数器(PC)。

R16(CPSR):当前程序状态寄存器。

下图需要背下来。
在这里插入图片描述
在这里插入图片描述

big.LITTLE多核处理技术

big.LITTLE技术能够将两个不同但相互兼容的处理器结合在同一个的片上系统,并允许功耗管理软件来为每项任务选择最匹配的单个或多个处理器。

“LITTLE”,最低功耗的处理器,通过运行操作系统以及某些应用程序来实现“随时随地网络接入”的基本任务,如社交媒体和音频播放。随后,操作系统和应用程序可以迅速切换至更高性能的处理器来满足更高性能需求的任务,比如导航和游戏。

异常处理

只考复位、IRQ(外部中断模式)和FIQ(快速中断模式)。

1优先级最高,6优先级最低。

复位异常:管理模式、优先级1。

IRQ:外部中断模式、优先级4,当CPSR的I为设置为0时,产生该异常,常用于设备外设请求。

FIQ:快速中断模式,优先级3,当CPSR的F为0时,产生该异常。

大端存储和小端存储

在计算机中普遍使用大端存储,方法也很简单,数据写下来默认左边为高位,从左往右读,地址由低到高,即高位存储在低地址。

例如0x11223344,这一共是4个字节,那么假设从0x2000H开始存,那么2000H存储的就是0x11,2001H存的就是0x22。

寻址方式

寻址方式其实在计算机组成中讲的很详细,简单来说就是这么几种:

(1)寄存器直接寻址:寄存器里面直接存数据。
(2)立即寻址:直接把操作数作为指令。
(3)寄存器偏移寻址:一般就是把寄存器里面的数据左移若干位作为数据。
(4)寄存器间接寻址:寄存器存的是地址,要根据这个地址找到存储器中的数据。
(5)基址(变)寻址:寄存器中的地址,再加上一个立即数的偏移量得到有效地址。这个常用于循环,通过修改寄存器,来遍历一段连续内存。
(6)多寄存器寻址:举几个例子好了。

LDMIA R1!, {R2-R4, R6};将R1指向的单元中的数据读出到R2,R3,R4,R6中,R1自动+1
STMIA R0!, {R2-R7, R12};将寄存器R2~R7, R12的值存到R0指向的寄存器中,R0自动+1

(7)堆栈寻址:共有4种类型的堆栈,分别是FA、EA、FD、ED。F表示满,即栈顶指针指向一个存在的元素,A表示增,即指针生长方向,E表示空,D表示降。

ARM指令

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
msr:将普通寄存器中的数据写到特殊寄存器中;
mrs:将特殊寄存器中的数据写到普通寄存器中;

msr  cpsr, r0  			=== cpsr=r0
mrs  r0, cpsr  			=== r0=cpsr

C和汇编混合编程

ATPCS规定数据栈为FD类型,8字节对齐。

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

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

相关文章

VSCode调试揭秘:Live Server助力完美测试Cookie与Session,远超“Open in Browser“!

文章目录 一、项目场景:二、问题描述1. open in browser:2. open with live server 三、原因分析:先了解一下open in browser和open with live server的区别两者的优缺点open in browseropen with live server 四、解决方案:总结 …

开发网站,如何给上传图片的服务器目录授权

开发网站,上传图像时提示”上传图片失败,Impossible to create the root directory /var/www/html/xxxxx/public/uploads/avatar/20240608.“ 在Ubuntu上,你可以通过调整文件夹权限来解决这个问题。首先,确保Web服务器&#xff08…

173.二叉树:找树左下角的值(力扣)

代码解决 /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullptr) {}* TreeNode(int x) : val(x), left(nullptr, right(nullptr) {}* Tree…

数据集(图片)求均值和标准差

数据集(图片)求均值和标准差 一、环境配置 运行一下命令完成环境配置 pip install opencv-python numpy二、源代码 import os import cv2 import numpy as npdef compute_mean_std(Img_folders):all_file []for images_path in Img_folders:all_file…

攻防世界---misc---What-is-this

1、下载附件,是一个.gz的文件夹,是linux系统的压缩包后缀 2、在kali中解压,解压之后得到两张图片 3、想把图片拖在物理机中分析,但是拖不了,所以将.gz文件在物理机中改为.zip,解压之后看到了一个没有后缀的…

Java从入门到放弃

线程池的主要作用 线程池的设计主要是为了管理线程,为了让用户不需要再关系线程的创建和销毁,只需要使用线程池中的线程即可。 同时线程池的出现也为性能的提升做出了很多贡献: 降低了资源的消耗:不会频繁的创建、销毁线程&…

Windows 10 找不到Microsoft Edge 浏览器

下载链接 了解 Microsoft Edge 手动下载浏览器 问题说明 一般来说,windows10系统应该是自带浏览器edge的,但有的电脑就是没有找到edge浏览器,可能系统是精简过的,可能是被卸载了。如下,控制面板确实没找到程序。 ​ …

端午节前夕送给高考学子的祝福

据中国新闻网消息:6月7日,2024年全国高考正式拉开大幕,全国1342万考生奔赴考场。各地纷纷开启“护考”模式和“静音模式”,为考生们创造良好的学习、考试、休息环境。 明天是2024年端午节,笔者祝愿1342万考生都将获得…

生信软件22 - 测序数据5‘和3‘端reads修剪工具sickle

大多数现代测序技术产生的3 端和5 端质量降低的reads,这两个区域错误地calling base会对组装、下游生物信息学分析造成影响。sickle使用滑动窗口沿着质量和长度阈值,根据质量是否低于阈值来修剪reads的3 端, 根据质量是否超过阈值来修剪reads…

最快的开源UDP传输工具:Kcptun

Kcptun:极速网络隧道,让数据传输飞起来!- 精选真开源,释放新价值。 概览 kcptun 是一个轻量级、高性能的TCP/UDP网络加速工具,由xtaci开发并托管在GitHub上。它通过使用kcp协议,为网络数据传输提供了一个快…

Django redirect()函数实现页面重定向

1,通过路由反向解析进行重定向 1.1 添加视图函数 myshop/app2/views.py from django.http import HttpResponse from django.shortcuts import render from django.urls import reverse def index(request):return HttpResponse("app2 的index")# 反向…

QField如何打开工程或数据文件

Field有个文件选择器,允许从本地设备打开工程。如果想从云端打开文件,请参阅 QFieldCloud 。 注意:请注意,卸载QField时,应用程序文件夹将被删除,而更新则不会。 导入并打开本地工程 QField界面 当转到 …

Unity DOTS技术(十五) 物理系统

要解决性能的瓶颈问题,在DOTS中我们将不再使用Unity自带的物理组件. 下面来分享一下在DOTS中当如何使用物理插件. 一.导入插件 在使用DOTS系创建的实体我们会发现,游戏物体无法受物理系统影响进行运动.于是我们需要添加物理系统插件. 1.打开Package Manager > 搜索插件Uni…

【NI国产替代】产线综测仪,高速高精度测量的示波器模块与任意波形发生器模块,多样化 DUT 供电;高精度万用表模块

Xilinx ZYNQ-7000 系列 FPGA 控制模块多样化 DUT 供电;高精度万用表模块高速高精度测量的示波器模块与任意波形发生器模块可选配射频开关与音频信号源和音频分析仪模块可快速部署的测试平台软件,支持测试计划导入、开发、执行管理具有良好的扩展性&#…

1.2-自然语言的分布式表示-基于计数的方法

本篇笔记对应的视频链接为: 3-基于计数的方法表示单词-将文字转换成编号的预处理工作_哔哩哔哩_bilibili;4-基于计数的方法表示单词-使用共现矩阵进行单词的分布式表示_哔哩哔哩_bilibili;5-基于计数的方法表示单词-单词之间相似度计算_哔哩哔…

超详解——python数字和运算_——小白篇

目录 1.的位运算 2. 常用内置函数/模块 math模块: random模块: decimal模块: 3.内置函数: 总结: 1.的位运算 位运算是对整数在内存中的二进制表示进行操作。Python支持以下常见的位运算符: 按位与&…

openh264 场景变化检测算法源码分析

文件位置 openh264/codec/processing/scenechangedetection/SceneChangeDetection.cppopenh264/codec/processing/scenechangedetection/SceneChangeDetection.h 代码流程 说明: 通过代码流程分析,当METHOD_SCENE_CHANGE_DETECTION_SCREEN场景类型为时…

git 的基本操作 Master and branch的版本合并 @ VS 1019

前言: 在VS 2019有git 的可视化管理,但,感觉微软其实就是在git上包了一层。版本冲突后,还是要靠git 的命令行代码搞。本文记录了一次,branch和master的版本合并的过程。作为,后续的参考。 【注意,这个是一…

相机标定中一些细节--畸变模型和参数

张正友标定方法做相机标定的主要过程是先估计每张图片的单应性矩阵,然后通过这一系列的单应性矩阵估计出内外参数初值,最后再考虑畸变模型的加入进行非线性优化。同时优化内参、外参和畸变参使得重投影误差最小。 镜头的畸变表现出来的非线性关系&#…