AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Delphi Diverse Fragen zum Assembler Operator call
Thema durchsuchen
Ansicht
Themen-Optionen

Diverse Fragen zum Assembler Operator call

Ein Thema von OLLI_T · begonnen am 18. Nov 2003 · letzter Beitrag vom 18. Nov 2003
Antwort Antwort
Seite 1 von 2  1 2      
OLLI_T

Registriert seit: 13. Okt 2003
Ort: Nähe Wetzlar / Hessen
143 Beiträge
 
Delphi 5 Enterprise
 
#1

Diverse Fragen zum Assembler Operator call

  Alt 18. Nov 2003, 12:18
Mahlzeit Leute!

Neues Thema, neues Glück. Hier sind so ein Paar sehr gute Leute unterwegs; das muss man nutzen.

Ich möchte ganz allgemein fragen, was ich bei einem Methoden- bzw. Funktionsaufruf aus einer Assembler-Klassenmethode heraus zu beachten habe. Das die ersten beiden Übergabeparameter - sofern vorhanden - ins EDX bzw. ECX Register geladen werden müssen ist klar!

1. Ich habe das Register EAX benutzt und somit ist der Zeiger auf das Objekt Self verloren gegangen. Muss ich vor einem Methodenaufruf das Register wiederherstellen oder passiert das automatisch?

2. Wie bewerkstellige ich die Übergabe von mehr als zwei Parameter. Genau diese Problematik steht mir nämlich nun bevor.

Ein konkretes Beispiel soll die Fragestellung verdeutlichen. Die Funktion Horzline soll via call aufgerufen werden:

Procedure TDIBSection24.HorzLine(X1,X2,Y:DWord); Der Assembler Code dazu wird dann etwa so aussehen:

Delphi-Quellcode:
Var SicSelf:TDIBSection24; XStart,XEnd,YPos:DWord;
  asm
    mov SicSelf, eax // Ist das notwendig?
    push ecx
    push edx
    mov eax, SicSelf // Ist das notwendig?
    mov edx, XStart
    mov ecx, XEnd
    // Wie definiere ich Parameter "Y"?
    Call HorzLine
    pop ecx
    pop ecx
Vielen Dank schon mal und guten Hunger.

OLLI
No Pain No Gain!
  Mit Zitat antworten Zitat
choose

Registriert seit: 2. Nov 2003
Ort: Bei Kiel, SH
729 Beiträge
 
Delphi 2006 Architect
 
#2

Re: Diverse Fragen zum Assembler Operator call

  Alt 18. Nov 2003, 12:23
Hallo OLLI,

irgendwann einmal hatte ich eine verdammt gute Ausarbeitung, die nicht nur mehrere Parameter, Methoden und Datentypen wie Double zu diesem Thema, sondern ebenfalls das ShortString-Handling als Funktionsergebnis behandelte. Leider verbummelt.

Habe das nur überflogen, aber vielleicht hilft es: http://thunder.prohosting.com/~whiskey7/issue02.htm
gruß, choose
  Mit Zitat antworten Zitat
choose

Registriert seit: 2. Nov 2003
Ort: Bei Kiel, SH
729 Beiträge
 
Delphi 2006 Architect
 
#3

Re: Diverse Fragen zum Assembler Operator call

  Alt 18. Nov 2003, 12:43
Hallo OLLI,

das hatte ich vergessen:
Zitat von OLLI_T:
1. Ich habe das Register EAX benutzt und somit ist der Zeiger auf das Objekt Self verloren gegangen. Muss ich vor einem Methodenaufruf das Register wiederherstellen oder passiert das automatisch?
Der Code (das Verhalten), der hinter einer Methode liegt, ist statisch und wird von allen Exemplaren einer Klasse (und ggf deren Erben) geteilt. Die Exemplarvariablen (der Zustand) des Objekts wird durch diese Methoden ggf verändert. Hierzu muss die Methode "wissen", wo die Daten liegen.
Wenn Du nun die Methode Foo aus der Methode Bar heraus aufrufst, c:= Self.Foo(a,b); erwartet Foo die selben Parameter, als wenn Du die Methode als Klient aufrufst c:= AnObject.Foo(a,b); (inkl des impliziten Parameters, der Referenz auf das Objekt).
Der Code ist in beiden Fällen identisch, allerdings könnte ein anderes Objekt gemeint sein, diese Information "steckt in EAX" und kann auch nicht vom Compiler zur Übersetzung Aufrufs generiert werden (schließlich ist ihm unbekannt, für welches Objekt Bar aufreufen wurde).
Vielleicht hast Du im Debugger schon einmal die Aussage "Auf Self kann aus Optimierungsgründen nicht zugegriffen werden" gelesen? Der Compiler hat hier erkannt, das die Referenz nicht länger benötigt wird und brauchte sie vorher auch nicht auf dem Stack ablegen. Wenn Du die "Referenz auf Self" verlierst, kannst Du weitere Methoden nicht länger korrekt aufrufen.

