AGB  ·  Datenschutz  ·  Impressum  







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

Multitasking Interna verstehen

Ein Thema von delphifan2004 · begonnen am 15. Jul 2020 · letzter Beitrag vom 22. Jul 2020
Antwort Antwort
Seite 1 von 3  1 23      
delphifan2004

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

Multitasking Interna verstehen

  Alt 15. Jul 2020, 08:24
Hallo, ich will mal an den API Funktionen und der Thread Klasse vorbei Multitasking "von Hand" programmieren, als ob ich ein Betriebssystem vor mir hätte, welches das nicht schon selber kann. Bill Gates, der Erfinder von Windows musste das einst auch tun, weil das alte DOS kein Multitasking konnte. So musste die gesamte Threadlogik erst geschaffen werden als Unterbau von Windows. Diese Vorgehensweise möchte ich gerne nachvollziehen. Wie sollte ich vorgehen? Ich habe für den Registers Typ diese Deklaration gefunden:

Delphi-Quellcode:
TParameters = packed record
{$IFDEF CPUX86}
    Registers: array[paEDX..paECX] of Cardinal; //gibt es da auch die Konstante paEIP?
    EAXRegister: Cardinal;
    ReturnAddress: Pointer;
{$ENDIF CPUX86}
    Stack: array[0..1023] of Byte;
  end;
In diesem Registers Array könnten also die Registerinhalte schon mal abgelegt werden. Wie komme ich aber da ran, wenn ich nicht das WinAPI zu Hilfe nehmen will, sondern so tun will, als gäbe es Windows noch gar nicht?

Ist ReturnAddress der aktuelle Befehlszählerstand?

Dann hätte ich ja schon mal eine Datenstruktur, welche meine Registerinhalte speichert, wenn ich Taskwechsel vornehmen will. Was muss ich noch beachten. Außer der Synchronisation wenn 2 Threads auf eine Zälervariable zugreifen? Allerdings 1024 Byte Stack kommt mir sehr wenig vor bei heutigen Programmen. Reicht denn das wirklich?

Ich würde Speicherbereiche für meine Programme in einer Liste verwalten welche die Startadressen hält. Dann wäre der jeweilige Befehlszählerstand ein Offset zur Anfangsadresse des Speicherbereiches. Allerdings hat jede .exe Datei ja noch einen Header vorne dran, die Startadresse folgt erst danach Was meint ihr daher zu meiner Idee?
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.861 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: Multitasking Interna verstehen

  Alt 15. Jul 2020, 09:05
Das Wegsichern der Register ist wohl das kleinste Problem beim Multitasking; um das man sich bei moderneren Prozessoren auch nicht mehr so sehr kümmern muss (Registerrenaming usw.)
Wichtiger ist es wie/wann der Prozesswechsel stattfindet (kooperativ/präemptiv; Zeitscheiben/round-robin; ...), IPC, Speicherverwaltung, Caching, ...

http://www.kolibrios.org/de/
https://github.com/vapaamies/KolibriOS
Markus Kinzler
  Mit Zitat antworten Zitat
Rollo62

Registriert seit: 15. Mär 2007
4.116 Beiträge
 
Delphi 12 Athens
 
#3

AW: Multitasking Interna verstehen

  Alt 15. Jul 2020, 09:42
Mit "kooperativ" habe ich sehr gute Erfahrungen gemacht, selbst auf 8-Bit MCUs.
Mit etwas Disziplin funktioniert das bei moderater Anferorderung and RTOS sehr gut,
und kann sogar in der realen Welt Echtzeitstuerungen übernehmen.
Größere Aufgaben in Teil-Blöcke zerlegen.

Die grobe Überlegung dahinter:
Wenn man eine Haupt-Schleife mit ca. 1 kHZ durchfahren kann, ohne irgendwo länger zu blockieren,
dann reicht das für 99.5% der Fälle im realen Leben aus.
Selbst wenn die 1 kHz nur mit +/- 20% erreicht werden.
Weil die reale Welt da draussen eben nicht so schnell durchläuft, Sensoren nicht so schnell liefern und Aktoren nicht so schnell schalten, ...
  Mit Zitat antworten Zitat
Benutzerbild von Sinspin
Sinspin

Registriert seit: 15. Sep 2008
Ort: Dubai
691 Beiträge
 
Delphi 10.3 Rio
 
#4

AW: Multitasking Interna verstehen

  Alt 15. Jul 2020, 12:50
Ich habe auch als DOS und Assembler Programmierer angefangen und mir sowas selber gebaut. Als ich dann was unter Windows machen musste kam ich mir vor wie kastriert.
Was da damals in den CPUs implementiert wurde um multithread handling auf CPU Ebene zu ermöglichen halte ich noch immer für eine der genialsten Erfindungen in der Geschichte der Computertechnik.

Um Heutzutage selber das Threadingverhalten zu implementieren würde bedeuten dass Du einen Thread dann aufteilen würdest. Ansonsten müsstest Du auf Kernelebene runter. Und der wird dich nicht lassen.
Was allerdings interessanter wäre, eine Routine zu schreiben die mit einem Ausfürungspfad die Zeitschnipsel verschiedener Threads vereint. Kann mir nicht vorstellen dass das geht.
Stefan
Nur die Besten sterben jung
A constant is a constant until it change.
  Mit Zitat antworten Zitat
delphifan2004

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

AW: Multitasking Interna verstehen

  Alt 15. Jul 2020, 19:33
