- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
假设您有一个指向函数的指针,您没有它的源并且它是“不受信任的”,因为它可能读/写到不允许的内存区域。
在它执行每条汇编指令之前,您要验证它不会访问不允许的内存区域。
操作系统(几乎)是裸机,即自定义 RTOS(因此没有 Linux 或 QNX)。
这是一个不仅在开发期间而且在正常运行时都需要启用的功能。
理想情况下,它会像这样运行:
void (*fptr)(int);
fptr = &someFunction; // untrusted, don't have source
// enable interrupts for each assembly instruction
_EN_INT();
// call the function
fptr();
// everytime the PC increments, some other code runs which verifies that if any load/stores are executed, it doesn't access some disallowed memory range
// disable interrupts for each assembly instruction
_DIS_INT();
问题
是否可以在每个汇编指令之后调用该函数并暂停执行?
最佳答案
The OS is (almost) bare-metal i.e. a custom RTOS (so no Linux or QNX).
我的回答假设您可以按照需要的方式修改“操作系统”...
Cortex MK20DX256VLH7
这似乎是一个 Cortex M4 CPU。
how to single-step code on-target with no jtag, breakpoints
From the doc, it doesn't say whether you NEED an external debugger to resume execution.
如果 CPU 真的停止了,您肯定需要外部信号(例如来自调试器的信号)。
不过大多数 CPU 都支持软件调试。这意味着只要遇到断点,就会执行中断服务例程。要继续执行,您只需从中断服务例程中返回即可。
我不知道 Cortex M4,但对于 Cortex M3,您必须设置一些特殊寄存器才能启用该功能。每当命中“BKPT”指令时,就会执行中断 #12 (*)。
对于 RAM 中的代码,您只需将 BKPT 指令(0xBExx,例如 0xBEBE)写入要设置断点的地址。 (在写入之前,您读出该值以便以后能够恢复它)。
对于闪存中的代码,M3 有一个“闪存修补单元”,允许您指定最多三个地址,即使其他数据存储在那里,这些地址也应被读出为 0xBExx(0xBEBE?)。这允许您在 Flash 中设置最多 3 个断点。
您感兴趣的是:控制 M3 中调试功能的寄存器(名为“DEMCR”)也有一个名为“MON_STEP”的位:
如果您在中断处理程序#12 中设置该位,则在从中断处理程序返回后恰好执行一条指令并再次触发中断#12。此功能的用例当然是单步执行代码!
要停止单步执行,您必须再次清除 MON_STEP 位...
重要 1:
我不知道 MK20DX256VLH7 是否真的具备所有这些功能。然而,因为它是一个 Cortex M4 芯片,而且 M4 应该具有 M3 的几乎所有功能,这些功能应该存在......
重要2:
实现单步执行和调试不是很快就能完成的。汇编语言知识将非常有帮助,您将需要大量时间...
From the doc, ...
您不仅需要 NXP 的 MK20DX256VLH7 文档,还需要 ARM 的 Cortex M4 文档。
(*) vector 表中的偏移量4*12就是这里的意思(在某些ARM文档中被命名为“IRQ(-4)”);不是 IRQ12。
关于c - 如何在没有 jtag、断点、模拟器、仿真器的情况下在目标上单步执行代码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47207384/
我创建了一个基于命令行可移植脚本的工业化不可知构建系统,可用于快速构建多个依赖项目,而不必依赖特定的 IDE 或构建工厂。它是不可知的,因为它不是基于单个构建引擎。我使用 cmake 创建了第一个版本
我最初使用 Java 目标开发了一个语法(用于 TestRig 支持),然后将其移植到 Python(从 git hub 语法存储库扩展了 Python3 语法,因此需要将操作移植到 Python
我有一个以 iPhone 和 watchOS 为目标的 Xcode 项目。 iPhone 目标使用加速度计,模拟器不支持。我可以只启动 iPhone 应用程序而不启动 watch 目标吗?我从: Ca
您好,我想创建一个批处理文件,用于在 .eml 文件(目标 A)中查找某些关键字,然后删除它们所在的行。之后,我需要批处理文件将"new"文件放入(目标 B)中的单独 .eml 文件中。文件也可以是
当尝试通过 IntelliJ 运行示例 CorDapp (GitHub CorDapp) 时,我收到以下错误: Cannot inline bytecode built with JVM target
我在尝试向我的 kotlin spring 项目添加一些依赖项时遇到问题。我使用 spring boot 初始化程序来运行一个基本项目。 我的问题:如果我取消对 jackson 或 Koin 依赖项的
这是有问题的网站: http://www.onepixelroom.com/londonrefurb 当我点击关于部分后面的多个圆圈时,我希望它更改上面文本中的引号。 到目前为止,我得到它来显示 文本
单击后,我将删除两个元素 $(this) 和 $("#foo")。 目前我的代码如下所示: $(this).remove(); $("#foo").remove(); 如何在不重复自己的情况下优化它?
我有一个小脚本,可将 Markdown 文件编译为 html,并将其与一些样式表和 javascript 一起插入到模板的主体中。我有一个 GNU makefile 来完成这个: output.htm
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
一些背景知识: 在android中我们开发了同样的应用,基本上我们先开发了Android应用,现在我们创建了它的IOS版本,所以这个应用有多个客户端。在 android 中,我们实际上是使用 Andr
我想知道是否可以使用 knockout 来更改html中的目标() 我的所有其他信息都在 JavaScript 中,所以这对我来说是一个大问题。这是我的 JavaScript: var library
这个问题在这里已经有了答案: Selecting and manipulating CSS pseudo-elements such as ::before and ::after using j
我在我的有向图中添加了一堆节点和顶点,使用设置 typedef boost::adjacency_list graph; 创建 Node有一个节点名称字符串,Edge它的分数有一个整数。我试图遍历所有
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 关闭 8 年前。 Improve
如何存储我在 NSUserDefaults 中创建的 Goal 类型的对象数组? ( swift ) 代码如下: func saveGoalList ( newGoalList : [Goal] ){
Array.prototype.indexOf 和 Date.now 已在 ES5 中引入。如果我编译存储在文件 test.ts 中的以下代码,为什么 Typescript 不能转译? Date.no
我正在阅读有关属性的内容,并了解到可以使用您的代码将它们应用于不同的目标实体 -(请参阅 Attribute Targets)。 因此,查看我项目中的 AssemblyInfo.cs 文件,我可以看到
给定一个 Makefile: all: build/a build/b build/c # need to change this to all: build/* build/a:
我有一个带有多框架目标的项目- netstandard2.0;net471 . 我想为 netframework 构建解决方案和 netstandard分别。 目前我使用这个 MSBuild 命令:
我是一名优秀的程序员,十分优秀!