Sourcecode Fortschritt



  • Version 0.0.2.31:

    - Syscall sleepMilliseconds entfernt
    - Syscall wait hinzugefügt
    - sleep und waitForTask im Userspace über den wait-Syscall implementiert
    - textColor-Syscall repariert
    - Userspace-Makefiles hängen nun auch von den statischen Bibliotheken ab -> Inkrementeller Build funktioniert besser
    - Test-Userprogramm ergänzt



  • Version 0.0.2.32:

    - APM: Implementation verbessert (Debug-Ausgaben), funktioniert aber weiterhin nicht
    - makefile: Ausgabe gekürzt, Objektdateien nun rekursiv gelöscht
    - Kleinigkeiten


  • Mod

    0.0.2.32 macht Probleme bei vbe in qemu

    Hinweis von MrX im IRC chat:
    version 0.0.2.20 - Rev: 858 hat den Schaden angerichtet.



  • Und Revision 872 behebt ihn 🙂

    Version 0.0.2.33:

    - VBE:
    --- Neue DoubleBuffer-Implementation (-> Es wird zumindest wieder ein Bild angezeigt, auf echter Hardware allerdings viel zu langsam)
    --- setDisplayStart funktionsfähig
    - GUI:
    --- Verschieben und X-Buttons nun für alle 4 Fenster
    --- Aufräumen beim Beenden
    - Maus: Anzeige nun Double-Buffer-Kompatibel, aber nur noch in GUI


  • Mod

    Wichtig:
    - Aktuelles nasm verwenden, am besten: 2.10rc4
    - "Rebuild" anstelle "Build" ausführen



  • Version 0.0.2.34:

    - Treiber für AMD PCNet III hinzugefügt.



  • Version 0.0.2.35:

    - Netzwerkschnittstelle implementiert, PCnet- und 8139-Treiber angepasst
    - Treiberansatz für RTL8168 (vermutlich auch für RTL8169 verwendbar)


  • Mod

    version = "0.0.2.36 - Rev: 875"

    ethernet.c umgebaut auf Erkennung des Ethernet Type (bei Ethernet 2):
    0x0800 IP
    0x0806 ARP

    Leider klappt das momentan nicht mit ping oder hrping, landet beides als ARP in PrettyOS, komischerweise wird dies auch in Wireshark so angezeigt.
    Bitte um Ratschläge, woran das liegen kann.



  • Version 0.0.2.37:

    - IP wird nun zur Laufzeit abgefragt


  • Mod

    version = "0.0.2.38 - Rev: 877"

    Eingabe der IP mit gets in der letzten Version führte in qemu-EHCI und auf PC zu
    #PF (page not present) at 08200837h - EIP: 0010EADBh
    in der Zeile "Attached Disks" bei RAMDisk.
    Daher wieder statische Zuordnung der IP in network.c. Eingabecode auskommentiert.
    gets steht in util.c. Die Eingabe funktioniert auch. Fehlerursache unklar.


  • Mod

    version = "0.0.2.39 - Rev: 878"

    Transmit klappt noch nicht bei rtl8139, Zwischenstand zur besseren Kontrolle des OWN Bits.


  • Mod

    version = "0.0.2.40 - Rev: 880"

    OWN Bit bei Tx von RTL8139 wird gewaltsam auf 1 gesetzt, denn nur 1->0 startet den PCI-Prozess zum Senden. Es funktioniert aber noch nicht. Fehlerursache unklar.

    Bitte um Mithilfe, damit das Senden bald klappt. 🙄


  • Mod

    version = "0.0.2.41 - Rev: 881"

    Netzwerk senden funktioniert noch nicht
    Fehler unklar
    malloc bei Tx-Puffer im Verdacht, früher hatten wir da ein statisches Array

    MrX teilt im chat mit, das rev. 873 noch mit Transmit OK arbeitet, also hat sich bei der neu implementierten Network-Schnittstelle ein Bug eingeschlichen. 🙄



  • Version 0.0.2.42:

    - Senden funktioniert wieder
    - Sendefunktion für AMD PCnet hinzugefügt


  • Mod

    Ist leider nicht funktionsfähig.

    Kleine Verbesserung bei qemu mit statischem Array. Dann sowohl bei ARP Req. als auch bei Ping Req. ein Tx OK, kommt aber nix an, auch nicht in wireshark.

    rtl8139.c:
    global:

    // Transmit
    uint8_t Tx_network_buffer[4096] __attribute__ ((aligned (4))); // Test
    

    bei install:

    // device->TxBuffer = malloc(4096, 4, "RTL8139-TxBuf");
       device->TxBuffer = Tx_network_buffer; // global array instead of malloc
    

    Bei real PC leider kein Tx OK.

    adapter-> kann durch device->device-> ersetzt werden. 😕

    Wir werden hier nochmal von der stabilen und funktionierenden Revision 873 ausgehen und in kleinen Schritten vorwärts gehen mit Tests auf einem echten PC mit RTL8139 im LAN mit Router. Das Problem entsteht beim Einbau der abstrakten Schnittstelle.



  • Version 0.0.2.43:

    - Zweiten Fehler beim Senden behoben (length & (0x3F0000 | 256<<11); war schuld)


  • Mod

    Hardware-Tests mit RTL 8139 Karte positiv. Sowohl ARP reply als auch ICMP reply bei zwei unabhängigen Testern.

    hrping -S -t IP (geht bis -s 20, bei -s 10 bricht die Hardware zusammen)

    siehe: http://linux-ip.net/html/ether-arp.html



  • Version 0.0.2.44:

    - RTL8139-Treiber überspringt nun die ersten 4 Bytes eines empfangenen Paketes (weil sie RTL8139-spezifische Daten enthalten)
    - Analyse der Pakete nach ethernet.c ausgelagert


  • Mod

    0.0.2.45 - Rev: 885

    // set transmit FIFO threshhold to 48*32 = 1536 bytes to avoid tx underrun (gefunden in open solaris)
    *((uint32_t*)(adapter->MMIO_base + RTL8139_TXSTATUS0 + 4 * rAdapter->TxBufferIndex)) = length | (48 << 16);
    

    Das OWN bit 13 wird dabei wohl automatisch auf 0 gesetzt durch die Länge, könnte man evtl. noch separat ergänzen.

    IP: 192.168.10.97


  • Mod

    0.0.2.46 - Rev: 886

    Zusätzlich zu IPv4 und ARP wurde noch IPv6 als ethernet type 0x86DD hinzugefügt bei der Analyse des Ethernet-Protokolls (ethernet.c).


Anmelden zum Antworten