Windows 98 auf modernen Prozessoren (auch in VMs!)
Moin,
Wer wie ich, (ur-)alt-Systeme bei manchen Kunden am laufen halten muß, sei es auf echter Hardware oder in einer VM,wird früher oder später über zwei Bugs in Windows 98 stolpern, der Probleme bei "zu schnellen" Prozessoren macht, also bei aktuellen Prozessoren fast immer.
Ich bin vor einem halben Jahr bei einem Kunden, dessen Windows98-VMs ich "am Leben halte", auf das Phäonmen gestoßen, daß plötzlich beim Booten Fehlermeldungen kamen, daß DLLs nicht geladen werden konnten (z.B. mfc42.dll) oder Anwendungen nicht starten konnten. Der neue Rechner hatte Windows 11 und die VM wurde unter vmware-player 17 betrieben und warf immer diesen Fehler. manche Anwendungen gingen, andere nicht. Dieselbe VM, auf einem Windows-10-rechner mit vmware-player 12 (oder auch 17) lief ohne weiteres. Die damalige Diagnose war daher. "Mit Windows 11 gibt es Probleme!" Also möglichst bei Win10 bleiben (auf den älteren Kisten).
Nun begab es sich, daß ich dem Kunden zwei neue (Mini-)PCs mit N95-Prozessor besorgt habe, weil neue Mitarbeiter dazugekommen sind. Die waren zwar mit Win11 Pro vorinstalliert, aber das war schnell durch ein Win10-pro-Backup-Image einer "alten" Kiste ersetzt und einsatzbereit. Alles bis auf die VM funktionierte einwandfrei. Fehlerbild wie oben bei der Kiste von vor einem halben Jahr. Eine aktuelle Fehlersuche ergab, daß nicht das OS Win11 der Bösewicht ist, sondern schlicht die aktuelleren Prozessoren den Fehler verursachen. Nach Recherchen im Internet kam heraus, daß Windows 98 zwei Bugs hat, die bei "zu schnellen" Prozessoren zu speicherfehlern und auch programmfehlern führen. Der Versuch, vmware (oder virtualbox) mitzuteilen, statt dem aktuellen Host-Prozessor der VM einen legacy-Prozessor wie z.B. einem 486er, pentium oder pentium II vorzugaukeln gingen schief. bei Qemu wäre das zwar ohne Probleme möglich gewesen, wurde aber vom Kunden nicht gewünscht,. weil "umständlicher".
Letzendlich bin ich dann auf einen patch bei Github gestoßen, der divere Patches an den Systemdateien von Windows 98 vornimmt und danach Windows 98 wieder sauber läuft, sofern man das von Windows allgemein überhaupt sagen kann.
Also:
Wer Windows 98 auf modernen Prozessoren einsetzen will, sei es direkt auf Hardware oder als VM, sollte sich den patcher9x von Github herunterladen und anwenden.
Dieser Patcher behandelt sowohl den Windows 9x TLB Invalidation Bug , als auch den Windows 95/98 CPU speed limit bug.
Wichtig:
Den Patch nur auf eine Kopie der VM anwenden, so daß man as original noch hat, falls etwas schiefgeht. Und den Patch nur ein einziges mal in einer Installion anwenden, weil ansonsten der wiederholte Patch die gepatchte Dateien unbrauchbar macht.
Ich hoffe, daß dieser Tipp zukünftigen Generationen (und mir als Gedächtnistütze) hilft.
LLAP
lks
Wer wie ich, (ur-)alt-Systeme bei manchen Kunden am laufen halten muß, sei es auf echter Hardware oder in einer VM,wird früher oder später über zwei Bugs in Windows 98 stolpern, der Probleme bei "zu schnellen" Prozessoren macht, also bei aktuellen Prozessoren fast immer.
Ich bin vor einem halben Jahr bei einem Kunden, dessen Windows98-VMs ich "am Leben halte", auf das Phäonmen gestoßen, daß plötzlich beim Booten Fehlermeldungen kamen, daß DLLs nicht geladen werden konnten (z.B. mfc42.dll) oder Anwendungen nicht starten konnten. Der neue Rechner hatte Windows 11 und die VM wurde unter vmware-player 17 betrieben und warf immer diesen Fehler. manche Anwendungen gingen, andere nicht. Dieselbe VM, auf einem Windows-10-rechner mit vmware-player 12 (oder auch 17) lief ohne weiteres. Die damalige Diagnose war daher. "Mit Windows 11 gibt es Probleme!" Also möglichst bei Win10 bleiben (auf den älteren Kisten).
Nun begab es sich, daß ich dem Kunden zwei neue (Mini-)PCs mit N95-Prozessor besorgt habe, weil neue Mitarbeiter dazugekommen sind. Die waren zwar mit Win11 Pro vorinstalliert, aber das war schnell durch ein Win10-pro-Backup-Image einer "alten" Kiste ersetzt und einsatzbereit. Alles bis auf die VM funktionierte einwandfrei. Fehlerbild wie oben bei der Kiste von vor einem halben Jahr. Eine aktuelle Fehlersuche ergab, daß nicht das OS Win11 der Bösewicht ist, sondern schlicht die aktuelleren Prozessoren den Fehler verursachen. Nach Recherchen im Internet kam heraus, daß Windows 98 zwei Bugs hat, die bei "zu schnellen" Prozessoren zu speicherfehlern und auch programmfehlern führen. Der Versuch, vmware (oder virtualbox) mitzuteilen, statt dem aktuellen Host-Prozessor der VM einen legacy-Prozessor wie z.B. einem 486er, pentium oder pentium II vorzugaukeln gingen schief. bei Qemu wäre das zwar ohne Probleme möglich gewesen, wurde aber vom Kunden nicht gewünscht,. weil "umständlicher".
Letzendlich bin ich dann auf einen patch bei Github gestoßen, der divere Patches an den Systemdateien von Windows 98 vornimmt und danach Windows 98 wieder sauber läuft, sofern man das von Windows allgemein überhaupt sagen kann.
Also:
Wer Windows 98 auf modernen Prozessoren einsetzen will, sei es direkt auf Hardware oder als VM, sollte sich den patcher9x von Github herunterladen und anwenden.
Dieser Patcher behandelt sowohl den Windows 9x TLB Invalidation Bug , als auch den Windows 95/98 CPU speed limit bug.
Wichtig:
Den Patch nur auf eine Kopie der VM anwenden, so daß man as original noch hat, falls etwas schiefgeht. Und den Patch nur ein einziges mal in einer Installion anwenden, weil ansonsten der wiederholte Patch die gepatchte Dateien unbrauchbar macht.
Ich hoffe, daß dieser Tipp zukünftigen Generationen (und mir als Gedächtnistütze) hilft.
LLAP
lks
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 670326
Url: https://administrator.de/tutorial/windows-98-auf-modernen-prozessoren-auch-in-vms-670326.html
Ausgedruckt am: 24.12.2024 um 14:12 Uhr
4 Kommentare
Neuester Kommentar
Moin,
Danke für den Tipp.
Wir hatten bis vor 1,5 Jahren auch noch nen Win95 virtuell laufen. Der lies sich aber nur mit einer älteren VMware Workstation starten, aber auch nur, wenn man beim Booten ständig [Pause] + [Enter] gedrückt hatte. Die VM wurde dann stets suspended, um das nicht tagtäglich machen zu müssen.
Danke für den Tipp.
Wir hatten bis vor 1,5 Jahren auch noch nen Win95 virtuell laufen. Der lies sich aber nur mit einer älteren VMware Workstation starten, aber auch nur, wenn man beim Booten ständig [Pause] + [Enter] gedrückt hatte. Die VM wurde dann stets suspended, um das nicht tagtäglich machen zu müssen.
Hallo, danke für das Tut.
Bin froh von 2003 weg zu sein. Mixed Domäne mit 2000 DC. Gut, 98 war ja nicht für das Netzwerk.
Für Spiele findet man ja schon Projekte: https://github.com/Emupedia/emupedia.github.io/
https://emupedia.net/
Meist aber doch in einer Box und man hat nur begrenzte Möglichkeiten das OS zu steuern. Frage mich was dahintersteckt. Hab mich noch nicht genauer mit befasst. Einige haben sogar Visual Studio Code auf dem Desktop. Das werden die ja kaum mit JS oder HTML 5 alles nachgebaut haben.
Überlege gerade wie sich das verhält. Und ob man ggf. mit sowas später - wenn VM und andere Methoden nicht mehr praktikabel sind - man auf sowas ausweichen kann......
mfg Crusher
Bin froh von 2003 weg zu sein. Mixed Domäne mit 2000 DC. Gut, 98 war ja nicht für das Netzwerk.
Für Spiele findet man ja schon Projekte: https://github.com/Emupedia/emupedia.github.io/
https://emupedia.net/
Meist aber doch in einer Box und man hat nur begrenzte Möglichkeiten das OS zu steuern. Frage mich was dahintersteckt. Hab mich noch nicht genauer mit befasst. Einige haben sogar Visual Studio Code auf dem Desktop. Das werden die ja kaum mit JS oder HTML 5 alles nachgebaut haben.
Überlege gerade wie sich das verhält. Und ob man ggf. mit sowas später - wenn VM und andere Methoden nicht mehr praktikabel sind - man auf sowas ausweichen kann......
mfg Crusher