ok6410学习笔记(1.arm常见的各种地址总结)

2023-11-10 15:10

本文主要是介绍ok6410学习笔记(1.arm常见的各种地址总结),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

         学习ok6410有一段时间了,总是对其中各中地址的来源比较模糊一会0x500080000  一会0x71000000的,最近自己又看了看手册,找了找资料,并和2440对比学习了下,总结如下。PS:资料有6410,2440中英文手册,ok6410原理图,mini2440原理图,韦东山第一期视频中的存储控制器,mmu,nandflash,和看原理图视频。

        mini2440地址映射问题:

          mini2440地址中norflash,DM9000,SRAM是跟寄存器一样的统一编址(主要与nandflash不同,nandflash是按照时序把地址发送出去的,不是地址线发送的,不是被存储器控制器操作的,是被nandflash控制器控制的,所以与他们不同)。

          如上图:如果是nor启动,norflash的起始地址是0x00000000,中间打叉的块是没有连接的,也就是无效的地址,DM9000的起始地址是从块4开始的0x20000000,SDRAM的起始地址是从块6开始的0x30000000.他们是通过nGCS0,nGCS1......起到片选的作用的(如下图)。nand启动只是把0x00000000变成了片内SRAM,把nandflash前4k拷贝过去而已。紧接着就是0x50000000开始的寄存器地址,后面还有一段映射的虚拟地址(主要跟uboot中的mmu内存管理单元初始化,和内核移植有关)。

          

          ok6410地址映射问题(资料太少大部分是我的理解,如有错误希望大神指导下):

    

         

        6410的内存映射分5个部分:

        1.引导镜像区(0x0000_0000~0x07FF_FFFF)

        2.内存存储区(0x0800_0000~0x0FFF_FFFF)如果是内部ROM启动0x0800_0000~0x0BFF_FFFF映射到引导镜像区,如果是nandflash启动 则将内部SRAM的地址0x0C00_0000~0x0FFF_FFFF映射到引导镜像区。

        3.静态存储区(0x1000_0000~0x3FFF_FFFF)bank0什么都没接,bank1接了DM9000,bank2,3的片选接在nandflash(但只是接在nandflashcon上的片选,没有统一编址),bank4,5应控制cf控制器但ok6410没接。

       4.动态存储器(0x4000_0000~0x6FFF_FFFF)DDR接口,ok6410用的是SRAM端口2地址为0x50000000,详讲下面ok6410原理图。

       5.外设(即寄存器地址0x7000_0000~0x7FFF_FFFF)记得韦东山在讲6410裸机的时候说裸机启动代码最先做的事情应该是把外设的基地址赋值给协处理器cp15此时赋的值就是0x70000000       PS:启动内核后ok6410的0x50000000映射到虚拟地址0c0000000。

       

     

         

          

       还剩下几个地址没有理解,待日后理解了再补充上来,有dnw里面设置的地址,有ads里面的两个地址,有uboot和内核里面分区地址。



这篇关于ok6410学习笔记(1.arm常见的各种地址总结)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/383482

相关文章

Go标准库常见错误分析和解决办法

《Go标准库常见错误分析和解决办法》Go语言的标准库为开发者提供了丰富且高效的工具,涵盖了从网络编程到文件操作等各个方面,然而,标准库虽好,使用不当却可能适得其反,正所谓工欲善其事,必先利其器,本文将... 目录1. 使用了错误的time.Duration2. time.After导致的内存泄漏3. jsO

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

java常见报错及解决方案总结

《java常见报错及解决方案总结》:本文主要介绍Java编程中常见错误类型及示例,包括语法错误、空指针异常、数组下标越界、类型转换异常、文件未找到异常、除以零异常、非法线程操作异常、方法未定义异常... 目录1. 语法错误 (Syntax Errors)示例 1:解决方案:2. 空指针异常 (NullPoi

C++常见容器获取头元素的方法大全

《C++常见容器获取头元素的方法大全》在C++编程中,容器是存储和管理数据集合的重要工具,不同的容器提供了不同的接口来访问和操作其中的元素,获取容器的头元素(即第一个元素)是常见的操作之一,本文将详细... 目录一、std::vector二、std::list三、std::deque四、std::forwa

Linux系统中配置静态IP地址的详细步骤

《Linux系统中配置静态IP地址的详细步骤》本文详细介绍了在Linux系统中配置静态IP地址的五个步骤,包括打开终端、编辑网络配置文件、配置IP地址、保存并重启网络服务,这对于系统管理员和新手都极具... 目录步骤一:打开终端步骤二:编辑网络配置文件步骤三:配置静态IP地址步骤四:保存并关闭文件步骤五:重

Linux配置IP地址的三种实现方式

《Linux配置IP地址的三种实现方式》:本文主要介绍Linux配置IP地址的三种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录环境RedHat9第一种安装 直接配置网卡文件第二种方式 nmcli(Networkmanager command-line

Java反转字符串的五种方法总结

《Java反转字符串的五种方法总结》:本文主要介绍五种在Java中反转字符串的方法,包括使用StringBuilder的reverse()方法、字符数组、自定义StringBuilder方法、直接... 目录前言方法一:使用StringBuilder的reverse()方法方法二:使用字符数组方法三:使用自

Java进阶学习之如何开启远程调式

《Java进阶学习之如何开启远程调式》Java开发中的远程调试是一项至关重要的技能,特别是在处理生产环境的问题或者协作开发时,:本文主要介绍Java进阶学习之如何开启远程调式的相关资料,需要的朋友... 目录概述Java远程调试的开启与底层原理开启Java远程调试底层原理JVM参数总结&nbsMbKKXJx

Linux虚拟机不显示IP地址的解决方法(亲测有效)

《Linux虚拟机不显示IP地址的解决方法(亲测有效)》本文主要介绍了通过VMware新装的Linux系统没有IP地址的解决方法,主要步骤包括:关闭虚拟机、打开VM虚拟网络编辑器、还原VMnet8或修... 目录前言步骤0.问题情况1.关闭虚拟机2.China编程打开VM虚拟网络编辑器3.1 方法一:点击还原VM

MySQL常见的存储引擎和区别说明

《MySQL常见的存储引擎和区别说明》MySQL支持多种存储引擎,如InnoDB、MyISAM、MEMORY、Archive、CSV和Blackhole,每种引擎有其特点和适用场景,选择存储引擎时需根... 目录mysql常见的存储引擎和区别说明1. InnoDB2. MyISAM3. MEMORY4. A