- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
简而言之,我想关闭 Linux 上下文(从内核内部)中的所有 MMU(和缓存)操作,用于调试目的,只是为了运行一些测试。明确地说,我不希望我的系统在那之后仍然可以正常工作。
关于我的设置:我目前正在摆弄集成了 Cortex A5 的 Freescale Vybrid (VF610) 及其低功耗模式。由于我正在试验一些可疑的本地内存损坏,而芯片处于“低功耗停止”模式并且我的 DDR3 处于自刷新状态,我正在尝试一点一点地改变操作,现在在不实际执行 WFI 的情况下执行所有挂起/恢复步骤。由于在这条指令之前我运行了地址转换,之后没有(它本质上是一个重置),我想通过“手动”关闭 MMU 来“模拟”它。
(我目前对我的芯片没有 JTAG 或任何其他调试访问权限。我通过 MMC/TFTP/NFS 加载它,并使用 LED 对其进行调试。)
到目前为止我尝试了什么:
/* disable the Icache, Dcache and branch prediction */
mrc p15, 0, r6, c1, c0, 0
ldr r7, =0x1804
bic r6, r6, r7
mcr p15, 0, r6, c1, c0, 0
isb
/* disable the MMU and TEX */
bic r7, r6, r7
isb
mcr p15, 0, r6, c1, c0, 0 @ turn on MMU, I-cache, etc
mrc p15, 0, r6, c0, c0, 0 @ read id reg
isb
dsb
dmb
以及具有相同效果的其他变体。
我观察到的:
在 MMU block 之前,我可以点亮一个 LED(3 条汇编指令,没有分支,没有什么花哨的,也没有访问我的 DDR,它已经处于自刷新状态——GPIO 端口的虚拟地址存储在一个寄存器中在那之前)。
在 MMU block 之后,无论我尝试使用物理地址还是虚拟地址,我都无法再尝试。
我认为问题可能与我的 PC 有关,它保留了一个过时的虚拟地址。查看内核其他地方的工作方式,但反过来(即启用翻译):
ldr r3, =cpu_resume_after_mmu
instr_sync
mcr p15, 0, r0, c1, c0, 0 @ turn on MMU, I-cache, etc
mrc p15, 0, r0, c0, c0, 0 @ read id reg
instr_sync
mov r0, r0
mov r0, r0
ret r3 @ jump to virtual address
ENDPROC(cpu_resume_mmu)
.popsection
cpu_resume_after_mmu:
(来自 arch/arm/kernel/sleep.S,cpu_resume_mmu)
我想知道这 2 条指令的延迟与什么有关,以及记录在何处。我在这个问题上一无所获。我尝试过类似的东西,但没有成功:
adr lr, BSYM(phys_block)
/* disable the Icache, Dcache and branch prediction */
mrc p15, 0, r6, c1, c0, 0
ldr r7, =0x1804
bic r6, r6, r7
mcr p15, 0, r6, c1, c0, 0
isb
/* disable the MMU and TEX */
bic r7, r6, r7
isb
mcr p15, 0, r6, c1, c0, 0 @ turn on MMU, I-cache, etc
mrc p15, 0, r6, c0, c0, 0 @ read id reg
isb
dsb
msb
mov r0, r0
mov r0, r0
ret lr
phys_block:
blue_light
loop
感谢任何有线索或指点的人!
最佳答案
为了解决问题的“这 2 条指令延迟是什么”部分,与/arch/arm 的大部分内容一样,它主要只是遗留下来的废话*。
早在任何类型的屏障指令之前的日子里,你必须考虑这样一个事实,即在你切换 MMU 时,管道包含在切换之前已经获取和解码的指令,所以有任何像分支或如果地址空间在它执行时发生了变化,那么那里的内存访问将会出现可怕的错误。 ARMv4 Architecture Reference Manual 做出了精彩的声明“启用和禁用 MMU 的正确代码序列是实现定义的”——实际上,这主要意味着你知道你的管道有 3 个阶段长,所以插入两个 NOP 以安全地填充它.或者 took full advantage of the fact做一些可怕的事情,比如安排直接跳转到翻译后的 VA,而不通过身份映射(哎呀!)。
从有趣的旧微体系结构手册拖网中,3 NOPs are needed for StrongARM (与 3 级 ARM7 流水线的 2 相比),并且读取与结果相关的数据的 CP15 是 XScale 的推荐自同步序列,这解释了对主 ID 寄存器显然毫无意义的读取。
然而,在现代的东西(ARMv6 或更高版本)上,这些都不是必需的,因为你有架构障碍,所以你只需拨动开关然后发出一个 isb
来刷新管道,这是在为此类架构构建时,instr_sync
宏扩展到什么。
* 或者 Linux“适用于一切”方法的一个很好的例子,取决于你的观点......
关于linux - ARM:禁用 MMU 并更新 PC,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30843270/
在gdb中获取此消息。我知道它不是错误或任何东西。我也做了分页,所以那不是问题。 有什么办法可以抑制此消息? 最佳答案 我很好奇看到这个问题没有得到解决... 我获得了GDB manual,它说(部分
好吧,这很烦人,而且可能很简单。我想用禁用的复选框启动我的网页,并在选择列表框中的特定行后启用这些框。所以我把它放在 onload 方法中 onload = function () { for
看来我需要以某种方式在我的 php 页面上禁用 IPv6,但我不确定该怎么做。我想我必须在我的 INI 文件中的某处添加 --disable-ipv6 ……虽然这看起来不像正确的语法。 我正在尝试解决
我有这两个代码: 第一个是禁用复制粘贴的宏: Sub Desable_Copy() Dim oCtrl As Office.CommandBarControl For Each oCt
在下面的代码中,我想, 如果我选择/单击“患者类型”按钮。它们在菜单“xmenumain”“儿科心电图”项中应该被禁用(它应该列在菜单列表中,但颜色为淡灰色)。我如何实现它? void MyMenu:
我目前在 Coordinator 布局中有一个底部导航栏,我向其添加了 HideBottomViewOnScrollBehaviour。有些屏幕需要隐藏导航栏,我可以通过从 BottomNavigat
我需要一些关于 jquery if 条件的帮助。我已经搜索和测试了几个小时,任何帮助都会很棒!我得到这个 HTML 代码: Value: No Match Test Test 2 Test 3
我正在开发 Delphi -7 中的自定义组件我有一些published特性 private { Private declarations } FFolderzip ,Fi
尝试学习菜单处理的基础知识。我的测试应用程序的菜单栏有 3 个菜单——即“TestApp”、“File”和“Help”。我发现我可以完全删除这些菜单,只需调用 say: NSMenu* rootMen
我以编程方式创建一个 NSMenuItem,但它被禁用。如果我重写 validateMenuItem: 方法并为所有项目返回 YES,则菜单项工作正常。 当我告诉菜单 autoEnableItems
我的 Web 表单中有一个 asp 按钮 (runat="server") 进入更新面板。 当我点击这个按钮时,它会执行一些操作。 Private Sub ButtonDoI
我目前正在为 video.js 构建一个插件,它可以在某些断点处将覆盖层呈现在屏幕上。但是,在不启动视频的情况下,我无法单击任何叠加层。我认为我需要禁用播放器上的点击播放功能。 我应该如何禁用/启用
设置剑道网格 selectable: "row", navigatable: true, 允许选择列标题单元格并通过键盘切换其排序状态。如何完全禁用使用键盘选择列标题单元格的功能? 最
我不想卸载code rush。我只是想在不需要的时候有机会将其关闭。 这可能吗? (快速版本)... 最佳答案 首先您应该打开“DevExpress”菜单。默认情况下,它在 CodeRush Xpre
设置: 我正在使用 TinyMCE 的 Angular 包装器来允许我的用户构建自己的电子邮件模板。这些电子邮件会发送给每个用户组织内的多个人员。我创建了自定义工具栏按钮来插入小文本 block [[
我希望下拉菜单在悬停时打开,前提是窗口大于 767 像素。我试图在页面加载和窗口调整大小时调用一个函数,并使用宽度大小条件。 enableHover() 函数仅适用于页面加载,不适用于窗口调整大小。
由于我遇到了一些问题,我正在 .NET Framework 4 中尝试连接池。使用 SQL Profiler,我可以看到每次从连接池中获取连接时,都会执行存储过程 sp_reset_connectio
我避免在我的 swift 代码中收到警告。然而,当谈到 Storyboard要求时,这对我来说有点困难。 所以现在我只想禁用 xcode 显示有关 Storyboard问题的警告。 我尝试了以下方法但
我不是 JavaScript 专家,我目前正在尝试为表单创建一个函数,该函数根据上一页上选择的数字重复相同的字段。 表单字段可能有 1 到 10 行,每行都有一个单选按钮选择,可启用/禁用每一行。 目
我正在尝试使用 CPU2006 运行各种基准测试,以查看各种优化在 gcc 速度方面的作用。我熟悉 -O1、-O2 和 -O3,但听说 -msse 是一个不错的优化。 -msse 到底是什么?我还看到
我是一名优秀的程序员,十分优秀!