Sourcecode Fortschritt


  • Mod

    version = "0.0.2.138 - Rev: 977"

    - arp_sendRequest korrigiert
    - arp_waitForReply geändert


  • Mod

    version = "0.0.2.139 - Rev: 978"

    - arp_sendRequest eingebaut in DHCP ACK options
    - qemu HACK dort eingebaut
    aber es läuft noch nicht rund, qemu gar nicht mit TCP wegen der nun fehlenden MAC-Adresse des gateways des externen routers, an den qemu/TAP nicht ran kommt. Da muss wohl ein MAC-HACK her wie vorher.

    In findConnection (tcp.c) ist auch noch ein blöder HACK für passive open im ersten recveive schritt.


  • Mod

    version = "0.0.2.140 - Rev: 979"

    - QEMU_HACK (in network.h zusammen mit externer router MAC definiert) eingebaut in ipv4.c beim Senden
    - tcpConnection_t* findConnectionID(uint32_t ID) neu eingeführt (zur Brückung strg+w und strg+x)
    - QEMU HACK aus DHCP entfernt
    - strg c listet nun incl. ID und Adresse auf


  • Mod

    version = "0.0.2.141 - Rev: 980"

    Fehler behoben in tcp.c bezüglich Übergabe des Ports an findConnection(...)

    Es gibt nun drei Versionen:
    - tcpConnection_t* findConnectionID(uint32_t ID)
    - tcpConnection_t* findConnectionListen(network_adapter_t* adapter)
    - tcpConnection_t* findConnection(uint8_t IP[4], uint16_t port, network_adapter_t* adapter)

    Es wird nun jeweils die qemu-Version von mir ins Repo gestellt. Bitte daran denken, die router-MACs in network.h anzupassen (qemu HACK). Man erhält diese mittels arp -a, evtl. vorher den router pingen, wenn er noch nicht im arp cache steht. 🙂

    Die Zuordnung der empfangenen Pakete zu den connections sollte nun recht gut klappen.

    Probleme:
    - strg c (connection list) ohne \n am Ende
    - telnet daten empfang macht probleme (ACK passt nicht?? Funktionierte aber schon gut)


  • Mod

    version = "0.0.2.142 - Rev: 981" 🙂

    Veränderungen in ckernel.c und tcp.c, die durch Suchen der passenden Verbindung helfen, dass die Experimente gelingen.

    Wichtig: Hinzufügen von ESTABLISHED als Parameter bei findConnection(...).

    Probieren Sie folgendes aus: (bitte MACs für Ihren externen Router zum Internet anpassen)

    Mehrfach strg+w drücken. Hierdurch werden zu meiner Homepage mehrere Verbindungen geöffnet, allerdings nur die erste wird auf ESTABLISHED gesetzt. Die anderen sitzen auf SYN_SENT. Wenn Sie nun strg+x drücken wird die angesprochene HTML-Datei gezogen und die Verbindung anschließend geschlossen. Daraufhin wird die nächste connection von SYN_SENT auf ESTABLISHED gesetzt (einige Sekunden warten). Das geht immer so weiter (mit strg+c die connections auflisten), bis keine HTTP-Verbindung mehr vorhanden ist. Dann erfolgt auf strg+x hin eine Fehlermeldung. Sie können auch beliebig passive LISTEN Sockets eröffnen. Diese kann man ebenfalls auf diese Weise mit z.B. telnet (gelingt bisher nur bei Hardware Tests) "abarbeiten".

    Diese Version zeigt die Möglichkeiten, wie man mehrere Verbindungen beispielhaft strukturieren kann, und die Abläufe, wenn man sich mit der gleichen Client-IP mit mehreren Verbindungen (verschiedene Port-Nummern) auf dieselbe Datei auf einem HTTP-Server (im Internet) aufsetzt. 🙂

    Sonstiges:
    copy_kernel_bin_to_floppy.bat wurde hinzugefügt:

    xcopy /y kernel\kernel.bin a:\kernel.bin
    

    Beschleunigt das Erstellen von Floppydisks bei Reihenversuchen, bei denen nur kernel.bin verändert wird.

    Bedienungshinweise:
    strg+w: baut HTTP-Verbindung auf zu meiner Homepage (ESTABLISHED)
    strg+x: zieht den HTML Text. Die Verbindung wird geschlossen
    strg+b: erstellt LISTEN socket (wartet auf SYN von außen)
    strg+c: listet alle Verbindungen auf

    qemu batch: qemu.exe -fda FloppyImage.img -soundhw pcspk -net nic,model=pcnet,addr=1A,macaddr=00:12:12:12:12:12 -net tap,ifname=TAP2 -net user -localtime

    wichtig: -net user


  • Mod

    version = "0.0.2.143 - Rev: 982"

    - bei qemu wird DHCP_Discover nun übergangen in network.c
    - unwichtige Korrektur in tcp.c

    Die Verbindung mit strg+w klappt nicht immer zuverlässig.


  • Mod

    version = "0.0.2.143 - Rev: 983"

    Farbwerte aus video.h eingesetzt.


  • Mod

    version = "0.0.2.144 - Rev: 984"

    Neues Farbschema eingefügt.



  • Version 0.0.2.145

    - Stack Trace implementiert
    - Ausgabe bei Exceptions verbessert
    - Kleinigkeiten



  • Version 0.0.2.146:

    - Textausgabe gemeinsam mit ehenkes verbessert



  • Version 0.0.2.147:

    - Ausgaben (hauptsächlich im Netzwerkcode) zusammen mit ehenkes wesentlich verbessert.


  • Mod

    version = "0.0.2.148 - Rev: 988"

    - Ausgabe-Fehler in tcp.c behoben


  • Mod

    version = "0.0.2.149 - Rev: 989"

    Netzwerk-Ausgaben weiter verfeinert, dass man IPs, MACs, TCP flags klar erkennt, bei connections nur noch die ID anstelle der längeren und bedeutungslosen Adresse. Man kann nun auch Empfang und Senden von Paketen besser erkennen.

    Dank an MrX für die Unterstützung bei der Einleitung der Umgestaltung der Ausgabe!

    Man erkennt nun auch merkwürdige Adressierungen klar, z.B. den nicht funktionierenden DHCP Ablauf in qemu oder wenn Nachzügler-Pakete an offenbar zu rasch (ohne time_wait) gelöschte Verbindungen geschickt werden. 😉


  • Mod

    version = "0.0.2.150 - Rev: 990"

    SEQ und ACK Nummern in Host-Format umgewandelt zum Speichern, Rechnen und als Parameter

    Anmerkung:
    qemu version, bitte router MAC in network.h anpassen an eigene Daten.



  • Version 0.0.2.151:

    - IP_t als Typ für IPs geschaffen (union, Zugriff auf Integer-Repräsentation mit .iIP, auf die uint8t[4]-repräsentation mit .IP). (Fukanos Tipp).
    - USB-Ausgabe gekürzt
    - Bugfix in Floppy-Motorsteuerung: Motor wird wieder ausgestellt, nachdem ein Screenshot erstellt wurde
    - Heap besser mit Mutexen geschützt
    - F12 als Alias für PrintScreen bei Screenshots (-> Bessere Kompatibilität mit Emulatoren)
    - Hack für Qemu verbessert: MAC des Qemu-Gateways statt des externen Gateways angegeben (Ehenkes Tipp)


  • Mod

    version = "0.0.2.152 - Rev: 992"

    - qemu IP/MAC statisch in arp cache hinzugefügt
    - Korrektur in ethernet.c für _NETWORK_DIAGNOSIS_
    - Ausgabe bei arp_sendRequest für gesuchte IP
    - DHCP_Discover gestrichen bei qemu (wirklich?), dafür 10.0.2.15 eingestellt in network.h
    - beep off


  • Mod

    Tipp für Testumgebung qemu (von taljeth):
    **-net dump,file=xyz.pcap (hinterher mit wireshark öffnen)
    **
    aktueller qemu batch:

    qemu.exe  -fda FloppyImage.img -soundhw pcspk -net nic,model=rtl8139,addr=1A,macaddr=00:12:12:12:12:12 -net tap,ifname=TAP2 -localtime -net user -net dump,file=netdump.pcap
    

    Eigene Erfahrungen: Bridge TAP/LAN macht wenig Sinn, gibt Probleme mit -net user. Ohne -net user geht es nicht, dann bleibt alles stecken nach dem ersten Senden, keine Antwort an PrettyOS.


  • Mod

    version = "0.0.2.153 - Rev: 993"

    - struct zur Speicherung von Daten während des Empfangs über die verschiedenen Protokolle hinweg eingebaut (bisher gesammelt: senderMAC, senderIP).
    - ACHTUNG: Änderung in network.h

    Mit Qemu wurde bisher kein vollständiges DHCP erreicht, was selbst bei Hardware ohne Probleme verlief.

    EDIT: diese version macht auch mit Test-PC Probleme. Ursache wird ermittelt. 🙄


  • Mod

    version = "0.0.2.154 - Rev: 994"

    - DHCP Request wieder auf BROADCAST Flag umgerüstet (nur damit läuft der Test-PC).

    Committed wurde die Qemu-Version.


  • Mod

    version = "0.0.2.154 - Rev: 995"

    Wir verzichten nun in Qemu auf das DHCP Discover (network.c). Damit erhalten wir von lästigen DHCP-Paketen freie und wirklich interessante Wireshark-Protokolle (pcap), die man direkt mit wireshark aus dem Internet als Vergleich zu eigenen Versuchen öffnen kann.

    Hier ein Beispiel mit strg+w (Handshake mit Homepage) und strg+x (Daten laden, Verbindung ordnungsgemäß schließen). Hier wirkt vor allem der Host zusätzlich mit, so dass wir davon lernen können, wie man es richtig macht. 🙂

    http://www.henkessoft.de/OS_Dev/wireshark_captions/rev.995_netdump.pcap

    Es kam letzt die Frage auf, ob 00-12-12-12-12-12 eine gültige MAC-Adresse ist (The first 3 byte of each MAC address are assigned to a specific vendor.). Sie ist es in der Tat:

    http://www.base64online.com/mac_address.php?mac=00%3A12%3A12
    Mac address: 00:12:12 Vendor: Plus PLUS Corporation


Anmelden zum Antworten