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
Benutzerbild von Stevie
Stevie

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

AW: Inline Assembler: CALL

  Alt 12. Sep 2016, 23: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
 
#2

AW: Inline Assembler: CALL

  Alt 13. Sep 2016, 00: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
 
#3

AW: Inline Assembler: CALL

  Alt 13. Sep 2016, 09: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
 
#4

AW: Inline Assembler: CALL

  Alt 13. Sep 2016, 16: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 16: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
 
#5

AW: Inline Assembler: CALL

  Alt 13. Sep 2016, 17: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 17:16 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

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

AW: Inline Assembler: CALL

  Alt 13. Sep 2016, 23:35
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);
Das ist nicht korrekt. thiscall geht so
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
 
#7

AW: Inline Assembler: CALL

  Alt 13. Sep 2016, 23:41
So - jetzt muss ich mal wirklich ein großes Kompliment an die Aktiven hier im Forum loswerden.

Delphi ist ein Thema, bei dem man insbesondere als Anfänger gern mal stundenlang im Kreis herum googlen kann - und dabei häufig nur allgemeines Blabla, geistigen Unfug und unnütze Dinge findet, die man eh schon längst wusste.

So konkrete Antworten genau auf den Punkt wie hier im Forum, dazu noch weitergehende Vorschläge wie man das ganze noch verbessern oder eleganter lösen kann...
Was soll ich sagen - Danke und ich ziehe den Hut.. Chapeau Jungs (oder Mädels)
  Mit Zitat antworten Zitat
Benutzerbild von Zacherl
Zacherl

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

AW: Inline Assembler: CALL

  Alt 14. Sep 2016, 14:16
Das ist nicht korrekt. thiscall geht so
Hast du natürlich recht. Der Codeschnipsel von mir funktioniert nur mit Delphi-eigenen Methoden (Register-Call + versteckter This-Pointer als erstes Argument).
Projekte:
- GitHub (Profil, zyantific)
- zYan Disassembler Engine ( Zydis Online, Zydis GitHub)
  Mit Zitat antworten Zitat
Antwort Antwort


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 17:58 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz