| intro | |||
Nomintro - Introduction à la section des appels-système.DescriptionCe chapitre décrit les appels-système de Linux. Pour avoir une liste des appels-système disponibles dans Linux 2, voyez la page syscalls(2) .Appel DirectDans la plupart des cas il n'est pas nécessaire d'invoquer directement un appel-système, mais il arrive parfois que la bibliothèque C standard n'implémente pas une fonction utile.Synopsis#include <linux/unistd.h>une macro _syscall L'appel systeme désiré
SetupLa chose la plus importante à connaître concernant un appel-système est son prototype. Vous devez connaître le nombre d'arguments, leurs types, et le type de retour de la fonction. Il y a 6 macros simplifiant l'appel effectif au système. Elles ont la forme :
_syscallX(type,name,type1,arg1,type2,arg2,...) Ces macros créent une fonction appelée name avec les arguments spécifiés. Une fois inclus le _syscall() dans le fichier source, on effectue l'appel-système avec name. Exemple
#include <stdio.h>
#include <linux/unistd.h> /* les macros _syscallX */
#include <linux/kernel.h> /* pour struct sysinfo */
_syscall1(int, sysinfo, struct sysinfo *, info);
/*
* Note : Si vous copiez directement depuis le source nroff
* de cette page, n'oubliez pas d'enlever les backslashes
* supplémentaires dans les printf.
*/
int main(void)
{
struct sysinfo s_info;
int error;
error = sysinfo(&s_info);
printf("code d'erreur = %d\n", error);
printf("Uptime = %ds\nCharge: 1 min %d / 5 min %d / 15 min %d\n"
"RAM: totale %d / libre %d / partagee %d\n"
"Mémoire dans buffers = %d\nSwap: total %d / libre %d\n"
"Nombre de processus = %d\n",
s_info.uptime, s_info.loads[0],
s_info.loads[1], s_info.loads[2],
s_info.totalram, s_info.freeram,
s_info.sharedram, s_info.bufferram,
s_info.totalswap, s_info.freeswap,
s_info.procs);
return(0);
}
Exemple D'éxécutioncode d'erreur = 0 uptime = 502034s Charge: 1 min 13376 / 5 min 5504 / 15 min 1152 RAM: totale 15343616 / libre 827392 / partagee 8237056 Mémoire dans buffers = 5066752 Swap: total 27881472 / libre 24698880 Nombre de processus = 40 NotesLa macro _syscall() ne crée pas de prototype. Il faut le fournir vous-même, principalement en C++.Les appels-système ne renvoient pas nécessairement des code d'erreurs tous positifs ou négatifs. Vous devez lire les sources pour vérifier le retour en erreur. Généralement, ce sont des codes d'erreur négatifs, par exemple -EPERM. La macro _syscall() renverra le résultat r de l'appel-système quand r est positif ou nul, mais renverra -1 sinon, en positionnant la variable errno a -r. Certains appels-système, comme mmap, nécessitent plus de cinq arguments. Ceci est géré en plaçant les arguments sur la pile et en passant un pointeur sur le bloc d'arguments. ConformitéDans ce paragraphe, des abréviations indiquent les variantes d'Unix, ou des standards dont les appels-système sont conformes à la description donnée dans ces pages de manuel. Il s'agit de :
Fichiers/usr/include/linux/unistd.hAuteursDans l'en-tête de la page de manuel se trouvent le nom des auteurs et les conditions de copyright. Ceci peut changer suivant les pages !
TraductionChristophe Blaess, 1997.
|