当前位置: 首页 > article >正文

回顾一下WPF原生实现命令

抑嘲仁俾概述在复杂的嵌入式世界中程序代码和数据往往分散存储在多种不同的内存芯片里例如Flash、SRAM、外部SDRAM等。分散加载Scatter-Loading文件就像一张精准的“内存地图”告诉链接器Linker程序存储在哪里加载地址LR 你的代码、常量、变量的初始值应该被烧录到哪里通常是Flash。程序在哪里运行执行地址ER 哪些代码和数据将在CPU运行时被访问和使用通常是RAM或支持 XIP 的Flash。理解这个文件你就能完全掌握你的程序在芯片中是如何“安家落户”的。分散加载文件分散加载文件定义了三个核心层次它们回答了三个问题加载区域 (Load Region, LR) 程序“存储”在哪里 — 对应非易失性存储器Flash、ROM。执行区域 (Execution Region, ER) 程序“运行”在哪里 — 对应CPU实际读写的内存位置RAM或支持XIP的Flash。输入段 (Input Section) 程序“由什么组成” — 对应你的目标文件 (*.o) 中的代码段 (RO)、数据段 (RW)、未初始化段 (ZI)。分散加载文件的语法用 Backus-Naur FormBNF语言描述如下load_region_name start_address | offset [attributes] [max_size]{execution_region_name start_address | offset [attributes][max_size]{module_select_pattern [(( input_section_attr | input_section_pattern)([,] input_section_attr | , input_section_pattern)) *)]}}将这些翻译成白话文就是定义一个加载区域 必须指定一个名称和地址绝对地址start\_address或者相对偏移offset。可以可选地指定[attributes]和[max\_size]。定义一个执行区域必须指定一个名称和地址绝对地址start\_address或者 相对偏移offset。可选地指定[attributes]和[max\_size]。选择输入段必须指定一个模块选择模式例如*.o。可选地使用第一组段可以是按属性 input\_section\_attr或者 按名称input\_section\_pattern。- 然后可以重复零次或多次(*)第二组段的选择以可选的逗号[,]开头然后选择属性 input\_section\_attr或者 名称input\_section\_pattern。下面是一个简单的分散加载文件的例子。LR_ROM 0x08000000 0x00020000 {ER_ROM 0x08000000 0x00020000 {.ANY (RO)}ER_RAM 0x20000000 0x00008000 {.ANY (RW ZI)}}在这个分散加载文件中用户首先定义了一块加载区域取名为 LR_ROM。程序映像文件烧录到这里起始地址: 0x08000000, 最大容量: 0x20000 (128 KB)。第二步用户针对这一个程序映像定义了一块执行区域取名为 ER_RAM。这块区域是执行区域它起始地址和最大容量分别都为 0x08000000 和 0x20000 (128 KB)。只读代码和常量. ANY (RO)在这里存放或执行。第三步用户针对同一个程序映像还定义了一块执行区域取名为 ER_RAM。读写变量 (复制) 和未初始化变量 .ANY (RW ZI) 都在初始化的时候从加载区域被搬到了这块执行区域具体的搬运过程不在本文的讨论范围之内。存储器介质现在你已经知道分散加载文件的基本语法了但是你还需要了解嵌入式系统中不同存储介质的特性。一般来说你的程序代码和初始数据烧录在 Flash (ROM) 里但你的程序在运行时所有的变化数据变量、堆栈必须在RAM里进行读写。下表是嵌入式系统中常用介质的机制和加载/执行的机制。方案 / 介质 存储特性 执行特性 采用的加载/执行机制 关键设计考量内置 Flash (MCU) 非易失容量有限 速度较快支持XIPXIP (Execute-in-Place) 分散加载 (.data复制到SRAM) 启动快功耗低但总容量受限。内置 SRAM (MCU/MPU) 易失容量有限 速度极快 分散加载目标 (用于.data,.bss,Stack,Heap) 存储关键高速数据和代码。外部 DRAM/SDRAM 易失容量大 速度中等可作为主内存 复杂分散加载 或 OS 动态加载 容量需求需要外部总线和内存控制器引入延迟。TCM 易失容量极小 速度最快 (零等待) 分散加载目标 (用于中断代码和关键算法) 用于保障实时性Real-Time和性能关键任务。外置 QSPI/NOR Flash 非易失容量大 有限XIPXIP或 Bootloader 复制 (到 DRAM) 性能依赖QSPI接口速度和内部缓存。代码覆盖OverlayN/A (软件机制) N/A (软件机制) 动态加载/覆盖 克服 RAM 容量限制但会牺牲性能。存储器介质上的映像加载下面介绍一些不同的存储器介质上程序映像加载和执行的方案。模式一纯 RAM 加载模式需求/问题我正在开发一个桌面操作系统的引导程序Bootloader或者一个纯粹用于调试的全RAM运行环境。程序需要快速加载并且不依赖任何Flash存储。我怎样才能让程序的所有部分代码和数据都在RAM中连续运行这种模式适用于将程序加载到 RAM例如操作系统引导加载程序或桌面系统的系统。下图由单个加载区域和三个执行区域组成RO/RW/ZI 在 RAM 中连续存放无需运行时复制。模式二单 ROM 单 RAM 单应用程序需求/问题我使用的是典型的 Cortex-M 系列单片机我如何实现这个最基本的嵌入式系统启动流程这是基于ROM的嵌入式系统中最常见的配置。 Cortex-M 系列芯片采用是内置Flash(如128KB到2MB) 和内置SRAM(32KB到512KB)。程序利用Flash的 XIP (Execute-in-Place) 特性直接在Flash中运行代码RO部分。读写数据RW 初始值存储在Flash中程序启动时C运行时库 (__main) 会将这部分数据从Flash复制到RAM。未初始化数据ZI在RAM中被清零或分配。如下图LR_IROM1 0x08000000 0x00010000 { ; 加载区域64KB Flash (存储程序)ER_IROM1 0x08000000 0x00010000 { ; 执行区域Flash (XIP运行)*.o (RESET, First) ; 选中所有目标文件中的 RESET 段并使用 First 属性强制它作为 ER 中的第一个段。*(InRoot$$Sections) ; 选中所有目标文件中的 C 运行时启动段。这一段必须在 Flash 中执行负责 RW复制和 ZI 清零。.ANY (RO) ; 选中其余所有的只读代码和常量链接器会将其放在前面两个关键段之后。 **目的** 确保 CPU 能够正确启动并保证 C 环境正确初始化。.ANY (XO) ; 所有仅执行代码}RW_IRAM1 0x20000000 0x00005000 { ; 执行区域20KB RAM (数据读写).ANY (RW ZI) ; 读写变量(复制) 和 未初始化变量(清零)}}注RESET, First硬件复位后CPU 会固定从 Flash 首地址读取栈指针 (MSP) 和复位入口 (Reset Handler)。First 强制链接器把向量表放在这防止被其他代码占位导致无法启动。InRoot$$Sections这是 C 语言运行时的根代码包括数据复制算法。它必须放在根区域Flash中否则 CPU 还没来得及把数据复制到 RAM就尝试去 RAM 执行代码会导致崩溃。模式三单 ROM 单 RAM 多应用程序 (Bootloader App)需求/问题我的产品需要支持 OTA远程升级 和多分区启动。我需要在 Flash 中划分出一个不可变的 Bootloader 区域以及一个可擦除更新的 应用程序 (App) 区域。这两个程序如何安全地共享 RAM 并在不同 Flash 地址运行采用双映像策略。Bootloader位于Flash起始地址 (0x08000000)App位于Flash的偏移地址 (0x08010000)。由于它们分时运行可以复用同一块RAM空间。App 启动时必须修改向量表偏移寄存器 (VTOR)指向 App 在 Flash 中的新起始地址。这里需要为 Bootloader 和 APP 编写两个独立的 .sct 文件。1. Bootloader 的 SCT:LR_BOOT 0x08000000 0x10000 { ; Bootloader 占用前 64KB FlashER_BOOT 0x08000000 0x10000 {*.o (RESET, First) ; 物理复位入口*(InRoot$$Sections).ANY (RO)}RW_BOOT 0x20000000 0x8000 { ; 使用 RAM.ANY (RW ZI)}}2. Application 的 SCT:; 注意加载地址偏移到了 0x08010000LR_APP 0x08010000 0x40000 {ER_APP 0x08010000 0x40000 {*.o (RESET, First) ; App 的向量表放在 App 区域的开头*(InRoot$$Sections).ANY (RO)}RW_APP 0x20000000 0x8000 { ; 复用相同的 RAM 地址 (因为 Boot 已停止运行).ANY (RW ZI)}}模式四多 Flash 区域配置需求/问题内置Flash容量不足。我如何将体积庞大的只读资源图片、字库放在外部Flash(0x60000000)同时核心代码仍在内置Flash运行采用混合模式将核心代码、中断向量表和对实时性要求极高的算法放置在速度最快的 内置 Flash 中运行而将体积庞大的图片、字库等资源放置在 外置 Flash 中。根据外置 Flash 的特性这些资源可以通过 XIP 直接读取或者在需要时加载到外部 SDRAM 中。; 主Flash区域 - 应用程序代码LR_MAIN_FLASH 0x08000000 0x00080000 {ER_VECTOR 0x08000000 0x400 {*.o (RESET, First) ; 中断向量表}ER_CODE 0x08000400 (0x80000-0x400) {*(InRoot$$Sections).ANY (RO).ANY (XO)}}; 外部Flash区域 - 资源数据LR_EXT_FLASH 0x60000000 0x00400000 {ER_RESOURCES 0x60000000 0x400000 {resources.o (RO) ; 专门的资源文件fonts.o (RO)images.o (RO)}}; 内部RAMLR_RAM 0x20000000 0x00020000 {RW_DATA 0x20000000 0x1F000 {.ANY (RW ZI)}; 预留栈空间ARM_LIB_STACK 0x2001F000 EMPTY 0x1000 {}}模式五多 RAM 区域配置需求/问题我需要利用MCU内建的多种RAM速度优势将实时性要求高的DMA缓冲区放到最快的CCMRAM中并将大型GUI缓冲区分配到外部SDRAM。LR_IROM1 0x08000000 0x00080000 {ER_IROM1 0x08000000 0x00080000 {*.o (RESET, First)*(InRoot$$Sections).ANY (RO).ANY (XO)}; 主RAM - 一般数据RW_IRAM1 0x20000000 0x00010000 {.ANY (RW ZI)}; 快速RAM - 关键变量RW_FAST_RAM 0x10000000 0x00004000 {fast_data.o (RW ZI) ; 指定快速访问的数据dma_buffers.o (RW ZI) ; DMA缓冲区}; 外部RAM - 大数据缓冲RW_EXT_RAM 0x60000000 0x00800000 {large_buffers.o (RW ZI)heap.o (RW ZI)}}模式六代码覆盖 (Code Overlay)需求/问题我的RAM空间非常有限但程序功能模块很多。我需要让几个不常用的模块A和B共享同一块RAM空间在需要时才将它们加载进来。当 RAM 资源有限时可以使用代码覆盖技术。使用OVERLAY属性。模块A和B在Flash中拥有独立的加载位置但它们被映射到RAM中的相同执行地址 (0x20008000)。运行时程序需要手动将所需的模块从Flash复制到这个共享的RAM区域中运行。LR_FLASH 0x08000000 0x00080000 {ER_CODE 0x08000000 0x00080000 {*.o (RESET, First)*(InRoot$$Sections)main.o (RO) ; 主程序始终在Flash中}}LR_RAM 0x20000000 0x00010000 {; 覆盖区域1OVERLAY_1 0x20008000 OVERLAY 0x2000 {module_a.o (RW ZI RO) ; 模块A的代码和数据}; 覆盖区域2 - 与区域1共享相同地址空间OVERLAY_2 0x20008000 OVERLAY 0x2000 {module_b.o (RW ZI RO) ; 模块B的代码和数据}; 通用RAM区域RW_DATA 0x20000000 0x8000 {.ANY (RW ZI)}}

