Sourcecode Fortschritt


  • Mod

    version = "0.0.2.188 - Rev: 1031"

    - kleine Änderungen in tcp.c und types.h (connectionID)
    - bei receive FIN,ACK (geht bei browser.c) werden testweise die Pakete in der IN-Queue angezeigt: Seq, len, data (funktioniert!)


  • Mod

    version = "0.0.2.188 - Rev: 1032"

    - irc angepasst, damit ein zufälliger Name (Pretty+Zufallszahl) gebildet wird.

    - Pretty14309 joined
    <Pretty14309>hi
    <ehenkes>test
    - Pretty14309 quit (Client exited)

    - Pretty17705 joined
    <Pretty17705>schon wieder da ^^
    - Pretty17705 quit (Connection reset by peer)

    - Pretty19370 joined
    ...
    - Pretty19370 quit (Connection reset by peer)


  • Mod

    version = "0.0.2.188 - Rev: 1033"

    Hinweis von Kollegen aus #lost auf die Pflicht, sich mit QUIT zu entfernen.
    “A client session is ended with a quit message.”

    Dem kommen wir gerne nach. Kostet aber schon wieder zwei Zeilen.;)

    case KEY_ESC:
    {
        char* msgQuit = "QUIT\r\n";
        tcp_send(connection, msgQuit, strlen(msgQuit));
        tcp_close(connection);
        return(0);
    }
    

    - Pretty31812 joined
    <Pretty31812>test auf quit
    - Pretty31812 quit (Life is too short...)

    - Pretty28547 joined
    <Pretty28547>nochmal jetzt mit ESC weg
    - Pretty28547 quit (Life is too short...)


  • Mod

    version = "0.0.2.189 - Rev: 1034"

    - memcpy, memset nun schneller (MrX)
    - irc.c (Nummernausgabe weg)



  • Version 0.0.2.190:

    - console.c: Bugfix: console_clear ändert Textfarbe nicht mehr.
    - memshow: Bugfix bei count%16!=0: Darstellung korrigiert.
    - memsetl durch memset ersetzt (Performance-Hack nicht mehr nötig)
    - optimiertes memset/memcpy auch im Userspace, memsetw ebenfalls optimiert
    - Shell:
    -- Bugfix: Eingabezeile nun korrekt gelöscht.
    -- Bugfix: Cursorposition wird zurückgesetzt, wenn Eintrag mit Pfeiltaste nach unten gelöscht wird.
    - Kleinigkeiten


  • Mod

    version = "0.0.2.191 - Rev: 1036"

    Steuerungsmechanismus window mittels Feedback aus event_issue testweise installiert, um Erfahrung zu bekommen.


  • Mod

    version = "0.0.2.192 - Rev: 1037"

    Gesamtgröße der TCP-Daten in der Event-Queue bestimmt


  • Mod

    version = "0.0.2.193 - Rev: 1038"

    Versuchsweise Steuerung des sliding window mit der Gesamtmenge an TCP-Data (bytes) in der Event Queue des task.


  • Mod

    version = "0.0.2.194 - Rev: 1039"

    tcp ausgaben stark vereinfacht


  • Mod

    version = "0.0.2.195 - Rev: 1040"

    Fehler in TCP korrigiert (z.B. window Steuerung)


  • Mod

    version = "0.0.2.196 - Rev: 1041"

    Eigenes Ping, also ICMP_echoRequest, eingebaut, und Empfang auf den ICMP_echoReply erweitert. leider funktioniert das auf der VM Qemu bisher noch nicht. Daher sollte man zunächst auf Hardware testen.

    Hier das Ergebnis auf strg+p:

    case 'p':
    {
      IP_t destIP; // www.henkessoft.de
      destIP.IP[0] =    82; destIP.IP[1] =   100; 
      destIP.IP[2] =   220; destIP.IP[3] =    68;
    
      network_adapter_t* adapter = network_getFirstAdapter();
      if (adapter)
      {
        ICMP_echoRequest(adapter, destIP);
      }
      break;
    }
    

    Folgendes tauscht dann als Analyse des Echos in PrettyOS wieder auf:

    ICMP_echoReply:  ID: AFFE seq: 1 
    PrettyOS ist das Betriebssystem der Projektgru
    ppe "OS-Development" im deutschsprachigen C++-Forum ...
    

    (Anmerkung: string wird noch nicht korrekt ausgelesen. Zeichen danach?)

    aus wiki: Das „Daten“-Feld kann jedoch auch dazu missbraucht werden, um Nutzdaten zu übertragen (ICMP-Tunneling). 😉 Werbung für PrettyOS und c++.de 😉
    hrping hat Cäsars de bello Gallico als Datensatz. 😃

    Macht man dies mit dem qemu hack, so taucht beim Versuch des Erreichens des Host-Subnets eine ICMP Botschaft in wireshark auf, die wir bisher noch nicht analysieren: "destination unreachable".

    264 27.444422 10.0.2.15 192.168.1.1 ICMP 2187 Echo (ping) request id=0xaffe, seq=1/256, ttl=128
    265 27.444593 10.0.2.2 10.0.2.16 ICMP 120 Destination unreachable (Port unreachable)

    ICMP bietet hiermit einen vielleicht guten Weg, um das qemu subnet 10.0.2.x und den Zusammenhang zum Host subnet (hier 192.168.1.x) zu analysieren und qemu so einzurichten, dass wir letztendlich auch unter Windows auf den störenden qemu hack verzichten können.

    siehe: http://de.wikipedia.org/wiki/Internet_Control_Message_Protocol



  • Version 0.0.2.197:

    - BL1 und BL2: Code aufgeräumt/optimiert, Hotfixes gesichtet und ggf. entfernt.
    - memcpy, memset und memsetw weiter verbessert; Zwei Bugs entfernt.
    - Weitere Funktionen in Standardlib implementiert


  • Mod

    version = "0.0.2.198 - Rev: 1043"

    - ICMP weiter vervollständigt

    strg+p: wir versuchen uns selbst zu "pingen": http://www.henkessoft.de/OS_Dev/Bilder/rev.1043_ICMP_PING.PNG "Destination port unreachable"

    Anmerkung: der ARP request erscheint sinnlos.


  • Mod

    version = "0.0.2.199 - Rev: 1044"

    - Kleine Korrekturen im Netzwerkbereich


  • Mod

    version = "0.0.2.200 - Rev: 1045"

    - #defines ... in os.h getestet und Fehler beseitigt (nun können alle geöffnet werden. Code compiliert, aber das Programm ist nicht mehr wirklich lauffähig. 😉 )
    - icmp.c Zahlen gegen die defines ausgetauscht aus icmp.h
    - Ausgaben bei Netzwerk verfeinert (z.B. nur eigenes tcp-window beim Senden)
    - tcp-window-Steuerung verbessert

    TODO: tcp In-Buffer freigeben nach Weitergabe an die Application


  • Mod

    version = "0.0.2.200 - Rev: 1046"

    starwars:
    Bildschirmlöschen eingebaut (vielleicht muss man noch Pakete zusammenfassen)


  • Mod

    version = "0.0.2.201 - Rev: 1047"

    - NetBIOS hinzugefügt
    - tcp Out Buffer versuchsweise verwendet (log-Fkt. eingebaut)
    - strg+p pingt jetzt 10.0.2.x (x = 0 ... 254)


  • Mod

    version = "0.0.2.202 - Rev: 1048"

    Fehler korrigiert in tcp.c, der zu #PF führte (malloc ...)

    tcp_showOutBuffers(connection,true); <--- testweise in tcp.c, zeile 460


  • Mod

    version = "0.0.2.203 - Rev: 1049"

    Netzwerk: Fehlerbeseitigung, Verfeinerung


  • Mod

    version = "0.0.2.204 - Rev: 1050"

    bei tcp_showOutBuffers werden bereits per ACK bestätigte Daten grün und die anderen braun angzeigt.

    Idee: Die grün angezeigten Daten können gelöscht werden, weil bereits angekommen und bestätigt. Die braun angezeigten Daten werden nach einer gewissen Zeit erneut gesendet. Hierbei wird keine Sinnfrage gestellt.


Anmelden zum Antworten