<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Aufrufkonvention</id>
	<title>Aufrufkonvention - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Aufrufkonvention"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Aufrufkonvention&amp;action=history"/>
	<updated>2026-06-27T12:47:38Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Wikipedia (Deutsch) – Lokale Kopie</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://wiki-de.moshellshocker.dns64.de/index.php?title=Aufrufkonvention&amp;diff=450295&amp;oldid=prev</id>
		<title>imported&gt;SchlurcherBot: Bot: http → https</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Aufrufkonvention&amp;diff=450295&amp;oldid=prev"/>
		<updated>2026-01-22T20:02:16Z</updated>

		<summary type="html">&lt;p&gt;Bot: http → https&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Unter &amp;#039;&amp;#039;&amp;#039;Aufrufkonvention&amp;#039;&amp;#039;&amp;#039; ({{enS|calling convention}}) versteht man die Methode, mit der in [[Computerprogramm]]en einem [[Unterprogramm]] Daten übergeben werden. In der Regel liegt es am [[Compiler]], welche Konvention zum Einsatz kommt, so dass der Programmierer sich nicht damit beschäftigen muss. Bei der Entwicklung von Software in mehreren Sprachen ist es jedoch erforderlich, dass alle [[Modul (Software)|Module]] kompatible Aufrufkonventionen verwenden.&lt;br /&gt;