Ich werde also erst mal probieren Datenstrukturen zu bauen und dann wie ein Kind rumprobieren um erste Erfahrungen zu sammeln.
  Mit Zitat antworten Zitat
TiGü

Registriert seit: 6. Apr 2011
Ort: Berlin
3.070 Beiträge
 
Delphi 10.4 Sydney
 
#6

AW: Multitasking Interna verstehen

  Alt 15. Jul 2020, 23:36
Ich werde also erst mal probieren Datenstrukturen zu bauen und dann wie ein Kind rumprobieren um erste Erfahrungen zu sammeln.
Du könntest natürlich auch erstmal dich in das Thema einlesen und versuchen zu verstehen, wie das bspw. in Windows gelöst ist.
Beispiel:
https://www.codeproject.com/Articles...Windows-Thread
  Mit Zitat antworten Zitat
HintByError

Registriert seit: 13. Dez 2018
Ort: Marburg
21 Beiträge
 
Delphi XE2 Professional
 
#7

AW: Multitasking Interna verstehen

  Alt 16. Jul 2020, 14:22
Zu beachten ist, dass die Maschineninstruktionen des Prozessors zur Implementierung von Threads privilegiert sind. Das heißt, dass eine Windows-Anwendung nicht auf diese Instruktionen zugreifen darf. Diese Instruktionen darf nur das Betriebssystem verwenden.
Wolfgang Sauer
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

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

AW: Multitasking Interna verstehen

  Alt 16. Jul 2020, 21:20
Der Record den du da oben gepostet hast hat rein gar nichts mit Multitasking zu tun sondern stammt aus System.ObjAuto.pas und ist für die Parameterübergabe beim dynamische Aufrufen von Methoden. Die 1024 Byte da reichen für mehr Parameter als man jemals an eine Methode übergibt.
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

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

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

AW: Multitasking Interna verstehen

  Alt 16. Jul 2020, 21:58
Ich werde also erst mal probieren Datenstrukturen zu bauen und dann wie ein Kind rumprobieren um erste Erfahrungen zu sammeln.
Du könntest natürlich auch erstmal dich in das Thema einlesen und versuchen zu verstehen, wie das bspw. in Windows gelöst ist.
Beispiel:
https://www.codeproject.com/Articles...Windows-Thread
... und mit Threads programmieren wie das unter Windows gemacht wir. Klar! Danke für den Link. Habe auch schon Michael Puff's Seite aufgesucht und dort auch Dokus gefunden über Win-API und auch über Threads mit Delphi ist ein Tutorial dabei. Das wäre dann erst mal die Verwendung der Threadlogik wie sie in Windows implementiert ist. Danach will ich aber weiter. Und lernen wie das "unter der Haube" gemacht wird. Das API ist ja nur das Interface dazu.

Zitat von HintByError:
Zu beachten ist, dass die Maschineninstruktionen des Prozessors zur Implementierung von Threads privilegiert sind. Das heißt, dass eine Windows-Anwendung nicht auf diese Instruktionen zugreifen darf. Diese Instruktionen darf nur das Betriebssystem verwenden.
Danke für den wichtigen Tipp. Dann wird das ja innerhalb von Windows schwierig umzusetzen. Mit Delphi ein Programm schreiben wird da nicht so einfach weil das ja auf Windows läuft.

Zitat von Stevie:
Der Record den du da oben gepostet hast hat rein gar nichts mit Multitasking zu tun sondern stammt aus System.ObjAuto.pas und ist für die Parameterübergabe beim dynamische Aufrufen von Methoden. Die 1024 Byte da reichen für mehr Parameter als man jemals an eine Methode übergibt.
Wie speichere ich denn da die aktuellen Registerinhalte vor dem Taskwechsel? Dafür wollte ich diese Struktur verwenden. Oder gibt es da in der CPU eine Methode? Ich habe eine AMD Athlon(tm) II X2 B24 CPU mit 2 Kernen je 3 GHz. Das ist aber meine konkrete CPU. Wenn ich aber mit meinem Entwurf auch auf anderen CPUs Erfolg haben will? Habe noch einen älteren Rechner mit Pentium 400MHz.

Welche Taskwechselmechanismen gibt es da auf der CPU Serie X86? WO finde ich Dokus dazu? Die möglichst auch verständlich geschrieben sind für einen der sowas noch nie gemacht hat?

Das Buch Programmierhandbuch 80386/80486 von Claßen der Reihe Technische Informatik vom Verlag Technik Berlin besitze ich bereits. Wahrscheinlich aber brauche ich noch mehr Infos als in diesem Buch zu finden.

Geändert von delphifan2004 (16. Jul 2020 um 22:16 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.184 Beiträge
 
Delphi 12 Athens
 
#10

AW: Multitasking Interna verstehen

  Alt 16. Jul 2020, 22:40
Statt das alles selber zu machen, oder um da bissl abzugucken, würde ich empfehlen sich mal die Fiber anzusehn.
Im Prinzip machen die genau das, was du willst.

https://docs.microsoft.com/en-us/win...d/using-fibers


Und sogar die neue Threading-API im Delphi hat mit TTask und TFuture etwas, was vom Verhalten dem sehr nah kommt.
Delphi-Referenz durchsuchenSystem.Threading
$2B or not $2B

Geändert von himitsu (16. Jul 2020 um 22:43 Uhr)
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 3  1 23      


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 22:48 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