pythonスクリプト内でアセンブリコードを実行したいのですが、可能ですか?
Cプログラミングでは次のようになります
static inline getesp(){
__asm__("mov %esp, %eax");
}
しかし、Pythonでそれを行う方法は?出来ますか?
Pythonプログラム内に直接アセンブリを埋め込むことができます:
これらは、アセンブリをコンパイルし、実行時にそれを実行可能メモリにロードすることによって機能します。最初の3つのプロジェクトはPythonでx86-64またはx86アセンブラを実装しますが、最後のプロジェクトは外部コンパイラを呼び出します。
ネクロポスティングには申し訳ありませんが、asmを使用して独自のDLLを記述し、Python内から関数を呼び出すことができると思います。
具体的な例として、ここでは、intを取り、1ずつ増加する関数を呼び出す方法を示します。
実行可能フラグを設定してメモリを取得するには、mmap
モジュールを使用します。
関数を呼び出すには、ctypes
モジュールを使用します。
マシンコードをメモリに配置するために、ハードコードされたバイト文字列があります。
コードは43を出力します。
import ctypes
import mmap
buf = mmap.mmap(-1, mmap.PAGESIZE, prot=mmap.PROT_READ | mmap.PROT_WRITE | mmap.PROT_EXEC)
ftype = ctypes.CFUNCTYPE(ctypes.c_int, ctypes.c_int)
fpointer = ctypes.c_void_p.from_buffer(buf)
f = ftype(ctypes.addressof(fpointer))
buf.write(
b'\x8b\xc7' # mov eax, edi
b'\x83\xc0\x01' # add eax, 1
b'\xc3' # ret
)
r = f(42)
print(r)
del fpointer
buf.close()
Pythonは、このタイプの低レベルのハードウェア相互作用をサポートしていません。
Pythonで小さなアセンブラを作成した可能性が高いです。使用したライブラリの一部はCtypesをサポートしている可能性がありますが、純粋なPythonを使用しました。ほとんどの言語は実際には低レベルでインターフェースします。HLLランゲージ機能を使用しているだけで、料金は支払っていませんコードの処理方法に適切な注意を払い、ASM x86コードを使用するVisual Basicで小さなPOC画像編集アプリも作成しました。これを編集して自分の言おうとしている方法に実際に確信が持てません。ただし、asmコードを読み取り、スクリプト自体から機能する関数は除きます。私の考えは間違っていると指摘されたと思います。 ASMコードは、コードのその領域を読み取ってコンパイルするスクリプト関数を使用して実行できます。まるでそれがその場で組み込まれたアセンブラであるかのように。私はそれほど優れたスピーカーではないように努めますが(この場合は筆者)、このページはここで私が言おうとしていることをよりよく説明できると思います http://code.activestate.com/レシピ/ 579037-how-to-execute-x86-64-bit-Assembly-code-directly-f /