&lt;br /&gt;
== Aufrufkonventionen der x86-Architektur ==&lt;br /&gt;
Die [[X86-Prozessor|x86-Architektur]] besitzt viele verschiedene Aufrufkonventionen.&amp;lt;ref name=&amp;quot;history&amp;quot;/&amp;gt; Wegen der begrenzten Zahl an Registern werden bei vielen x86-Aufrufkonventionen die Argumente überwiegend über den Stack übertragen, während der Rückgabewert (oder ein Zeiger auf ihn) über ein Register zurückgegeben wird. Einige Konventionen nutzen Register für die ersten Argumente, was der Performance für einfache, häufig aufgerufene Funktionen zugutekommt (z.&amp;amp;nbsp;B. Funktionen, welche keine anderen aufrufen und in die dadurch nicht zurückgekehrt wird).&lt;br /&gt;
&lt;br /&gt;
=== cdecl ===&lt;br /&gt;
Die so genannte &amp;#039;&amp;#039;&amp;#039;cdecl&amp;#039;&amp;#039;&amp;#039;-Aufrufkonvention wird von vielen [[C (Programmiersprache)|C-]] und [[C++]]-Compilern verwendet, die auf der [[X86-Prozessor|x86-Architektur]] laufen.&amp;lt;ref name=agnerfog/&amp;gt; Hierbei werden die [[Parameter (Informatik)|Parameter]] nacheinander von rechts nach links auf den [[Stapelspeicher|Stack]] gelegt. Rückgabewerte werden von der aufgerufenen Funktion in der Regel im EAX-[[Register (Computer)|Register]] der [[Hauptprozessor|CPU]] abgelegt. Eine Ausnahme bilden [[Gleitkommazahl]]en, die in ST0 abgelegt werden. Die Register EAX, ECX und EDX stehen für die Verwendung innerhalb der Funktion zur Verfügung.&amp;lt;ref&amp;gt;[http://publib.boulder.ibm.com/infocenter/ratdevz/v7r1m1/index.jsp?topic=/com.ibm.etools.cbl.win.doc/topics/rpsubw29.htm IBM: Developing COBOL and PL/I applications for Windows, CDECL] (Stand: 7. Dezember 2008)&amp;lt;/ref&amp;gt; Wenn darüber hinaus andere Register verwendet werden sollen, muss der Inhalt dieser Register von der Funktion gesichert (meist durch Ablegen auf den Stack) und vor dem Rücksprung wiederhergestellt werden.&lt;br /&gt;
&lt;br /&gt;
Beispiel in C-Code:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;c&amp;quot;&amp;gt;&lt;br /&gt;
int function(int, int, int); /* Prototyp der Funktion */&lt;br /&gt;
int a, b, c, x; /* Variablendeklaration */&lt;br /&gt;
&lt;br /&gt;
x = function(a, b, c); /* Funktionsaufruf */&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Der Funktionsaufruf in der letzten Zeile erzeugt den folgenden x86-[[Assemblersprache|Assembler]]-Code (in [[Microsoft Macro Assembler|MASM]]-Syntax):&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;asm&amp;quot;&amp;gt;&lt;br /&gt;
; Argumente in umgekehrter Reihenfolge auf den Stack legen&lt;br /&gt;
push c&lt;br /&gt;
push b&lt;br /&gt;
push a&lt;br /&gt;
&lt;br /&gt;
; Funktion aufrufen&lt;br /&gt;
call function&lt;br /&gt;
&lt;br /&gt;
; Stack-Pointer zurücksetzen&lt;br /&gt;
add esp, 12&lt;br /&gt;
&lt;br /&gt;
; Rückgabewert der Funktion sichern&lt;br /&gt;
mov x, eax&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Der Aufrufer baut nach der Rückkehr den Stack selbst wieder ab, indem der Stack-Pointer (gespeichert im ESP-Register) so gesetzt wird, dass er wieder auf die Position im Speicher zeigt, auf die er vor den Push-Operationen zeigte. Im Beispiel oben werden drei [[Integer (Datentyp)|Integer]], also 12 [[Byte]]s, auf den Stack gelegt. Da der Stack in x86-Systemen von oben nach unten wächst, wird dabei ESP um 12 dekrementiert. Um wieder auf die Position von vorher zu kommen, muss im Anschluss an den Aufruf wieder 12 auf den Wert im ESP-Register addiert werden. So können auch Funktionen mit variabler Argumenten-Anzahl und Länge realisiert werden.&lt;br /&gt;
&lt;br /&gt;
Die cdecl-Aufrufkonvention ist gewöhnlich die Standard-Aufrufkonvention eines x86-C-Compilers.&lt;br /&gt;
Allerdings verfügen viele Compiler über die Option, eine andere Konvention zu verwenden.&lt;br /&gt;
&lt;br /&gt;
Eine Funktion kann manuell mit folgender Syntax als cdecl-Funktion deklariert werden:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;c&amp;quot;&amp;gt;&lt;br /&gt;
int _cdecl function(int, int, int);&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== stdcall ===&lt;br /&gt;
Die &amp;#039;&amp;#039;&amp;#039;stdcall&amp;#039;&amp;#039;&amp;#039;-Aufrufkonvention ist de facto die Standard-Aufrufkonvention für die [[WinAPI|Microsoft Win32-API]].&amp;lt;ref name=msdn/&amp;gt; Funktionsparameter werden von rechts nach links übergeben. Die Register EAX, ECX, und EDX sind reserviert für die Verwendung innerhalb der Funktion, werden also unter Umständen verändert. Rückgabewerte werden im EAX-Register zurückgegeben. Anders als bei &amp;#039;&amp;#039;cdecl&amp;#039;&amp;#039; bereinigt die aufgerufene Funktion den Stack, nicht der Aufrufer. Wegen dieser Tatsache unterstützen stdcall-Funktionen keine variablen Argumentenlisten.&lt;br /&gt;
&lt;br /&gt;
Beispiel (Deklaration einer stdcall-Funktion in C):&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;c&amp;quot;&amp;gt;&lt;br /&gt;
int _stdcall function(int, int, int);&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Funktionen, die die stdcall-Methode benutzen, sind in Assembler-Code leicht zu erkennen, da sie vor dem Rücksprung zum aufrufenden Code den Stack immer selbst abbauen. Der x86-Befehl &amp;#039;&amp;#039;ret&amp;#039;&amp;#039; erlaubt einen optionalen Parameter, der die Größe des abzubauenden Stacks angibt.&lt;br /&gt;
&lt;br /&gt;
Beispiel: Beim Rücksprung 12 Byte von Stack entfernen.&lt;br /&gt;
&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;asm&amp;quot;&amp;gt;&lt;br /&gt;
ret 12&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Pascal ===&lt;br /&gt;
Bei der &amp;#039;&amp;#039;&amp;#039;Pascal&amp;#039;&amp;#039;&amp;#039;-Aufrufkonvention werden die Parameter, im Gegensatz zur cdecl-Konvention, in der Reihenfolge von links nach rechts auf dem Stack abgelegt, und die aufgerufene Funktion muss den Stack-Pointer vor dem Rücksprung zum aufrufenden Code selbst zurücksetzen.&amp;lt;ref name=agnerfog/&amp;gt;&lt;br /&gt;
&lt;br /&gt;
=== Register (FastCall) ===&lt;br /&gt;
Die &amp;#039;&amp;#039;&amp;#039;Register&amp;#039;&amp;#039;&amp;#039;- oder &amp;#039;&amp;#039;&amp;#039;FastCall&amp;#039;&amp;#039;&amp;#039;-Aufrufkonvention ist compilerspezifisch.&amp;lt;ref name=agnerfog/&amp;gt; Im Allgemeinen besagt sie, dass die ersten zwei oder drei Funktions-Argumente mit einer Größe von 32 Bit oder weniger in den Registern EAX, EDX, und möglicherweise auch ECX übergeben werden anstatt über den Stack. Die übrigen Argumente werden von rechts nach links auf dem Stack abgelegt, ähnlich wie bei cdecl. Der Borland- und Delphi-Compiler hingegen legen die übrigen Argumente wie bei der Pascal-Aufrufkonvention von links nach rechts auf dem Stack ab.&amp;lt;ref&amp;gt;[https://docwiki.embarcadero.com/RADStudio/XE3/en/Program_Control Aufrufkonventionen in Delphi]&amp;lt;/ref&amp;gt; Die Rückgabewerte werden in den Registern AL, AX, oder EAX zurückgegeben. Bei x64-Systemen werden bis zu vier Argumente mit 64&amp;amp;nbsp;bit oder weniger in speziellen Registern übergeben, der Rest auf dem Stack.&lt;br /&gt;
&lt;br /&gt;
Diese Konvention wird unter anderem im [[Linux (Kernel)|Linux-Kernel]] benutzt, um Argumente an [[System Call|System-Calls]] zu übergeben. Die System-Call-Nummer, die jeden möglichen Aufruf eindeutig bestimmt, wird im EAX-Register abgelegt, während alle Argumente an die Kernel-Funktion in den Registern EBX, ECX, EDX, ESI und EDI gespeichert werden. Müssen mehr Argumente übergeben werden, wird einfach eine [[Datenstruktur]] mit den benötigten Elementen im Speicher abgelegt und ein Zeiger auf diese als Argument an die Funktion weitergereicht.&lt;br /&gt;
&lt;br /&gt;
=== thiscall ===&lt;br /&gt;
Diese Aufrufkonvention wird für den Aufruf nicht-statischer C++-Member-Funktionen benutzt. Es gibt zwei Hauptversionen von &amp;#039;&amp;#039;&amp;#039;thiscall&amp;#039;&amp;#039;&amp;#039;, die abhängig vom Compiler und abhängig davon benutzt werden, ob die Funktion variable Argumentlisten unterstützt oder nicht.&lt;br /&gt;
&lt;br /&gt;
Beim [[GNU Compiler Collection|GCC]] ist &amp;#039;&amp;#039;&amp;#039;thiscall&amp;#039;&amp;#039;&amp;#039; fast identisch mit &amp;#039;&amp;#039;&amp;#039;cdecl&amp;#039;&amp;#039;&amp;#039;, der Aufrufer bereinigt den Stack und die Parameter werden von rechts nach links auf dem Stack abgelegt. Der Unterschied liegt im [[Methodenzeiger|&amp;#039;&amp;#039;&amp;#039;this&amp;#039;&amp;#039;&amp;#039;-Zeiger]], der als letztes Argument auf dem Stack abgelegt wird, so, als wäre er der erste zu übergebende Parameter der Funktion.&lt;br /&gt;
&lt;br /&gt;
Beim [[Microsoft Visual C++]] Compiler wird der &amp;#039;&amp;#039;&amp;#039;this&amp;#039;&amp;#039;&amp;#039;-Zeiger im ECX-Register übergeben und die aufgerufene Funktion bereinigt den Stack, es wird also wie bei der &amp;#039;&amp;#039;&amp;#039;stdcall&amp;#039;&amp;#039;&amp;#039; Aufrufkonvention verfahren. Werden hingegen variable Argumentlisten verwendet, bereinigt der Aufrufer den Stack (also wie bei &amp;#039;&amp;#039;&amp;#039;cdecl&amp;#039;&amp;#039;&amp;#039;).&lt;br /&gt;
&lt;br /&gt;
Die &amp;#039;&amp;#039;&amp;#039;thiscall&amp;#039;&amp;#039;&amp;#039;-Aufrufkonvention kann explizit nur bei Microsoft Visual C++ 2005 und späteren Versionen verwendet werden und ermöglicht den Aufruf von Elementfunktionen aus nativem Code heraus, wenn Klassen standardmäßig die &amp;#039;&amp;#039;&amp;#039;clrcall&amp;#039;&amp;#039;&amp;#039;-Aufrufkonvention verwenden (managed code).&lt;br /&gt;
&lt;br /&gt;
=== Übersichtstabelle Aufrufkonventionen ===&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Architektur  !!Aufrufkonvention !!Betriebssystem, Compiler !!Parameter in Registern !!Parameterreihenfolge auf dem Stack !!Stack wird aufgeräumt von... !!Rückgabeparameter, Kommentar&lt;br /&gt;
|-&lt;br /&gt;
|rowspan=&amp;quot;6&amp;quot;| 16 bit || cdecl || || || C  || caller ||&lt;br /&gt;
|-&lt;br /&gt;
| pascal || || ||Pascal || function ||&lt;br /&gt;
|-&lt;br /&gt;
| fastcall ||Microsoft (non-member)|| ax, dx, bx || Pascal || function || return pointer in bx&lt;br /&gt;
|-&lt;br /&gt;
|fastcall ||Microsoft (member function)|| ax, dx || Pascal || function || „this“ auf der niedrigen Stack-Address. return pointer in ax&lt;br /&gt;
|-&lt;br /&gt;
|fastcall ||[[Turbo C|Borland]] ||ax, dx, bx ||Pascal ||function || „this“ auf der niedrigen Stack-Address. return ptr auf der oberen Stack-Address&lt;br /&gt;
|-&lt;br /&gt;
|  ||[[Watcom C/C++|Watcom]] ||ax, dx, bx, cx ||C ||function ||return pointer in si&lt;br /&gt;
|-&lt;br /&gt;
|rowspan =&amp;quot;7&amp;quot;|[[IA-32|32bit]] || cdecl || || ||C ||caller ||&lt;br /&gt;
|- || stdcall || ||C ||function ||&lt;br /&gt;
|-&lt;br /&gt;
|- pascal ||Pascal || function ||&lt;br /&gt;
|-&lt;br /&gt;
| || [[GNU Compiler Collection|GNU-Compiler]] || || C ||hybrid || Stack möglicherweise auf 16 aligned.&lt;br /&gt;
|-&lt;br /&gt;
|fastcall ||Microsoft ||ecx, edx|| C ||function ||return pointer auf dem Stack falls nicht member function&lt;br /&gt;
|-&lt;br /&gt;
|fastcall ||Gnu ||ecx, edx ||C ||function ||&lt;br /&gt;
|-&lt;br /&gt;
|fastcall ||Borland ||eax, edx, ecx ||Pascal ||function ||&lt;br /&gt;
|-&lt;br /&gt;
|thiscall ||Microsoft ||ecx ||C ||function ||default für member functions&lt;br /&gt;
|-&lt;br /&gt;
| ||Watcom ||eax, edx, ebx, ecx|| C ||function ||return pointer in esi&lt;br /&gt;
|-&lt;br /&gt;
|rowspan=&amp;quot;2&amp;quot;|[[X86-64|64bit]] || Microsoft x64 calling convention&amp;lt;ref name=&amp;quot;ms&amp;quot;/&amp;gt; || Windows ([[Microsoft Visual C++|Microsoft-Compiler]], [[Intel C++ Compiler|Intel-Compiler]])|| rcx/xmm0, rdx/xmm1, r8/xmm2, r9/xmm3|| C ||caller ||Stack aligned auf 16. 32 bytes shadow space auf dem stack. Die spezifizierten 8 Register können nur für Parameter 1, 2, 3 und 4 verwendet werden (z.&amp;amp;nbsp;B. entweder rcx oder xmm0, aber nicht beide, deswegen insgesamt nur 4).&lt;br /&gt;
|-&lt;br /&gt;
|AMD64 ABI convention&amp;lt;ref name=&amp;quot;AMD&amp;quot;/&amp;gt; || Linux, BSD, Mac (Gnu-Compiler, Intel-Compiler)|| rdi, rsi, rdx, rcx, r8, r9, xmm0-7 || C || caller ||Stack aligned auf 16. Red zone unter dem Stack.&lt;br /&gt;
|}&amp;lt;ref name=agnerfog /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Einzelnachweise ==&lt;br /&gt;
&amp;lt;references&amp;gt;&lt;br /&gt;
&amp;lt;ref name=&amp;quot;agnerfog&amp;quot;&amp;gt;&lt;br /&gt;
{{Internetquelle |autor=Agner Fog |url=https://www.agner.org/optimize/calling_conventions.pdf |titel=Calling conventions for different C++ compilers and operating systems |datum=2010-02-16 |abruf=2010-08-30 |format=PDF; 416&amp;amp;nbsp;kB |sprache=en}}&lt;br /&gt;
&amp;lt;/ref&amp;gt;&lt;br /&gt;
&amp;lt;ref name=&amp;quot;msdn&amp;quot;&amp;gt;&lt;br /&gt;
{{Internetquelle |url=http://msdn.microsoft.com/en-us/library/zxk0tw93%28v=VS.80%29.aspx |titel=___stdcall |hrsg=msdn.microsoft.com |datum=2010-02-16 |abruf=2010-09-24 |sprache=en}}&lt;br /&gt;
&amp;lt;/ref&amp;gt;&lt;br /&gt;
&amp;lt;ref name=&amp;quot;AMD&amp;quot;&amp;gt;{{Literatur |Autor=Michael Matz, Jan Hubicka, Andreas Jaeger, and Mark Mitchell |Titel=System V Application Binary Interface AMD64 Architecture Processor Supplement |Verlag=Advanced Micro Devices |Datum=2010-09-03 |Sprache=en |Online=[http://www.x86-64.org/documentation/abi.pdf Online] |Format=PDF |Abruf=2010-09-26 }} {{Webarchiv|url=http://www.x86-64.org/documentation/abi.pdf |wayback=20110716085220 |text=Online |archiv-bot=2023-03-11 02:51:41 InternetArchiveBot }}&amp;lt;/ref&amp;gt;&lt;br /&gt;
&amp;lt;ref name=&amp;quot;history&amp;quot;&amp;gt;&lt;br /&gt;
{{Internetquelle |autor=Raymond Chen |url=http://blogs.msdn.com/b/oldnewthing/archive/2004/01/02/47184.aspx |titel=The history of calling conventions, part 1 |hrsg=The Old New Thing |datum=2004-01-02 |abruf=2010-09-26 |sprache=en}}&lt;br /&gt;
&amp;lt;/ref&amp;gt;&lt;br /&gt;
&amp;lt;ref name=&amp;quot;ms&amp;quot;&amp;gt;&lt;br /&gt;
{{Internetquelle |url=https://docs.microsoft.com/en-us/cpp/build/x64-calling-convention?view=msvc-170 |titel=x64 calling convention |hrsg=Microsoft |datum=2021-08-03 |abruf=2021-12-06 |sprache=en}}&lt;br /&gt;
&amp;lt;/ref&amp;gt;&lt;br /&gt;
&amp;lt;/references&amp;gt;&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Compilerbau]]&lt;br /&gt;
[[Kategorie:Unterprogramm]]&lt;/div&gt;</summary>
		<author><name>imported&gt;SchlurcherBot</name></author>
	</entry>
</feed>