AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Inline Assembler: CALL

Ein Thema von Amicello · begonnen am 12. Sep 2016 · letzter Beitrag vom 14. Sep 2016
Antwort Antwort
Seite 1 von 2  1 2      
Amicello

Registriert seit: 12. Sep 2016
13 Beiträge
 
#1

Inline Assembler: CALL

  Alt 12. Sep 2016, 18:33
Hallo,

seit einigen Tagen hat mich Delphi als Programmiersprache begeistert, ganz einfach durch den Inline Assembler.
Leider scheitert es an scheinbar trivialen Dingen:
z.B. bei soetwas:

push eax
call 006F0B4F

Hier meldet der Compiler beim Call: "error in numeric constant"

call $006F0B4F
Compiler meldet: "invalid combination of opcode and operand"

call 0x006F0B4F
Compiler meldet: "invalid combination of opcode and operand"

call 006F0B4Fh
Compiler meldet: "invalid combination of opcode and operand"


Wie macht man es denn in Delphi nun richtig?
Ein Freund der schon länger mit der Sprache arbeitet, macht es so mit einem Umweg:

mov ecx,$006F0B4F
Call ecx

Das funktioniert - kann aber nicht der Weisheit letzter schluss sein.
Hier muss es doch eine korrekte Schreibweise für absolute Addresssen geben.
Kann hier jemand weiterhelfen?

Geändert von Amicello (12. Sep 2016 um 18:36 Uhr)
  Mit Zitat antworten Zitat
Amicello

Registriert seit: 12. Sep 2016
13 Beiträge
 
#2

AW: Inline Assembler: CALL

  Alt 12. Sep 2016, 18:44
Oh sehe gerade, dass ein CALL ebenso wie ein JMP relativ zum EIP addressiert wird.
Das ganze soll eine DLL zum Injecten in ein bestehendes Programm werden, und da der Compiler nicht wissen kann, wo die Originalroutine in Bezug auf die compilierte DLL im Speicher sitzt bleibt wohl nur die Lösung über den Umweg. Oder hat noch jemand eine andere Idee?
  Mit Zitat antworten Zitat
Benutzerbild von Zacherl
Zacherl

Registriert seit: 3. Sep 2004
4.629 Beiträge
 
Delphi 10.2 Tokyo Starter
 
#3

AW: Inline Assembler: CALL

  Alt 12. Sep 2016, 20:06
In Delphi ist "$" das Prefix für hexadezimale Darstellung und nicht "h" als Suffix.

Es gibt kein CALL ABS im X86 Assembler. Calls und Jumps sind immer relativ. Höchstens CALL [ADDR] ist noch möglich.
Projekte:
- GitHub (Profil, zyantific)
- zYan Disassembler Engine ( Zydis Online, Zydis GitHub)
  Mit Zitat antworten Zitat
Amicello

Registriert seit: 12. Sep 2016
13 Beiträge
 
#4

AW: Inline Assembler: CALL

  Alt 13. Sep 2016, 00:41
Jau.. genauso hab ich das jetzt auch umgesetzt. Ich habe die CALL-Adressen als Konstante definiert.
Die fertige DLL hab ich mir dann mal mit einem Debugger in der Praxis angesehen.

Delphi scheint das nicht als absolute Konstante im Programmcode zu verwursten, sondern legt schön eine 4-Byte breite Variable mit dem Wert als Inhalt an. In dem Fall recht praktisch!
Im Endprodukt steht dann ein CALL [xxxxxxxx] mit der Delphi-Internen Adresse der Variablen, dessen Inhalt dann auf das gewünschte Ziel zeigt. Passt!

Vielleicht nicht die eleganteste Lösung, aber funktioniert - und man braucht nicht den Umweg über ein zusätzliches Register.


const
adr_00845C55 : DWORD = $00845C55;

(...)

ASM
CALL [adr_00845C55]
END;
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

Registriert seit: 12. Aug 2003
Ort: Soest
4.016 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#5

AW: Inline Assembler: CALL

  Alt 13. Sep 2016, 00:45
Delphi scheint das nicht als absolute Konstante im Programmcode zu verwursten, sondern legt schön eine 4-Byte breite Variable mit dem Wert als Inhalt an.

Delphi-Quellcode:
const
  adr_00845C55: DWORD = $00845C55;
Das liegt daran, dass du hier eine sogenannte Typisierte Konstante deklariert hast.
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight
  Mit Zitat antworten Zitat
