1.用宏生成系統調用例程
高級語言應用程序一般不能直接訪問內核函數。但是,總還是有一些高級用戶需要訪問內核函數,如果讓用戶自己編寫匯編語言程序來實現內核的陷入,顯然是不合適的,因為它既不安全也不符合設置操作系統的初衷___為用戶提供一個友好的程序設汁平台。
由於用於封裝內核服務例程的系統調用例程有一個固定的框架,所以為了簡化對內核服務例程的封裝工作,Linux定義了從_sysca110~_sysca115的6個宏,高級用戶可使用這些宏把所需的內核服務例程封裝為系統調用例程。
上述這6個宏的名稱後的數字表示被封裝的內核服務例程可使用的參數個數(系統調用號除外)。在上述宏對內核服務例程進行封裝時,Linux規定,給宏傳遞參數的個數應是內核服務例程所需參數個數的2倍再加2,即2(n+1)個,其中″是系統調用的參數個數。也就是說.對於內核服務例程的每一個參數,在宏中都必須用兩個參數來表達:一個用來指明參數的名稱,一個用來指明參數的類型。還要附加兩個參數,分別用來表達系統調用返回值的名稱和類型。例如,用宏來封裝內核服務例程write()時,就應按下面的格式來調用宏syscall3:_syscall3(int,write,int,fd,cONst char*,buf,unsingnde int,count)
其中:int和wrlte為返回值的類型和名稱;int和fd為其參數fd的類型和名稱;const char*和buf為其參數buf的類型和名稱;unsigned lnt和count為其參數count的類型和名稱。
2.系統調用接口
一般情況下,作為一個完善的操作系統,是不會讓用戶應用程序直接使用名稱類似於.svsxyz()形式的系統凋用例程來調用內核服務例程的。所以,通常還要在系統調用例程的上面再用高級語言提供一個與普通函數一樣的接口,這樣用戶在通過這個接口凋用系統服務時,感覺就像使用普通函數一樣方便。