table of contents
- bookworm 4.18.1-1
- bookworm-backports 4.24.0-2~bpo12+1
- testing 4.24.0-2
- unstable 4.24.0-2
SOCKETCALL(2) | Linux-Programmierhandbuch | SOCKETCALL(2) |
BEZEICHNUNG¶
socketcall - Systemaufrufe für Sockets
ÜBERSICHT¶
#include <linux/net.h> /* Definition der SYS_*-Konstanten */ #include <sys/syscall.h> /* Definition von SYS_socketcall */ #include <unistd.h>
int syscall(SYS_socketcall, int Aufruf, unsigned long *Arg);
Hinweis: Glibc stellt keinen Wrapper für socketcall() bereit; hierdurch wird die Verwendung von syscall(2) notwendig.
BESCHREIBUNG¶
socketcall() ist ein gemeinsamer Kernel-Eintrittspunkt für die Socket-Systemaufrufe. Aufruf gibt an, welche Socket-Funktion aufgerufen werden soll, Arg zeigt auf einen Speicherbereich, dessen Inhalt als Argumente an den entsprechenden Aufruf weitergeleitet wird.
Benutzerprogramme sollten die entsprechenden Funktionen mit ihren normalen Namen aufrufen. Nur Programmierer von Standardbibliotheken oder Kernel-Hacker müssen socketcall() kennen.
Aufruf | Handbuchseite |
SYS_SOCKET | socket(2) |
SYS_BIND | bind(2) |
SYS_CONNECT | connect(2) |
SYS_LISTEN | listen(2) |
SYS_ACCEPT | accept(2) |
SYS_GETSOCKNAME | getsockname(2) |
SYS_GETPEERNAME | getpeername(2) |
SYS_SOCKETPAIR | socketpair(2) |
SYS_SEND | send(2) |
SYS_RECV | recv(2) |
SYS_SENDTO | sendto(2) |
SYS_RECVFROM | recvfrom(2) |
SYS_SHUTDOWN | shutdown(2) |
SYS_SETSOCKOPT | setsockopt(2) |
SYS_GETSOCKOPT | getsockopt(2) |
SYS_SENDMSG | sendmsg(2) |
SYS_RECVMSG | recvmsg(2) |
SYS_ACCEPT4 | accept4(2) |
SYS_RECVMMSG | recvmmsg(2) |
SYS_SENDMMSG | sendmmsg(2) |
KONFORM ZU¶
Dieser Aufruf ist Linux-spezifisch und sollte nicht für portierbare Programme verwendet werden.
ANMERKUNGEN¶
Für einige Architekturen – beispielsweise x86-64 und ARM – ist der Systemaufruf socketcall() nicht implementiert. Stattdessen sind socket(2), accept(2), bind(2) usw. wirklich als getrennte Systemaufrufe realisiert.
Unter x86-32 war socketcall() historisch der einzige Eintrittspunkt für das Sockets-API. Beginnend mit Linux 4.3 werden allerdings direkte Systemaufrufe unter x86-32 für das Sockets-API bereitgestellt. Dies ermöglicht die Erstellung von seccomp(2)-Filtern, die Socket-Systemaufrufe filtern (für neue Anwendungsprogramme, die für die Verwendung der neuen Eintrittspunkte übersetzt wurden), und bietet auch ein (sehr) kleine Leistungsverbesserung.
SIEHE AUCH¶
accept(2), bind(2), connect(2), getpeername(2), getsockname(2), getsockopt(2), listen(2), recv(2), recvfrom(2), recvmsg(2), send(2), sendmsg(2), sendto(2), setsockopt(2), shutdown(2), socket(2), socketpair(2)
KOLOPHON¶
Diese Seite ist Teil der Veröffentlichung 5.13 des Projekts Linux-man-pages. Eine Beschreibung des Projekts, Informationen, wie Fehler gemeldet werden können sowie die aktuelle Version dieser Seite finden sich unter https://www.kernel.org/doc/man-pages/.
ÜBERSETZUNG¶
Die deutsche Übersetzung dieser Handbuchseite wurde von Martin Schulze <joey@infodrom.org>, Martin Eberhard Schauer <Martin.E.Schauer@gmx.de> und Helge Kreutzmann <debian@helgefjell.de> erstellt.
Diese Übersetzung ist Freie Dokumentation; lesen Sie die GNU General Public License Version 3 oder neuer bezüglich der Copyright-Bedingungen. Es wird KEINE HAFTUNG übernommen.
Wenn Sie Fehler in der Übersetzung dieser Handbuchseite finden, schicken Sie bitte eine E-Mail an die Mailingliste der Übersetzer.
22. März 2021 | Linux |