相关文章:

回顾一下WPF原生实现命令

抑嘲仁俾概述 在复杂的嵌入式世界中,程序代码和数据往往分散存储在多种不同的内存芯片里(例如 Flash 、 SRAM 、外部 SDRAM等)。分散加载(Scatter-Loading)文件,就像一张精准的“内存地图”,告…...

想用 Claude Code 做 AI 编程,很多人其实卡在了接入这一步

这两年,很多开发者已经不是在问“AI 编程值不值得用”,而是在问: 怎么才能尽快把它接进自己的开发流程里。 尤其是像 Claude Code 这类终端型 AI 编程工具,对会写代码的人来说吸引力很直接:不用切网页,不用…...

论生成式AI从“工具逻辑”向“精神秩序”的过渡!

生成式AI从“工具逻辑”向“精神秩序”的过渡,标志着其社会角色正发生本质性转变——从被动响应的“效率机器”,逐渐演变为主动参与、甚至重构人类认知、情感与价值系统的“精神性存在”。这一过渡是技术、社会与文化复杂互动的结果,可从以下…...

基于python的网络生鲜超市购物管理系统的设计与实现

前言 网络生鲜超市购物系统是一个集在线购买、支付、订单管理、会员服务等功能于一体的综合性电子商务平台。该系统旨在为广大用户提供便捷、高效的购书体验,同时帮助生鲜超市拓宽销售渠道,提升品牌影响力。 采用当前流行的B/S模式以及3层架构的设计思想…...

