First, you can find libaio source in http://libaio.sourcearchive.com/
version source,unzip it
#define __SYSCALL_CLOBBERS "$1", "$3", "$10", "$11", "$12", "$13", \ "$14", "$15", "$24", "$25", "memory"
#define io_syscall1(type,fname,sname,type1,arg1)\type fname (type1 arg1)\{\ long _sys_result; \ register long __v0 asm("$2"); \ register long __a0 asm("$4") = arg1; \ register long __a1 asm("$7"); \ __asm__ __volatile__( \ ".set push\n\t" \ ".set noreorder\n\t" \ "li %0, %2\n\t" \ "syscall\n\t" \ ".set pop\n\t" \ :"=r"(__v0),"=r"(__a1) \ :"i" (__NR_##sname),"r"(__a0) \ : __SYSCALL_CLOBBERS \ ); \ _sys_result = __v0; \ _sys_result; \}
#define io_syscall2(type,fname,sname,type1,arg1,type2,arg2)\type fname (type1 arg1,type2 arg2)\{\ long _sys_result; \ register long __v0 asm("$2"); \ register long __a0 asm("$4") = arg1; \ register long __a1 asm("$5") = arg2; \ register long __a2 asm("$7"); \ __asm__ __volatile__( \ ".set push\n\t" \ ".set noreorder\n\t" \ "li %0, %2\n\t" \ "syscall\n\t" \ ".set pop\n\t" \ :"=r"(__v0),"=r"(__a2) \ :"i" (__NR_##sname),"r"(__a0),"r"(__a1) \ : __SYSCALL_CLOBBERS \ ); \ _sys_result = __v0; \ _sys_result; \}
#define io_syscall3(type,fname,sname,type1,arg1,type2,arg2,type3,arg3)\type fname (type1 arg1,type2 arg2,type3 arg3)\{\ long _sys_result; \ register long __v0 asm("$2"); \ register long __a0 asm("$4") = arg1; \ register long __a1 asm("$5") = arg2; \ register long __a2 asm("$6") = arg3; \ register long __a3 asm("$7"); \ __asm__ __volatile__( \ ".set push\n\t" \ ".set noreorder\n\t" \ "li %0, %2\n\t" \ "syscall\n\t" \ ".set pop\n\t" \ :"=r"(__v0),"=r"(__a3) \ :"i" (__NR_##sname),"r"(__a0),"r"(__a1),"r"(__a2) \ : __SYSCALL_CLOBBERS \ ); \ _sys_result = __v0; \ _sys_result; \}
#define io_syscall5(type,fname,sname,type1,arg1,type2,arg2,type3,arg3,type4,arg4, \ type5,arg5)\type fname (type1 arg1,type2 arg2,type3 arg3,type4 arg4,type5 arg5)\{\ long _sys_result; \ register long __v0 asm("$2"); \ register long __a0 asm("$4") = arg1; \ register long __a1 asm("$5") = arg2; \ register long __a2 asm("$6") = arg3; \ register long __a3 asm("$7") = arg4; \ register long __a4 asm("$8") = arg5; \ register long __a5 asm("$9"); \ __asm__ __volatile__( \ ".set push\n\t" \ ".set noreorder\n\t" \ "li %0, %2\n\t" \ "syscall\n\t" \ ".set pop\n\t" \ :"=r"(__v0),"=r"(__a5) \ :"i" (__NR_##sname),"r"(__a0),"r"(__a1),"r"(__a2),"r"(__a3) ,"r"(__a4) \ : __SYSCALL_CLOBBERS \ ); \ _sys_result = __v0; \ _sys_result; \}
/****************END*************************/
That is All.They are the most important part. The rest is just relsove compile problem.
Like somewhere is missing the mips definition, somewhere is missing the .h name.
Remeber change the CC in Makefile, use mips-gcc.
Finally,just run make command,you will get a static lib which is named "libaio.a"
I use it to work with fio tools,it's work for me.Hope it's useful to you.
今天想用一下fio在mips架構下,修改fio代碼,將mips相關的地方補全,主要是缺少mips定義,還有一些標頭檔方面的問題。
最後發現連結的時候提示找不到libaio庫。搜尋了一下,在http://libaio.sourcearchive.com/下載了libaio的代碼。
然後解壓準備編譯一個mips版本,結果悲劇的發現libaio不支援mips架構,簡單的分析了一下源碼,發現原來就差一個標頭檔,用來
定義在mips架構下,使用者態如何進入核心的翻譯,這個是和架構強相關的。
簡單開始google和stackoverflow了一把,沒有什麼有用的發現。分析了一下x86和x86_64架構的標頭檔,發現還算簡單。
於是準備自己寫一下,google一下mips的ABI介面,然後又搜尋了一下系統調用的實現,然後就完成了上面的標頭檔的主要內容。
主要就是利用系統調用的介面,是linux核心支援的aio相關的調用,通過寄存器傳入多個參數到核心。
剩下的就是解決libaio本身的編譯問題,注意一下,這部分代碼會有編譯警示,分析一下,主要是類型轉換方面的,我決定不管了^_^
編譯得到了libaio.a。下一步是將libaio.a拷貝到庫目錄中去。編譯通過後,到mips環境下試了一下,ok成功了。