_syscall   Début   Suivant   Sommaire   Préc.page.lue   Accueil
Section: Manuel du programmeur Linux (2)
Updated: 25 novembre 2007
Sommaire  



NOM   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
_syscall - Invoquer un appel système sans prise en charge par la bibliothèque (OBSOLÈTE)  



SYNOPSIS   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
#include <linux/unistd.h>

Une macro _syscall

appel système désiré  




DESCRIPTION   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
La chose importante à savoir sur un appel système est son prototype. Vous devez savoir combien d'arguments il prend, leurs types et le type retour de la fonction. Il y a sept macros qui facilitent les appels du système. Elles ont la forme :

_syscallX(type,name,type1,arg1,type2,arg2,...)

X est 0-6, qui est le nombre d'argument pris par l'appel système
type est le type de retour de l'appel système
name est le nom de l'appel système
typeN est le type du Nème argument
argN est le nom du Nème argument

Ces macros créent une fonction name avec les arguments que vous avez spécifiés. Une fois que vous avez inclus votre _syscall() dans votre fichier source, vous pouvez appeler l'appel système par name.  




FICHIERS   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
/usr/include/linux/unistd.h  



CONFORMITÉ   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
L'utilisation de ces macros est spécifique à Linux et est déconseillée.  



NOTES   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
À partir du noyau 2.6.18 environ, les macros _syscall ont été supprimées des fichiers d'entêtes fournis à l'espace utilisateur. Utilisez syscall(2) à la place. (Certaines architectures, particulièrement ia64, n'ont jamais fourni les macros _syscall ; sur ces architectures, syscall(2) était toujours nécessaire.)

Les macros _syscall() ne fournissent pas de prototype. Vous devez en créer un, particulièrement les utilisateurs de C++.

Il n'est pas obligatoire que les appels système retournent un code d'erreur seulement positif ou négatif. Vous devez lire les sources pour savoir comment les erreurs sont retournées. Généralement, il s'agit de la valeur opposée d'un code d'erreur standard, par exemple, -EPERM. Les macros _syscall() retourneront le résultat r de l'appel système lorsque r n'est pas négatif, mais retournera -1 et écrira la variable errno avec -r lorsque r est négatif. Pour ces codes d'erreurs, voir errno(3).

Lors de la définition d'un appel système, les types d'arguments doivent être passés par valeur ou par pointeur (pour les types aggrégés comme les structures).  




EXEMPLE   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <linux/unistd.h>       /* for _syscallX macros/related stuff */
#include <linux/kernel.h>       /* for struct sysinfo */

_syscall1(int, sysinfo, struct sysinfo *, info);

/* Note : si vous copiez directement à partir du fichier source
nroff de la page, n'oubliez pas de SUPPRIMER les contre obliques
supplémentaires dans l'instruction printf. */

int
main(void)
{
    struct sysinfo s_info;
    int error;

    error = sysinfo(&s_info);
    printf("code error = %d\n", error);
    printf("Uptime = %lds\nLoad: 1 min %lu / 5 min %lu / 15 min %lu\n"
           "RAM: total %lu / free %lu / shared %lu\n"
           "Memory in buffers = %lu\nSwap: total %lu / free %lu\n"
           "Number of processes = %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);
    exit(EXIT_SUCCESS);
}
 



Échantillon de sortie   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
code error = 0
uptime = 502034s
Load: 1 min 13376 / 5 min 5504 / 15 min 1152
RAM: total 15343616 / free 827392 / shared 8237056
Memory in buffers = 5066752
Swap: total 27881472 / free 24698880
Number of processes = 40
 



VOIR AUSSI   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
intro(2), syscall(2), errno(3)  



TRADUCTION   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil

Ce document est une traduction réalisée par Alain Portal <aportal AT univ-montp2 DOT fr> le 23 décembre 2007 et révisée le 8 janvier 2008.

L'équipe de traduction a fait le maximum pour réaliser une adaptation française de qualité. La version anglaise la plus à jour de ce document est toujours consultable via la commande : « LANG=C man 2 _syscall ». N'hésitez pas à signaler à l'auteur ou au traducteur, selon le cas, toute erreur dans cette page de manuel.


 



Sommaire   Début   Suivant   Sommaire   Préc.page.lue   Accueil
NOM
SYNOPSIS
DESCRIPTION
FICHIERS
CONFORMITÉ
NOTES
EXEMPLE
Échantillon de sortie
VOIR AUSSI
TRADUCTION

Ce document a été créé par man2html suivi de man2html.pl, le 17/10/2008 17:51:59, en utilisant les pages de 'man'.
 

Valid HTML 4.01 Transitional