ARM架构—— IMX6ULL芯片

一、LED点灯相关寄存器配置

IMX6ULL 的 GPIO 属于 IOMUXC(输入输出复用控制器)和 GPIO 模块共同管理,点灯本质是将指定引脚配置为 GPIO 输出模式,并控制其高低电平。核心分为两大步骤:引脚复用配置GPIO 功能配置

1.IOMUXC 模块寄存器(引脚复用 / 电气属性配置)

寄存器类型 作用
IOMUXC_SW_MUX_CTL_PAD_XXX 引脚复用选择(MUX 寄存器):设置引脚功能为 GPIO
IOMUXC_SW_PAD_CTL_PAD_XXX 引脚电气属性配置(PAD 寄存器):设置上下拉、驱动能力、速率、摆率等

2.GPIO模块寄存器

寄存器名称 地址偏移 作用
GPIOx_GDIR 0x00 方向寄存器:配置 GPIO 为输入(0)或输出(1)
GPIOx_DR 0x04 数据寄存器:写 1/0 控制输出高 / 低电平;读可获取输入电平

3.CCM时钟寄存器

寄存器名称 地址偏移 核心作用
CCM_CCGR0 ~ CCM_CCGR6 0x60 ~ 0x78 时钟门控寄存器(最核心):控制各外设时钟的开启 / 关闭

二、.ELF文件格式

段名 中文名称 权限 存储数据类型
.text 代码段 只读、可执行 程序的可执行指令(函数、main、汇编指令、分支 / 跳转指令等)
.data 数据段 可读、可写 已初始化的全局 / 静态变量(非 0 值)
.bss 未初始化数据段 可读、可写 未初始化/初始化为0的全局/静态变量
.rodata 只读数据段 只读 常量数据(字符串常量、const 修饰的全局变量、宏定义常量等)
.stack 栈段 可读、可写 函数调用栈(局部变量、函数参数、返回地址、栈帧指针等)
.heap 堆栈 可读、可写 动态内存分配区域(malloc/free、kmalloc/kfree 申请的内存)

三、链接脚本的作用

编译器编译出的目标文件(.o)只是零散的段,不知道自己该放在内存 / Flash 的哪个地址。链接脚本,解决两个核心问题:

1.地址映射:把 ELF 的逻辑段(.text/.data 等)绑定到物理存储地址;

2.内存布局:定义程序在存储介质(Flash/RAM)中的分布规则。

相关推荐
AI服务老曹13 小时前
架构实战:如何基于 GB28181 与异构计算构建跨平台(X86/ARM)AI 视频管理系统?源码交付深度解析
arm开发·人工智能·架构
CinzWS1 天前
A53 FPGA原型验证:从RTL到可运行系统的挑战
arm开发·嵌入式·芯片验证·原型验证·a53
AI服务老曹1 天前
深度解析:支持 GB28181/RTSP 及异构计算(X86/ARM+GPU/NPU)的 AI 视频管理平台架构方案(附源码交付与 Docker 部署)
arm开发·人工智能·音视频
2302_813806221 天前
基础环境篇 – 交叉编译环境搭建与NFS服务配置
arm开发
极创信息1 天前
信创领域五种主流CPU架构(X86 / ARM / RISC-V / MIPS / LoongArch)
java·arm开发·数据库·spring boot·mysql·软件工程·risc-v
AI服务老曹2 天前
节省95%开发成本:支持X86/ARM与GPU/NPU异构部署的AI视频云网关架构深度解析
arm开发·人工智能·音视频
徐某人..2 天前
基于i.MX6ULL平台的智能网关系统开发
arm开发·c++·单片机·qt·物联网·学习·arm
2035去旅行2 天前
嵌入式开发,如何选择C标准库
linux·arm开发
进击的小头2 天前
20_第20篇:嵌入式外设驱动开发基础:寄存器级开发与库函数开发对比实战
arm开发·驱动开发·单片机
AI服务老曹2 天前
架构实战:如何构建支持X86/ARM及异构GPU/NPU的跨平台企业级AI视频管理系统?
arm开发·人工智能·架构