AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein 32 Bit Programme auf 64 Bit Rechnern

32 Bit Programme auf 64 Bit Rechnern

Ein Thema von delphifan2004 · begonnen am 17. Nov 2005 · letzter Beitrag vom 21. Nov 2005
Antwort Antwort
Seite 2 von 2     12
NicoDE
(Gast)

n/a Beiträge
 
#11

Re: 32 Bit Programme auf 64 Bit Rechnern

  Alt 18. Nov 2005, 17:29
Zitat von tommie-lie:
Ich hatte eigentlich gehofft, von dir zu erfahren, wie die Beschränkungen der Architektur aussehen, nicht die der Windows-Prozessverwaltung. Oder bist du doch noch nicht so intim mit deinem x86-64 geworden?
Die Hoffnung stirbt zuletzt
Da es Aufgabe des Betriebssystems ist, im 64-Bit-Modus so zu tun als ob ein 32-Bit-Kernel vorhanden ist, habe ich mich nicht um die Details gekümmert.
Durch den Prozessor ist es nur dadurch limiert, dass im 64-Bit-Modus kein vm86-Modus zur Verfügung steht. Der Prozessor-Support für die Vitualisierung ist erst in den neuesten AMD64 vorhanden (aber das dürfte nur VMware interessieren).
  Mit Zitat antworten Zitat
delphifan2004

Registriert seit: 26. Nov 2004
Ort: Dresden
272 Beiträge
 
Delphi 10.3 Rio
 
#12

Re: 32 Bit Programme auf 64 Bit Rechnern

  Alt 18. Nov 2005, 23:21
Hallo!

Zitat von tommie-lie:
Es gibt keinen 16-Bit-Emulator (ntvdm) mehr!
Dann dürften auch 16 Bit Dlls aus Borland-Pascal-Zeiten nicht mehr ladbar sein, da dannn das nötige API fehlt. Hab allerdings in Delphi Funktionen wie LoadLibrary16... gefunden. Wenn ich deinen Einwurf, tommie-lie, richtig verstanden habe, gibt es diese Funktionen dann nicht mehr.