Anmerkung:
Sofern die Methode (und alle aus ihr aufgerufenen) den Zustand des Exemplars nicht liest oder verändert, ist es problemlos, undefinierte Werte in EAX zu übergeben.

Ich hoffe das war nicht zu wirr...
gruß, choose
  Mit Zitat antworten Zitat
OLLI_T

Registriert seit: 13. Okt 2003
Ort: Nähe Wetzlar / Hessen
143 Beiträge
 
Delphi 5 Enterprise
 
#4

Re: Diverse Fragen zum Assembler Operator call

  Alt 18. Nov 2003, 14:32
HY Choose!

OK, also werde ich EAX brav in Ruhe lassen bzw. sichern, sofern ich noch ne weitere Klassenmethode aufrufen möchte! Das mit der Optimierung und Self wird damit auch verständlich.

Dann könnte ich eigentlich ausführlich schreiben:

  Call [EAX].HorzLine Das entspricht dann in Pascal:

  Self.HorzLine(XStart,XEnd,Y); Das mit der Parameterübergabe ist mir allerdings trotz des guten Links noch nicht ganz geläufig. Die Daten müssen auf den Stack und gemäß der Standardaufrufkonvention register von links nach rechts. Somit muss ich mein Beispiel von eben wohl in dieser Art erweitern:

Delphi-Quellcode:
Var SicSelf:TDIBSection24; XStart,XEnd,YPos:DWord;
  asm
    mov SicSelf, eax // Das muss sein!
    push ecx
    push edx
    mov eax, SicSelf // Das muss sein!
    mov edx, XStart
    mov ecx, XEnd
    push Y
    Call HorzLine
    pop Y
    pop edx
    pop ecx
Werde das mal testen, ob ich damit hinkomme! Dir noch einen schönen Nachmittag.

OLLI
No Pain No Gain!
  Mit Zitat antworten Zitat
Benutzerbild von negaH
negaH

Registriert seit: 25. Jun 2003
Ort: Thüringen
2.950 Beiträge
 
#5

Re: Diverse Fragen zum Assembler Operator call

  Alt 18. Nov 2003, 15:00
Self sollte in EAX stehen, muß aber nicht unbedingt. Wenn zB. die aufgerufene Methode statisch ist und keinerlei Zugriffe auf Self macht und keine weiteren Methoden aufruft, dann wird Self nicht benötigt. Dies ist aber extrem selten der Fall.
In EAX in einer Methode steht also entweder das Object selber, oder aber bei Klassenmethoden der Klassentyp der Klasse.

Nun, je nachdem was für eine Methode aufgerufen wird unterscheidet sich der Assembler:

Delphi-Quellcode:

type
  TMyObject = class
    
    procedure StaticMethod;
    procedure VirtualMethod; virtual;
    procedure DynamicMethod; dynamic;
    class procedure ClassDynamicMethod; dynamic;
  end;

asm
   CALL TMyObject.StaticMethod

   MOV EDX,[EAX]
   CALL DWord Ptr [EDX + VMTOffset TMyObject.VirtualMethod]

   PUSH ESI
   MOV ESI,DMTIndex TMyObject.DynamicMethod
   CALL System.@CallDynaInst

   MOV ESI,DMTIndex TMyObject.ClassDynamicMethod
   CALL System.@CallDynaClass
   
   POP ESI
end;
Es ist also sinnvoll in Assembler sich auf statische Methoden zu beschränken, da auch DMTIndex und VMTOffset nicht in jeder Delphi Version definiert sind.

Man sieht auch sehr schön das überschriebene Methoden "override" ein Problem darstellen können. Haben wir eine Objectdeklaration in der überschriebene Methoden vorkommen, so wissen wir nicht, ohne die Basisklassen zu kennen, ob es eine virtuelle oder dynamische Methode ist. Somit wissen wir dann auch nicht nach welcher Art & Weise wir im Assembler vorzugehen haben.

Gruß Hagen

PS: übrigens kann man das in der Hilfe zur Inline Assemblersyntax nachlesen
  Mit Zitat antworten Zitat
Benutzerbild von negaH
negaH

Registriert seit: 25. Jun 2003
Ort: Thüringen
2.950 Beiträge
 
#6

Re: Diverse Fragen zum Assembler Operator call

  Alt 18. Nov 2003, 15:05
Willst du sichergehen, und denoch schnell un effizient auf virtuelle/dynamische methoden zugreifen so gehts auch so:

Delphi-Quellcode:
var
  M: procedure of object;
begin
  M := Self.DynaMethod;
  asm
    MOV EAX,M.Data
    CALL M.TMethod.Code
  end;
end;
Gruß hagen
  Mit Zitat antworten Zitat
choose

Registriert seit: 2. Nov 2003
Ort: Bei Kiel, SH
729 Beiträge
 
Delphi 2006 Architect
 
#7

Re: Diverse Fragen zum Assembler Operator call

  Alt 18. Nov 2003, 15:10
Zitat von negaH:
PS: übrigens kann man das in der Hilfe zur Inline Assemblersyntax nachlesen
Danke für den Tipp Hagen, dort steht ua:
Zitat:
Typbezeichner können zur einfachen und schnellen Erstellung von Variablen verwendet werden. Die folgenden Anweisungen erzeugen denselben Maschinencode, der den Inhalt von [EDX] in das Register EAX lädt:
Code:
MOV    EAX,(TRect PTR [EDX]).B.X
MOV    EAX,TRect([EDX]).B.X
MOV    EAX,TRect[EDX].B.X
MOV    EAX,[EDX].TRect.B.X
Wir wissen's inzwischen ja aber besser

Hast Du vielleicht ein Dokument der Art, wie ich es verloren habe und OLLI weiterhelfen könnte ("Parameterübergabe und Ergebnisrückgabe in Delphi aus Sicht der Maschine")?
gruß, choose
  Mit Zitat antworten Zitat
choose

Registriert seit: 2. Nov 2003
Ort: Bei Kiel, SH
729 Beiträge
 
Delphi 2006 Architect
 
#8

Re: Diverse Fragen zum Assembler Operator call

  Alt 18. Nov 2003, 15:17
@OLLI: ...Und wenn Du einmal "fast" die Lösung sehen willst, wie die "Referenz auf Self" automatisch geladen wird, guck Dir mal
Delphi-Quellcode:
{ Standard window procedure }
{ In    ECX = Address of method pointer }
{ Out   EAX = Result }

function StdWndProc(Window: HWND; Message, WParam: Longint;
  LParam: Longint): Longint; stdcall; assembler;
asm
   //...
        MOV EAX,[ECX].Longint[4]
        CALL [ECX].Pointer
        ADD ESP,12
        POP EAX
end;
an und verfolge, wie denn nun tatsächlich der Wert nach ECX kommt...
Lustige Variante, die insbesondere deshalb Interessant weil seit D5 unverändert und die Adresse von WndProc des Fensterhandles "von außen" ermittelbar ist
gruß, choose
  Mit Zitat antworten Zitat
Benutzerbild von negaH
negaH

Registriert seit: 25. Jun 2003
Ort: Thüringen
2.950 Beiträge
 
#9

Re: Diverse Fragen zum Assembler Operator call

  Alt 18. Nov 2003, 15:22
Zitat:
Lustige Variante, die insbesondere deshalb Interessant weil seit D5 unverändert
Seit D1 ist sie schon so. Sie hat aber auch den Nachteil das die nötigen Daten in Speicherblöcken die mit GlobalAlloc() alloziert wurden abgelegt sind. Das so allseits bekannte 8k Speicherloch in DLL's mit VCL Controls rührt daher. Denn dieser Minimalblock kann bei der Terminierung einer solchen DLL nicht autom. freigegeben werden, ohne das dabei mit schweren Abstützen zu rechnen ist.

Gruß Hagen
  Mit Zitat antworten Zitat
choose

Registriert seit: 2. Nov 2003
Ort: Bei Kiel, SH
729 Beiträge
 
Delphi 2006 Architect
 
#10

Re: Diverse Fragen zum Assembler Operator call

  Alt 18. Nov 2003, 15:34
Zitat von negaH:
Seit D1 ist sie schon so.
Habe mit einer D1->D3 Migration mit Delphi begonnen, um meine Arbeiten dann mit einer D3->D5 Migration fortzusetzen...

Dort bin ich erst auf diese und ähnliche Verfahren aufmerksam geworden, die man auch nutzen kann, um Win32-API-CallBacks auf Methoden inkl des Zustands eines beliebigen Objekts zu "weiterzuleiten"...

Noch einmal meine Frage, Hagen : Hast Du zum Thema "Parameterübergabe und... mit ASM", "Nette Dinge, die man mit ASM und Delphi hinbekommt", "Pitfalls using Delphi and ASM" etc. Artikel oder sonstige Beiträge, die das Thema zusammenhängend darstellen?
gruß, choose
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 16:45 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz