zoukankan      html  css  js  c++  java
  • iTOP4412设备驱动学习五--地址和存储的概念

    资料来源于迅为视频学习教程。

    本节主要是学习使用datasheet。

    对宏定义的操作就是对寄存器的操作,上层程序员不需要关心具体的物理或虚拟地址

    1. 4412中的物理地址:

            CPU内部存储器register,eMMc,TF卡

        MMU:内存管理单元

           概念:中央处理器中用来管理虚拟存储器、物理存储器的控制电路,同时负责虚拟地址映射为物理地址。

           基本思路:数据和堆栈的大小总和可以超过物理存储器的大小,操作系统把当前使用的部分留在内存中,其他的保留在硬盘上。

           地址范围:32位的最大为232=4G

       虚拟地址

           分页机制:空间被划分为页的单位,相应的物理地址空间被划分为页帧。页的大小必须一样,页帧的大小页也必须一样

    便于理解的说法:

        虚拟地址:用于解决告诉MPU和低速存储器之间通信的一种技术

                         虚拟地址的范围和内存的物理地址重合

    其他地址概念:

        Base Address:基地址,某一类寄存器的起始地址。寄存器+偏移地址=物理地址

        Offset:偏移地址。

        GPIO基地址:0x106E_0000+偏移地址

        总线地址:

        I2C地址:I2C总线用于区分I2C设备的地址,例如I2C总线上挂载了设备camera,声卡,eeprom等。

                      MPU如何区分I2C是和哪个设备通信:通过I2C的地址

    2. 存储

        SCP datesheet:第三节:存储相关的(Memory Map)地址列表

        ROM:只读存储器,慢,***程序不能在ROM中运行***

              如:(flash rom)硬盘、TF卡、U盘等

        RAM:随机访问存储器,掉电丢失数据,有时候特指内存

        Cache:高速缓存

        SFR:特殊寄存器

    SCP中使用的存储: 

        iROM:存储三星的一段固化的代码,用于启动uboot

        iRAM:iROM中不能运行程序,三星固化代码在iRAM中运行的

       iCache:CPU和内存中间通信的。速度: CPU > i-Cache > RAM > ROM

        SFR:特殊寄存器,GPIO, 中断,总线在这里面配置

        Memory of Dynamic Memory Controller:动态内存控制器。即平时所说的内存

                            Linux内核中函数ioremap的返回值是一个地址,这个地址一定在这个范围区间:0x4000_0000 ~ 0xA000_0000。

                            1G的内存:0x4000_0000~0x8000_0000

                            内存是有物理地址的。

    以上

  • 相关阅读:
    系统tabbar出现两个tabbar的问题解决方案。
    iOS 开发苹果由http改为https 之后,如果服务器不做相应的修改,那么客户端需要做点更改
    UIAlertController的一些简单实用方法
    ios开发同一个lab显示不同的颜色
    ios开发同一个版本多次提交不想改变版本号的解决方法
    iOS开发textfield的一些方法汇总
    C#笔记
    Shader之性能优化
    Shader之ShaderUI使用方法
    Shader Example
  • 原文地址:https://www.cnblogs.com/nanzh/p/12466316.html
Copyright © 2011-2022 走看看