Die Dll könnte auch unter Borland Pascal so geschrieben werden, das beispielsweise Assemblerfunktionen aufgerufen werden, die mit den 32 Bit Registern
arbeiten: asm db 66h mov ax,bx, wobei durch das Byte 66h, wenn das der richtige OpCode dafür ist, dafür sorgt, das die 32 Bit, Äquivalente verwendet werden, falls der integrierte Assembler verwendet wird. Außerdem enthält Borland Pascal den Turbo-Assembler, der die Direktive .386 beherrscht, womit dann aus dem Code ein 32 Bit Programm entstht. Dann in der Dll Funktionen definieren, die in Turbo-Assembler geschrieben sind. (In der Dll Objektdatei dazulinken...).
Die Dll könnte außerdem 32Bit-Funktionen des Windows API aufrufen.
Die Dll ist doch aber dann immer noch 16 Bittig, zumindest das Ladeformat? Die Verwendung solch einer Dll wird doch sicher dann problematisch? In ihr werden zwar dann 32 Bit Funktionen aufgerufen, es gibt inzwischen auch eine 32 Bit Version des DOS Extenders von Borland Pascal, aber der BPascal Compiler erzeugt doch trotzdemnoch 16 Bit Code (16 Bit Aufrufadressen auch in Dll)? Da liege ich doch sicher richtig in der Annahme, das Borland Pascal DLLs, auch wenn sie nur 32 Bit-Funktionen aufrufen und den 32 Bittigen DOS-Extender voraussetzen, wie dann auch das übrige Programm, das die Dll verwendet, auf keinen Fall auf 64 Bit Rechnern im 32 Bit Modus laufen. Und wenn ich diese Borland Pascal Dll zusammen mit Delphi verwenden wollte, steht das Problem 16 Bittiger Aufrufadressen im Raum und außerdem die fehlenden Ladefunktionen für die 16 Bittige Dll. (LoadLibrary16,GetProcedureAddress16,...

Nun denn, ein schönes WE wünscht

Delphifan2004
  Mit Zitat antworten Zitat
DelphiSourcer

Registriert seit: 7. Feb 2005
43 Beiträge
 
Delphi 2006 Professional
 
#13

Re: 32 Bit Programme auf 64 Bit Rechnern

  Alt 19. Nov 2005, 10:23
Hallo!

Zitat von delphifan2004:
Dann dürften auch 16 Bit Dlls aus Borland-Pascal-Zeiten nicht mehr ladbar sein, da dannn das nötige API fehlt. Hab allerdings in Delphi Funktionen wie LoadLibrary16... gefunden. Wenn ich deinen Einwurf, tommie-lie, richtig verstanden habe, gibt es diese Funktionen dann nicht mehr.
Ich habe zwar noch keinen 64 Bit Rechner, aber bei allem, was ich über erfahren und gelesen habe, ist das gsnau so.

Zitat von delphifan2004:
Die Dll ist doch aber dann immer noch 16 Bittig, zumindest das Ladeformat? Die Verwendung solch einer Dll wird doch sicher dann problematisch? In ihr werden zwar dann 32 Bit Funktionen aufgerufen, es gibt inzwischen auch eine 32 Bit Version des DOS Extenders von Borland Pascal, aber der BPascal Compiler erzeugt doch trotzdemnoch 16 Bit Code (16 Bit Aufrufadressen auch in Dll)? Da liege ich doch sicher richtig in der Annahme, das Borland Pascal DLLs, auch wenn sie nur 32 Bit-Funktionen aufrufen und den 32 Bittigen DOS-Extender voraussetzen, wie dann auch das übrige Programm, das die Dll verwendet, auf keinen Fall auf 64 Bit Rechnern im 32 Bit Modus laufen. Und wenn ich diese Borland Pascal Dll zusammen mit Delphi verwenden wollte, steht das Problem 16 Bittiger Aufrufadressen im Raum und außerdem die fehlenden Ladefunktionen für die 16 Bittige Dll. (LoadLibrary16,GetProcedureAddress16,...
Ich denke mal, da liegst Du genau richtig.
Wenn Du den Quelltext von so einer Dll hast, schreib ihn Dir so um, das Du ihn mit einem 32 Bittigen Delphi übersetzen kannst. Wenn Du den Quelltext der Dll nicht hast, Pech gehabt!

Andere Frage, Wozu soll das gut sein, 16 Bittige 32 Bit Dlls zu verwenden?

Der theoretische Teil dieser Fragestellung düfte ja mit all diesen Antworten abgehandelt sein, aber ich sehe keinen praktischen Nutzen, 16 Bittige Dlls in einem 32 Bittigen Betriebssystem verwenden zu wollen.

DelphiSourcer
  Mit Zitat antworten Zitat
Benutzerbild von sakura
sakura

Registriert seit: 10. Jun 2002
Ort: Unterhaching
11.412 Beiträge
 
Delphi 12 Athens
 
#14

Re: 32 Bit Programme auf 64 Bit Rechnern

  Alt 19. Nov 2005, 11:09
Zitat von richard_boderich:
das kommt auf deine cpu an. also auf einen itanium laufen alle 32 bit programme aber arsch langsam.
Ich selbst habe leider "nur" einen 32 Bitter, aber mein Kollege hat einen 64 Bit Intel PC und dass die 32 Bit Anwendungen langsamer laufen als vorher, das kann er Dir garantiert nicht bestätigen... Das Ding ist verdammt schnell, ich will den auch haben

......
Daniel Lizbeth
Ich bin nicht zurück, ich tue nur so
  Mit Zitat antworten Zitat
xaromz

Registriert seit: 18. Mär 2005
1.682 Beiträge
 
Delphi 2006 Enterprise
 
#15

Re: 32 Bit Programme auf 64 Bit Rechnern

  Alt 19. Nov 2005, 11:52
Hallo,
Zitat von sakura:
Zitat von richard_boderich:
das kommt auf deine cpu an. also auf einen itanium laufen alle 32 bit programme aber arsch langsam.
Ich selbst habe leider "nur" einen 32 Bitter, aber mein Kollege hat einen 64 Bit Intel PC und dass die 32 Bit Anwendungen langsamer laufen als vorher, das kann er Dir garantiert nicht bestätigen... Das Ding ist verdammt schnell, ich will den auch haben

......
Dein Kollege hat aber doch keinen Itanium, oder? Wahrscheinlich eher einen P4 mit 64-Bit-Erweiterung. Das ist ja nur ein aufgebohrter 32-Bit-Prozessor, da gibt's keinen Unterschied. Nur der Itanium kann kein 32 Bit und emuliert das -> langsam.

Aber mal zur Ursprungsfrage: Nur weil in einem Programm die 8- oder 16-Bit-Register verwendet werden ist das Programm noch lange kein 16-Bit-Programm. Der Unterschied liegt primär in der Speicheradressierung und darin, dass Windows in der 64-Bit-Ausführung keine 16-Bit-Api mehr unterstützt. Der Prozessor kann die Programme selbstverständlich ausführen (es sind ja gültige Opcodes), aber die Api-Aufrufe laufen ins Leere. Unter Win9x liefen auch alle 16-Bit-Programme in einem gemeinsamen Adressraum, ich weiss aber nicht, ob das unter WinXP auch so ist.

Gruß
xaromz
  Mit Zitat antworten Zitat
tommie-lie
(Gast)

n/a Beiträge
 
#16

Re: 32 Bit Programme auf 64 Bit Rechnern

  Alt 19. Nov 2005, 12:12
Zitat von delphifan2004:
Zitat von tommie-lie:
Es gibt keinen 16-Bit-Emulator (ntvdm) mehr!
Verleumdung! Das habe ich nie geschrieben!!!elfeins

Zitat von delphifan2004:
Dann dürften auch 16 Bit Dlls aus Borland-Pascal-Zeiten nicht mehr ladbar sein, da dannn das nötige API fehlt.
So isses ooch.

Zitat von delphifan2004:
Hab allerdings in Delphi Funktionen wie LoadLibrary16... gefunden. Wenn ich deinen Einwurf, tommie-lie, richtig verstanden habe, gibt es diese Funktionen dann nicht mehr.
Ich weiß nicht, was die Funktion genau macht und wo sie herkommt, aber wenn es eine aus Win3.x mitgeschleppte API-Funktion ist, wird sie höchstwahrscheinlich nicht mehr funktionieren, richtig.

Zitat von delphifan2004:
Die Dll könnte auch unter Borland Pascal so geschrieben werden, das beispielsweise Assemblerfunktionen aufgerufen werden, die mit den 32 Bit Registern arbeiten: asm db 66h mov ax,bx, wobei durch das Byte 66h, wenn das der richtige OpCode dafür ist, dafür sorgt, das die 32 Bit, Äquivalente verwendet werden, falls der integrierte Assembler verwendet wird.
Sicher, bei deiner Registeroperation wird's vermutlich auch noch mit den 16bit-Registern funktionieren (das war die Frage, die ich an Nico stellte, aber da er sie auch nicht beantworten kann, gehe ich einfach mal davon aus, daß AMD nicht schwachsinnigerweise Beschränkungen eingebaut hat, die vollkommen unnötig sind). Aber sag erstmal dem alten TurboPascal-Linker, daß er dir eine 32bit-PE machen soll.

Zitat von delphifan2004:
Außerdem enthält Borland Pascal den Turbo-Assembler, der die Direktive .386 beherrscht, womit dann aus dem Code ein 32 Bit Programm entstht.
Mit einem modernen Assembler und Linker kriegst du auch auf einem 32bit-Prozessor ein 64bit-Programm zustande, das ist kein Kunststück.

Zitat von delphifan2004:
Die Dll ist doch aber dann immer noch 16 Bittig, zumindest das Ladeformat? Die Verwendung solch einer Dll wird doch sicher dann problematisch?
Jupp, weil Windows sich die Emulation seines alten Adressmodells gespart hat.

Zitat von delphifan2004:
Da liege ich doch sicher richtig in der Annahme, das Borland Pascal DLLs, auch wenn sie nur 32 Bit-Funktionen aufrufen und den 32 Bittigen DOS-Extender voraussetzen, wie dann auch das übrige Programm, das die Dll verwendet, auf keinen Fall auf 64 Bit Rechnern im 32 Bit Modus laufen.
Weiß ich nicht, ich weiß nicht, was der Linker kann, ich weiß nicht, was dieser 32bit-Extender macht, und ich weiß nicht, was vorher an Initialisierung durch Borlands RTL abläuft (vergl. System.pas und SysInit.pas der Delphi-RTL).


In deinem, delphifan2004, Post habe ich irgendwie keinen Widerspruch und keine Anmerkung zu Nicos Aussage gefunden, daß die ntvdm nicht mehr existiert. Oder wolltest du nur bestätigt wissen, daß eine alte 16bit-DLL, die einem Win3.x-Linker entsprungen ist, nicht mehr von einem 32bit-Programm unter WoW64 geladen werden kann? Falls ja: Nein, kann sie nicht mehr.
  Mit Zitat antworten Zitat
Benutzerbild von Mystic
Mystic

Registriert seit: 18. Okt 2003
Ort: Flerzheim
420 Beiträge
 
Turbo Delphi für Win32
 
#17

Re: 32 Bit Programme auf 64 Bit Rechnern

  Alt 19. Nov 2005, 12:57
Zitat von NicoDE:
3) Einige Systemverzeichnisse werden innerhalb von WoW64 automatisch umgeleitet. Ein 32-Bit-Programm sieht zum Beispiel C:\WINDOWS\SysWOW64 als "C:\WINDOWS\system32" (unter C:\WINDOWS\SysWOW64 liegen die DLLs der Win32-API unter C:\WINDOWS\system32 die DLLs der Win64-API). Das gleiche gilt auch für das %ProgramFiles%-Verzeichnis und andere. Um die 'Umleitung' zu umgehen muss man diese mit einer neuen API deaktivieren. Es können also nur 32-Bit-Programme auf C:\WINDOWS\system32 zugreifen wenn sie die neuen APIs kennen...
Warum haben die denn nicht das system64-Verzeichnis eingeführt und das system32 für WOW64 belassen?

64-Bit DLLs im system32-Verzeichnis. Das passt doch nicht.
Jan Steffens
Der Fachwortgenerator - 100% Schwachsinn --- Der UPnP Router Manager - Kommentare erwünscht!
  Mit Zitat antworten Zitat
delphifan2004

Registriert seit: 26. Nov 2004
Ort: Dresden
272 Beiträge
 
Delphi 10.3 Rio
 
#18

Re: 32 Bit Programme auf 64 Bit Rechnern

  Alt 19. Nov 2005, 13:45
Hallo!

Zitat von tommie-lie:
Oder wolltest du nur bestätigt wissen, daß eine alte 16bit-DLL, die einem Win3.x-Linker entsprungen ist, nicht mehr von einem 32bit-Programm unter WoW64 geladen werden kann? Falls ja: Nein, kann sie nicht mehr.
Danke. Genau um diese Bestätigung ging es mir. Habe nämlich aus dem Internet ne Grafikbibliothek (Hyper32V2) für Turbo/Borland-Pascal runtergeleden und wollte die nach Delphi portieren. Mit Delphi neu übersetzen erfordert zu viele Änderungen und die Freepascal Version setzt den DOS Extender Go32v2 voraus, und diese Unit gibt es wiederum nicht für Delphi. Und da kam mir der Gedanke mit der Dll. Funzt also nicht! Danke, Da brauch ich also nicht erst Zeit in die Enrwicklung dieser Dll investieren. Trotzdem schade. Hätte man als Grundlage für DOS Spiele nehmen können, da solche immer noch beleibt zu sein scheinen.

Schönes Wochenende wünscht Euch allen

Delphifan2004
  Mit Zitat antworten Zitat
tommie-lie
(Gast)

n/a Beiträge
 
#19

Re: 32 Bit Programme auf 64 Bit Rechnern

  Alt 19. Nov 2005, 15:07
Zitat von delphifan2004:
Habe nämlich aus dem Internet ne Grafikbibliothek (Hyper32V2) für Turbo/Borland-Pascal runtergeleden
Bei Programmer's Heaven ist als Systemvorraussetzung DOS und Win9x angegeben, würde sie überhaupt auf einem NT laufen?

Zitat von delphifan2004:
Hätte man als Grundlage für DOS Spiele nehmen können, da solche immer noch beleibt zu sein scheinen.
Die könnte man zumindest in DOSBox zum Laufen kriegen (benutze ich, um ein DOS-Spiel zu spielen, das selbst unter Win98 nicht laufen wollte). Da man allerdings mit Delphi keine reinen DOS-Anwendungen schreiben kann, müsste man dazu aber trotzdem bei TurboPascal bleiben.
  Mit Zitat antworten Zitat
NicoDE
(Gast)

n/a Beiträge
 
#20

Re: 32 Bit Programme auf 64 Bit Rechnern

  Alt 21. Nov 2005, 12:32
Zitat von delphifan2004:
Hab allerdings in Delphi Funktionen wie LoadLibrary16... gefunden. Wenn ich deinen Einwurf, tommie-lie, richtig verstanden habe, gibt es diese Funktionen dann nicht mehr.
Diese Funktion war nie Teil der dokumentierten Win32-API (sie wurde unter Win9x - davon gibt's keine 64-Bit-Version - fürs Thunking benötigt).

Zitat von Mystic:
Warum haben die denn nicht das system64-Verzeichnis eingeführt und das system32 für WOW64 belassen?
Die gleiche Diskussion gab's bei Linux (lib/lib32, lib/lib64, ...). Offensichtlich entschied man sich für die Abwärtskompatibilität, da viele Strings hart-codiert wurden (%SystemRoot%\system32 ein Klassiker...).

Zitat von delphifan2004:
Genau um diese Bestätigung ging es mir.
Dann probiere es aus, oder lass es ausprobieren...
  Mit Zitat antworten Zitat
Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

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 07:15 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