_syscall(2) System Calls Manual _syscall(2) NOME _syscall - invoca una chiamata di sistema senza supporto di libreria (OBSOLETO) SINTASSI #include Una macro _syscall la chiamata di sistema desiderata DESCRIZIONE La cosa importante da sapere sulle chiamate di sistema e il loro prototipo. Bisogna conoscere il numero di argomenti, il loro tipo, e il tipo di ritorno della funzione. Ci sono sette macro che rendono piu facile la reale chiamata nel sistema. Hanno il formato: _syscallX(tipo,nome,tipo1,arg1,tipo2,arg2,...) dove X is 0-6, which are the number of arguments taken by the system call tipo e il tipo di ritorno della chiamata di sistema nome e il nome della chiamata di sistema tipoN e il tipo dell'N-esimo argomento argN e il nome dell'N-esimo argomento Queste macro creano una funzione chiamata nome con gli argomenti specificati. Una volta inclusa la _syscall() nel proprio file sorgente, si puo chiamare la chiamata di sistema con nome. FILE /usr/include/linux/unistd.h STANDARDS Linux. STORIA Starting around Linux 2.6.18, the _syscall macros were removed from header files supplied to user space. Use syscall(2) instead. (Some architectures, notably ia64, never provided the _syscall macros; on those architectures, syscall(2) was always required.) NOTE Le macro _syscall() non producono un prototipo. Occorrera quindi crearne uno, specialmente per chi usa C++. Le chiamate di sistema non devono per forza restituire solo codici di errore positivi o negativi. Occorrera leggere il sorgente per essere sicuri di come ognuna di esse riporta gli errori. Solitamente, il valore di ritorno e il negato di un codice di errore standard, per esempio -EPERM. Le macro _syscall() restituiranno il risultato r della chiamata di sistema quando r e non-negativo, ma restituiranno -1 e imposteranno la variabile errno a r quando r e negativo. Per i codici di errore si veda errno(3). Quando si definisce una chiamata di sistema, i tipi di argomento devono essere passati per valore o per puntatore (per gli aggregati come le strutture). ESEMPI #include #include #include #include /* for _syscallX macros/related stuff */ #include /* for struct sysinfo */ _syscall1(int, sysinfo, struct sysinfo *, info); 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); } Esempio di Output 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 VEDERE ANCHE intro(2), syscall(2), errno(3) TRADUZIONE La traduzione italiana di questa pagina di manuale e stata creata da Elisabetta Galli e Marco Curreli Questa traduzione e documentazione libera; leggere la GNU General Public License Versione 3 o successiva per le condizioni di copyright. Non ci assumiamo alcuna responsabilita. Per segnalare errori nella traduzione di questa pagina di manuale inviare un messaggio a . Linux man-pages 6.06 31 ottobre 2023 _syscall(2)