windows如何调用Linux的API,Windows和Native API中的系统调用?
最近,我在* NIX操作系統(tǒng)中使用了很多匯編語言。我想知道Windows域。
Linux中的調(diào)用約定:
mov $SYS_Call_NUM, %eax
mov $param1 , %ebx
mov $param2 , %ecx
int $0x80
而已。這就是我們應該如何在Linux中進行系統(tǒng)調(diào)用。
linux中所有系統(tǒng)調(diào)用的參考:
關(guān)于哪個$
SYS_Call_NUM和哪個參數(shù),我們可以使用此引用:http
://docs.cs.up.ac.za/programming/asm/derick_tut/syscalls.html
官方參考:http :
//kernel.org/doc/man-
pages/online/dir_section_2.html
Windows中的調(diào)用約定:
???
Windows中所有系統(tǒng)調(diào)用的參考:
???
非官方的:http :
//www.metasploit.com/users/opcode/syscalls.html,但是除非我知道調(diào)用約定,否則如何在匯編中使用它們。
官方:???
如果您說的話,他們沒有記錄在案。那么如何在不知道系統(tǒng)調(diào)用的情況下為Windows編寫libc?Windows Assembly編程如何?在驅(qū)動程序編程中至少要了解這些。對?
現(xiàn)在,所謂的本機API怎么了?是Native API與System calls for
windows二者都是指同一事物的不同方面?為了確認,我比較了兩個非官方來源的數(shù)據(jù)
系統(tǒng)調(diào)用:http :
//www.metasploit.com/users/opcode/syscalls.html
我的觀察:
所有系統(tǒng)調(diào)用都以字母開頭Nt,因為Native API由很多不以字母開頭的功能組成Nt。
System Call of windows是的子集Native API。系統(tǒng)調(diào)用只是本機API的一部分。
任何人都可以確認并解釋。
編輯:
還有另一個答案。這是第二個答案。我真的很喜歡它,但是我不知道為什么應答者刪除了它。我要求他重新發(fā)布他的答案。
創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎勵來咯,堅持創(chuàng)作打卡瓜分現(xiàn)金大獎總結(jié)
以上是生活随笔為你收集整理的windows如何调用Linux的API,Windows和Native API中的系统调用?的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: linux 网络在线升级,linux在线
- 下一篇: linux内存分配堆栈数据段代码段,li