- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要一个额外的寄存器来在 smali 方法中存储一个字符串。我知道 smali 代码中的寄存器逻辑(参见 https://github.com/JesusFreke/smali/wiki/Registers ),但我仍然想知道如何归档寄存器的增加。
假设我有一个带有 .locals n 的方法。现在我想要 .locals n+1。首先,我想遍历该方法并将 1 添加到每个 v 寄存器(v0 -> v1,v1 -> v2)。然后 v0 将是我的新寄存器,我不会破坏任何现有数据。此外,我保持 p 和 v 寄存器之间的对齐。
不幸的是,这种简单的方法会导致代码无法编译。我不知道为什么。我错过了什么?
最佳答案
不幸的是,没有简单、有保证的方法来做到这一点。但是,最接近的是增加 .registers
或 .locals
中的寄存器数量,就像您描述的那样,然后最后一个非参数寄存器将可供您使用.此外,确保文件未使用 -p/--no-parameter-registers 选项反汇编,以便所有参数寄存器都使用它们自己的编号方案,因此它们不会受到影响通过寄存器的增加。
使用这种方法时您可能会遇到的一个问题是参数寄存器被递减了一个寄存器。这可能会导致问题,例如,如果其中一个参数寄存器被映射到 v15,并且它被降低到 v16。这可能是个问题,因为很多指令只能接受 v0 到 v15。因此,在这些情况下,您可能需要添加另一个或两个临时寄存器,并使用寄存器值玩音乐椅游戏,将值交换进出较低的寄存器,以便在只能寻址前 16 个寄存器的此类指令中使用。
由于这样做的复杂性,我通常建议您尽量避免更改现有方法中的寄存器数量。而是尝试在新方法中实现逻辑,然后您可以从现有方法调用该方法而无需分配新寄存器。当然,这并不总是可行的,具体取决于您想要做什么。
关于android - Smali:增加寄存器数量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27341565/
我在 smali 中有这行代码 :cond_2 sput-boolean v11, Lcom/geo/main/MainActivity;->mLARGE:Z 我想直接给v11赋一个True值 我该怎
我收到以下 dalvikvm 验证程序错误: Line 1041: W/dalvikvm( 2610): VFY: register1 v5 type 13, wanted 5 Line 1042:
我需要一个额外的寄存器来在 smali 方法中存储一个字符串。我知道 smali 代码中的寄存器逻辑(参见 https://github.com/JesusFreke/smali/wiki/Regis
.method private a()Landroid/content/Intent; .locals 5 .prologue .line 297 :try_start_0 iget-object v
我需要将此指令转换为 smali 代码: Uri uri = Uri.parse("http://www.google.com"); // missing 'http://' will cause c
我正在尝试生成基于 .smali 文件的调用图。然而,我遇到了一个令人困惑的案例如下: .super Landroid/graphics/drawable/Drawable; .source "SBa
.method public c()Ljava/lang/String; .locals 3 const/4 v1, 0x0 const-string v0, "wifi" invoke-virtua
我有一个 smali 代码,我想在其中的一开始就注入(inject)一个 sleep 函数。为此,我创建了一个只是 hibernate 的应用程序,生成了它的 smali 并作为 onCreate 方
按照 smali 代码,通过单击查看按钮在 web View 中查看 url。但链接后面是结果 url 中的 PackageName 。那么我应该在以下 smali 代码中更改什么才能仅转到链接?
我注入(inject)了这段代码invoke-static {p0}, Lcom/outfit7/talkingtomcandyrun/Toast;->show(Landroid/content/Co
smali 中的这一行是做什么的?我一直在谷歌上搜索 .restart 的东西,但没能找到任何关于它的信息。 .restart local v3 #i:I 最佳答案 这相当于 dex 文件
我使用 baksmali 反汇编了一个 Android 应用程序,并研究了生成的smali代码。其中一个类包含以下行: .local v1, "future":Lcom/android/volley/
我对一些 android apk 进行了逆向工程,以添加一些用于功能测试的工具。我想知道给定一个 smali,如下所示,我该如何添加类似 的内容 Log.e(TAG, "some descritpio
我一直在研究 smali 中的一个简单方法(此处来自 Android),我想知道如何对它做一些简单的事情,比如 return false。我一直在尝试通过与 Java 对应物比较和一些示例来理解它,我
是否存在 .smali 文件的解析器? 让我更明确一点: 我需要编写一个程序。 这个程序的输入是一个.smali文件。 这个程序(感谢我的解析器寻找 ) 应该在每次声明全局变量时捕获。 下一步添加一些
我知道如何从函数返回 TRUE bool 值: .locals 1 const/4 v0, 0x1 return v0 现在我需要返回一个整数(10000 值)。怎么办? 最佳答案 下面的方法 pub
我使用 apktool 将 .dex 解码为 smali,但我找不到编辑 DEBUG 的方法,DEBUG 是一个默认为 false 的 boolean 值(在 Java 字节码编辑器中读取 0x000
我对apk文件进行逆向工程,发现AlertDialog is cancelable false invoke-virtual {v0, v4}, Landroid/app/AlertDialog$Bu
我正在逆向一个 Android 应用程序。我想修改并重建它。我使用APK Studio(这几乎是 apktool 的 GUI 版本)来获取 apk 中的文件。现在阅读 smali 代码非常困难。 我还
序言 我正在尝试使用 dex 文件的 Smali/Baksmali 汇编器/反汇编器来了解 DalvikVM 指令。 问题 来自这个java文件 package gd; class Hello {
我是一名优秀的程序员,十分优秀!