鸿蒙常见问题分析三十二:Column子组件超出容器边界

上周末,我正为一个新的HarmonyOS应用页面布局挠头。设计稿上是一个精美的信息卡片,外层Column容器设置了固定的宽高和圆角背景,里面嵌套了一个显示标题的Row。我按照设计实现了边框、内边距,一切看起来都很完美——直到我给内部的…...

STM32报错日志(1)_FreeRTOS-01

问题:使用STM32CubeMX在STM32F103C8T6上配置FreeRTOS时,编译出现文件名之类的报错原因:ST官方更新时兼容出现问题,不兼容最新的固件包解决办法:在STM32CubeMX中将固件包改成V1.8.5...

Flutter 三方库 square_connect 的鸿蒙化适配指南 - 让全球支付触手可及,打造鸿蒙应用专家级的支付中台

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.csdn.net Flutter 三方库 square_connect 的鸿蒙化适配指南 - 让全球支付触手可及,打造鸿蒙应用专家级的支付中台 前言 在鸿蒙(OpenHarmony)应用进军全球化电商与…...

Flutter 三方库 argos_translator_offline 的鸿蒙化适配指南 - 让机器翻译回归“端侧隔离”,打造鸿蒙应用专家级的离线多语言 AI 治理中台

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.csdn.net Flutter 三方库 argos_translator_offline 的鸿蒙化适配指南 - 让机器翻译回归“端侧隔离”,打造鸿蒙应用专家级的离线多语言 AI 治理中台 前言 在鸿蒙(OpenHarmon…...

分⽀和循环:C语言的脊柱

序言 在C语言中,分支(条件判断)和循环(重复执行)是程序逻辑的核心,二者共同构成了代码的“脊柱”,决定了程序的执行流程。我们可以使⽤ if 、 switch 实现分⽀结构,使⽤ for 、 whi…...

Linux 系统中,uv 是一款由 Rust 编写的超高速 Python 包管理与虚拟环境工具

在 Linux 系统中,uv 是一款由 Rust 编写的超高速 Python 包管理与虚拟环境工具,旨在替代传统的 pip、virtualenv 等工具,号称能带来 10-100 倍的性能提升。 🔧 核心功能与常用命令场景命令说明安装curl -LsSf https://astral.sh/u…...

大数据领域Spark的集群网络优化

大数据领域Spark的集群网络优化关键词:大数据、Spark、集群网络、网络优化、性能提升摘要:本文聚焦于大数据领域中Spark集群网络的优化问题。在大数据处理场景下,Spark作为主流的分布式计算框架,其集群网络性能对整体计算效率有着…...

SAP UI5中DOMParser解析XML关键步骤

SAP UI5框架中基于DOMParser的XML数据解析机制涉及多个关键环节&#xff0c;这些步骤共同构成了元数据解析的核心流程。根据技术文档分析&#xff0c;其关键实现步骤如下&#xff1a; 1. 解析器实例化与初始化 var xmlParse function (text) {/// <summary>Returns an…...

2026软考资料,看这一份就够了

2026年软考5月战役即将打响&#xff0c;备考黄金期已至&#xff01;我将近年备考中精心筛选、整理的各科目资料&#xff08;均整理自互联网公开资源&#xff09;无偿开放分享&#xff0c;希望能为各位考友助一臂之力&#xff0c;一起冲刺通关&#xff01;&#x1f4da; 目前资料…...

面试官:MCP 与 Skills 有什么区别?

1️⃣面向对象不同 MCP 是大模型与外部世界的标准化连接协议&#xff0c;负责打通边界&#xff0c;让大模型能安全、统一地调用外部工具。 Skills 是行为规范层&#xff0c;是面向 Cursor 等 AI 编程工具的模块化、可复用能力封装机制。核心是把标准作业流程固化成可复用的技…...

RAG检索瓶颈突破实战指南(非常详细),Multi-HyDE与Adaptive HyDE从入门到精通,收藏这一篇就够了!

在检索增强生成&#xff08;RAG&#xff09;系统中&#xff0c;检索准确性是决定最终生成效果的关键瓶颈。传统的稠密检索往往受限于查询与文档之间的语义鸿沟&#xff08;Semantic Gap&#xff09;。为了解决这一问题&#xff0c;Hypothetical Document Embeddings&#xff08…...

大模型百万Token长上下文训练教程(非常详细),上下文并行与Ring Attention从入门到精通,收藏这一篇就够了!

只用了几年时间&#xff0c;上下文窗口就从 4k 膨胀到 1000 万。Meta 发布的 Llama 4 Scout 的时候说这个模型支持 1000 万 Token&#xff0c;是 Llama 3 那 128k 的 78 倍。而Google Gemini 3 Pro 是 100 万&#xff0c;Claude 4 也桐乡市100万。 一次推理跑完整个代码库、几…...

大模型+知识图谱行业落地(非常详细),民航维修检索生成从入门到精通,收藏这一篇就够了!

摘要&#xff1a;本研究创新性地融合大语言模型、知识图谱技术及重排序方法&#xff0c;旨在以低成本、高质量实现民航维修历史方案检索与推荐方案生成&#xff0c;优化维修决策&#xff0c;提升维修效率与质量。研究利用大模型的分析推理能力&#xff0c;借助定制化知识图谱检…...

专用业务信息平台(SBISP)(之三)--SMP(软件制作平台)语言基础知识之八十

专用业务信息平台&#xff08;SBISP&#xff09;&#xff08;之一&#xff09;--SMP&#xff08;软件制作平台&#xff09;语言基础知识之八十 专用业务信息平台&#xff08;SBISP&#xff09;&#xff08;之二&#xff09;--SMP&#xff08;软件制作平台&#xff09;语言基础…...

在AIStudio星河社区配置OpenClaw小龙虾

很多人都在热捧小龙虾OpenClaw 很多人都在使用小龙虾 很多人被小龙虾拔掉了底裤..... 所以小龙虾还是不能在自己的工作机器上安装&#xff0c;最好是用一台云端机器&#xff0c;万一出了安全问题&#xff0c;损失能小一点。 尝试在AIStudio星河社区配置OpenClaw小龙虾 参考…...

C语言之数据结构初见篇(2):顺序表之通讯录的实现

目录 一、基本概念 二、通俗理解 三、这个程序是什么 1. 数据结构 2. 核心功能 四、通讯录代码的实现 1.多个文件的创建 一、基本概念 顺序表实现的通讯录是一种基于数组结构的联系人信息管理系统。它将数据结构的理论知识&#xff08;顺序表&#xff09;应用到实际场景…...

2026年软著申请被驳回的五大高频原因深度解析

随着软件开发工具的迭代升级&#xff0c;2026年的软件著作权登记审查工作也进入了精细化阶段。很多开发者与企业往往认为只要提交了材料就能顺利拿证&#xff0c;却忽视了审查中心对“独创性”与“一致性”的严格把控。近期&#xff0c;因代码雷同、文档逻辑断裂等问题导致的驳…...

Winform基于PaddleOCR图片文字提取方法

1.目的掌握Winform下基于Sdcb. PaddleOCR和OpenCvSharp实现图片文字的提取方法。⒉编程软件Visual Studio 2022⒊界面设计如下图设计了UI界面&#xff0c;包括使用Button、PictureBox和RichTextBox控件&#xff1a;本案例以下图特定图片为案例进行文字提取&#xff1a;⒋代码简…...

问题记录,JMeter运行一次有时候显示两次请求?

当使用http协议访问www.itcast.com时&#xff0c;结果树中有两次请求当使用https协议访问www.itcast.com时&#xff0c;结果树中有一次请求核心表现&#xff1a;在JMeter中创建单个HTTP请求&#xff08;如配置http://xxx.com&#xff09;&#xff0c;点击“运行”按钮后&#x…...

SLAM算法(ROS入门)

SLAM 建图 ​ 机器人研究的问题包含许许多多的领域&#xff0c;我们常见的几个研究的问题包括&#xff1a;建图(Mapping)、定位(Localization)和路径规划&#xff08;Path Planning&#xff09;&#xff0c;如果机器人带有机械臂&#xff0c;那么运动规划&#xff08;Motion P…...

[Java EE 进阶] 一文吃透 Spring IoCDI:核心概念 + 实战用法 + 面试考点(上篇)

一.IOC&DI 介绍1. 传统程序开发 的问题 : 高耦合以 “造一辆车” 为例&#xff0c;传统开发中对象的创建和依赖关系由自身控制&#xff1a;汽⻋依赖⻋⾝&#xff0c;⻋⾝依赖底盘&#xff0c;底盘依赖轮 ;所有的对象都通过 new 手动创建 ; 当底层组件(如轮胎尺寸) 发生变化…...

计网相关协议3

DNS查询&#xff1a;查找域名对应IP&#xff08;先浏览器缓存、本地hosts、路由器缓存&#xff0c;再递归/迭代DNS服务器查询&#xff09;。...

2026年知网AIGC检测算法又升级了,降AI方法得跟着变

2026年知网AIGC检测算法又升级了&#xff0c;降AI方法得跟着变 知网在2025年底对AIGC检测系统做了一次大升级。如果你还在用去年的降AI方法&#xff0c;大概率过不了了。这篇说说升级了哪些地方&#xff0c;现在该怎么应对。 这次升级改了什么 根据最近的实测数据和公开信息…...

FLV 流解剖学:e-flv 如何用 Go 构建轻量级诊断工具

FLV 流解剖学&#xff1a;e-flv 如何用 Go 构建轻量级诊断工具 项目仓库&#xff1a;https://github.com/veovera/enhanced-rtmp 文档来源&#xff1a;GitHub Discussion #50 版本&#xff1a;早期实验版&#xff08;WIP&#xff09; &#x1f4cc; 项目概述 e-flv 是 Enhance…...

第3篇:Spring Boot + WebSocket + 消息队列STOMP协议发布订阅模式 实现多频道实时消息广播

基于发布&#xff0c;订阅&#xff0c;主题 模式&#xff0c;实现原理图前提&#xff1a;环境已经搭建好&#xff0c;具体看第二篇1 maven依赖&#xff0c;springboot 版本 3.3.1<!-- 核心包 --><dependency><groupId>org.springframework.boot</groupId…...

性能监控之 blackbox_exporter+Prometheus+Grafana 实现网络探测

文章目录一、什么是黑盒监控&#xff1f;二、blackbox_exporter 简介三、安装1、二进制包2、docker四、使用原理五、几种应用场景1、ICMP 测试&#xff08;主机探活&#xff09;2、TCP 测试&#xff08;监控主机端口存活状态&#xff09;3、HTTP检测&#xff08;监控网站状态&a…...