Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Delphi 8051 Emulator in Delphi programmieren (https://www.delphipraxis.net/115151-8051-emulator-delphi-programmieren.html)

DelphiManiac 6. Jun 2008 20:15


8051 Emulator in Delphi programmieren
 
Ich habe zurzeit ein sehr anspruchsvolles Projekt,
von dem ich mir ein paar Tipps von euch erhoffe.

Folgendes soll entwickelt werden:

- Ein Delphi Programm, dass sich so verhält als wäre es ein Embedded 8051 Programm, das auf einer Hardware läuft.

Ich will das mal näher erläutern:

Es gibt ein Hardware, die z.B.: eine USB Schnittstelle hat, diese Hardware macht verschiedene Sachen (Berechnungen, Ein/Ausgänge, ...etc)
Auf der Hardware läuft eine Software die das übernimmt.

Zur Parametrierung des Gerätes gibt es eine PC-Software, die mit dem Gerät kommuniziert.

Jetzt soll ein Programm entwickelt werden, dass das in Software abbildet.

Also quasi, dass die PC-Sofware nicht mit dem Gerät sondern mit dem EMU kommuniziert, dass aber gar nicht wissen muss/soll.

Wie kann man eine solche Software erstellen, welche Kommunikation nutzt man an der Stelle? Hängt man sich zwischen den USB-Verkehr?

Danke schonmal
Gruß

BullsEye 6. Jun 2008 21:23

Re: 8051 Emulator in Delphi programmieren
 
Ich wage fast zu bezeifeln, das das möglich ist. Zumindestens nicht in Delphi.
Mit Delphi ist es nicht möglich die Hardware anzusprechen, und auch wenns ein Emulator ist, musst du deinem PC ja vorgaukeln, es sei Hardware. Also Treibermäßig.

Some Info ;)

divBy0 6. Jun 2008 21:45

Re: 8051 Emulator in Delphi programmieren
 
Du willst doch den 8051 µController von Intel simulieren, oder?

Hab eben mal gesucht, hier gibt es vielleicht etwas, was die weiterhelfen kann:

jsim

DelphiManiac 6. Jun 2008 22:07

Re: 8051 Emulator in Delphi programmieren
 
Vielleicht habe ich mich auch zu kompliziert ausgedrückt :-) :lol:

Also mein Delphi Prog soll eigentlich nur die Funktionalität abbilden, die das Gerät hat.

Beispiel:

PC-Software fragt Gerät nach dem aktuellen Temperatur
- Gerät antwortet 120 °C

PC-Software fragt EMU nach dem aktuellen Temperatur
- EMU antwortet 120 °C

so ungefähr, da ist nur die Frage, wie sollen die 2 Applikationen miteinander kommunizieren, sind Windows Messages da sinvoll,
oder was gibt es dort für Möglichkeiten?

Danke!

oki 6. Jun 2008 22:31

Re: 8051 Emulator in Delphi programmieren
 
ich bin mir nicht sicher ob es passt, aber mit DUnit kannst du super Testroutinen schreiben. Ein Emulator ist das aber nicht.

Gruß oki

DGL-luke 7. Jun 2008 01:34

Re: 8051 Emulator in Delphi programmieren
 
Ja, dazu muss der Emulator so tun, als wäre er das Gerät. Er muss also zu Windows gehen, und sagen, "Hallo, ich bin ein Treiber, ich gehöre zu einem Systemgerät".

Ein Programm, das sowas tut, nennt man dann Systemgerätetreiber.

Weil da aber jeder kommen könnte, und Hardware prinzipiell ein wenig sensibel ist, sagt Windows, da könnt' ja jeder kommen, und sagen er is n Treiber, und Blue Screens und/oder hardwaredefekte bauen.

Und darum müssen Treiber in den Kernelmode, und dazu müssen Sie ein paar Bedingungen erfüllen, insbesondere muss direkt irgendwo in der Datei stehen, "Hallo Windows, ich bin ein Trieber, bitte hab mich lieb", und das geht mit Delphi nicht.

...das heißt, gehen tuts vom Prinzip her schon, wenn man das selber reinschreibt; aber das will keiner, und wenn aber du wirklich willst, musst du mal Olli oder Assarbad fragen (:zwinker:), und die werden dir dann erstmal sagen, dazu brauchst du das DDK, oder das WDK, und C solltest du flüssig schreiben können, und C++ auch, und dann klatschen Sie dir noch den 1000seitigen 686er-Befehlssatz in die Hand, wenn du gar keine Ruhe gibst (aber pssst, den braucht man eigentlich garnicht).