Amicello

Registriert seit: 12. Sep 2016
13 Beiträge
 
#6

AW: Inline Assembler: CALL

  Alt 13. Sep 2016, 01:25
Das liegt daran, dass du hier eine sogenannte Typisierte Konstante deklariert hast.
Ja.. da hab ich mich auch schon versucht etwas einzulesen. Speicherzugriffe mit PDWORD Variablen(^) sind auch herrlich bequem.
Irgendwann werd ich mich wohl auch noch dran gewöhnen wo man ein ";" setzt und wo nicht
Nur mit der IDE steh ich noch auf Kriegsfuß (Stichwort TABS, Zeilenende) .. aber ich denke das wird auch.
  Mit Zitat antworten Zitat
Benutzerbild von Zacherl
Zacherl

Registriert seit: 3. Sep 2004
4.629 Beiträge
 
Delphi 10.2 Tokyo Starter
 
#7

AW: Inline Assembler: CALL

  Alt 13. Sep 2016, 10:11
Falls du lieber auf inline-Assembly verzichten willst, geht sogar Folgendes:
Delphi-Quellcode:
type
  TFunctionPointer = function(A, B, C: Integer): Integer; stdcall;

// Aufruf
TFunctionPointer($00401234)(1, 2, 3);
Je nachdem was für Funktionen du aufrufst, musst du natürlich schauen, ob die überhaupt einer Standard Calling-Convention (stdcall, cdecl, etc.) folgen. Falls nicht, kommst du um den Assembler-Code wohl nicht herum.
Projekte:
- GitHub (Profil, zyantific)
- zYan Disassembler Engine ( Zydis Online, Zydis GitHub)
  Mit Zitat antworten Zitat
Amicello

Registriert seit: 12. Sep 2016
13 Beiträge
 
#8

AW: Inline Assembler: CALL

  Alt 13. Sep 2016, 17:40
Falls du lieber auf inline-Assembly verzichten willst, geht sogar Folgendes: (...)
Interessanter Ansatz!
Manche Programmfunktionen erfordern zusätzlich zum PUSH'en der Paramenter aber auch noch bestimmte Suchverweisen, Kriterien etc. z.B. in den Registern EAX/ECX. Da muss ich dann in die Assemblertrickkiste greifen, aber trotzdem danke für deinen Tipp!
Ich werde den sicherlich an der ein oder anderen Stelle mit einbauen.

Geändert von Amicello (13. Sep 2016 um 17:40 Uhr) Grund: ,
  Mit Zitat antworten Zitat
Benutzerbild von Zacherl
Zacherl

Registriert seit: 3. Sep 2004
4.629 Beiträge
 
Delphi 10.2 Tokyo Starter
 
#9

AW: Inline Assembler: CALL

  Alt 13. Sep 2016, 18:13
Also thiscall (ECX = Pointer zur Objektinstanz) ist auch ohne Assembly möglich:
Delphi-Quellcode:
type
  TFunctionPointer = function(A, B, C: Integer): Integer of object;

// Aufruf
var
  Method: TMethod;
begin
  Method.Code := Pointer($00401234); // Adresse der Funktion
  Method.Data := Pointer($00749624); // Adresse der Objektinstanz
  Result := TFunctionPointer(Method)(1, 2, 3);
Ich glaube lediglich fastcall (und natürlich alle nicht-standard Conventions) wird von Delphi nicht unterstüzt.
Projekte:
- GitHub (Profil, zyantific)
- zYan Disassembler Engine ( Zydis Online, Zydis GitHub)

Geändert von Zacherl (13. Sep 2016 um 18:16 Uhr)
  Mit Zitat antworten Zitat
Amateurprofi

Registriert seit: 17. Nov 2005
Ort: Hamburg
1.057 Beiträge
 
Delphi XE2 Professional
 
#10

AW: Inline Assembler: CALL

  Alt 13. Sep 2016, 22:18
[QUOTE=Zacherl;1347473]In Delphi ist "$" das Prefix für hexadezimale Darstellung und nicht "h" als Suffix.QUOTE]

Das stimmt nicht.
Du kannst zum Beispiel schreiben
mov eax,$123
mov eax,123H (Hex)
mov eax,123O (Octal)
mov eax,0101B (Binär)
Gruß, Klaus
Die Titanic wurde von Profis gebaut,
die Arche Noah von einem Amateur.
... Und dieser Beitrag vom Amateurprofi....
  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 11:51 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