Wer also mit Delphi Treiber schreiben will, der muss es mit C schon können, und wer mit C Treiber schreiben kann, für den gibt es absolut keinen Grund, es mit Delphi zu machen.

Der Weg zum eigenen Gerätetreiber ist sehr steinig, und in der Delphi-Welt gibts es dazu leider kaum Hilfe :(

PS: ...gibt es in Vista nicht schon usermode treiber?

hanspeter 7. Jun 2008 08:08

Re: 8051 Emulator in Delphi programmieren
 
Zitat:

Zitat von DelphiManiac
Ich habe zurzeit ein sehr anspruchsvolles Projekt,
von dem ich mir ein paar Tipps von euch erhoffe.

Das geht mit Delphi problemlos.
Ich kenne einige Emulatoren, die in Delphi geschrieben sind. (z.B. Atmel).
Ich selbst habe so etwas mal für eine B@R Power Panel Steuerung geschrieben.
Hier war die gesamte Oberfläche in Delphi geschrieben und die eigentliche Prozess-Steuerung in Strukturiertem Text (SPS).
Für den 8051 sollte man einen Quelltext für die Simulation der CPU wohl noch im Internet finden.

Es wird praktisch die CPU des 8051 emuliert. I/O ist letztendlich auf feste Speicheradressen gemappt.
Hier setzt die Emulation an.
Ein zweites Programm versorgt diese Speicheradressen mit Daten. Die können entweder simuliert oder
über Harware (war bei mir immer Rs232) bereitgestellt werden.
Das ist asynchron und auch mit Delphi möglich.
Es gibt komerzielle Produkte die diese Aufgabe komplett lösen. Die sind aber nicht billig.
Man darf sich allerdings über den Aufwand nicht täuschen. Die Emulation einer 8051 CPU sollte noch recht schnell gehen.
Wo der Aufwand entsteht ist dann die ganze Debuging-Geschichte.
Ist das eigentliche 8051 Programm in Assembler geschrieben, ist das noch recht einfach. Bei einer Hochsprache z.B. C
entsteht mit dem Mapping Quelltext - Speicherstelle einiger Aufwand.
Etwas Aufwand entsteht dadurch, das ein gewisses Timing beim Bereitstellen von Daten auf dem Speicherabbild beachtet werden
muß.
Übrigens ein kleiner Geheimtip.
Für Steuerungen auf so kleinen Prozessoren, setze ich auch heute noch gerne Forth ein. Kennt das noch wer?


Gruß Peter

sx2008 7. Jun 2008 08:16

Re: 8051 Emulator in Delphi programmieren
 
Zitat:

Zitat von DelphiManiac
Also mein Delphi Prog soll eigentlich nur die Funktionalität abbilden, die das Gerät hat.

Das bedeutet aber, dass es nicht nötig (und auch nicht sinnvoll) ist, 8051 Code zu emulieren.
Irgendein Gerät hängt an einer USB-Schnittstelle und das gilt es per Software nachzubilden.

Angenommen, du könntest die PC-Software überreden nicht per USB sondern über TCP/IP zu kommunizieren, dann wäre dein Problem mit Delphi gut zu lösen.
Wenn die PC-Software aus deiner Feder kommt, wäre das kein Problem.
Andernfalls wird es schwierig: wie kann man eine USB-Schnittstelle per Software simulieren, die es hardwaremässig gar nicht gibt?

DGL-luke 7. Jun 2008 10:03

Re: 8051 Emulator in Delphi programmieren
 
Zitat:

Zitat von sx2008
Andernfalls wird es schwierig: wie kann man eine USB-Schnittstelle per Software simulieren, die es hardwaremässig gar nicht gibt?

Gerätetreiber.

@hanspeter: du löst aber noch nicht das problem, wie fremdsoftware, die ein USB-Gerät erwartet, mit dem Emulator kommunizieren soll. dazu bräuchte man dann einen gerätetreiber.

Apollonius 7. Jun 2008 11:28

Re: 8051 Emulator in Delphi programmieren
 
Warum hookst du nicht einfach CreateFile, ReadFile und CloseHandle?


Alle Zeitangaben in WEZ +1. Es ist jetzt 10:34 Uhr.
Seite 1 von 2  1 2      

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