Sourcecode Fortschritt


  • Mod

    Rev. 248: ehci.c: Zwischenschritt ( zwei zusätzliche Zeitschleifen )
    Bringt aber nix, eher schlechter (Test auf meinem Entw.-PC und bei Tobiking)


  • Mod

    Rev. 249:

    Diese Version wurde mit Basis rev. 240 bei ehci.c wieder aufgebaut, da die letzten Veränderungen keinen wirklichen Vorteil brachten. Nun fährt zumindest mein "störrischer PC" nach einigen Fehlversuchen (Host System Error) in die richtige Spur. Die Details der übertragenen Daten werden nur bei length != 0 angezeigt, um den Bildschirm nicht mit Nullen zu überladen. 😉

    Cuervo - unser Cheftester - sieht keine Fehler auf seinem Test-PC. Bei Tobiking läuft es leider noch nicht.

    Hier ein Screenshot zum vergleich mit dem eigenen Ergebnis:
    http://www.henkessoft.de/OS_Dev/Bilder/rev249.PNG 🙂


  • Mod

    Rev. 250:
    - Bessere Hi-Speed-Erkennung (vs. J-State)
    - Systemfrequenz erhöht von 100 Hz auf 1000 Hz


  • Mod

    Rev. 251:

    ckernel.c, util.c: Testversion für rdtsc-Messung pro Millisekunde (Ziel: sleep ohne Interrupt)
    http://en.wikipedia.org/wiki/Time_Stamp_Counter

    64-bit register present on all x86 processors since the Pentium. It counts the number of ticks since reset. Instruction RDTSC returns the TSC in EDX:EAX.

    Test wird momentan in der Zeitanzeige der kernel-idle-loop durchgeführt, weil wir dort einen Messabstand von jeweils einer Sekunde haben.

    while( true )
    {
        //...
    
        OldRdtscValue = CurrentRdtscValue;
    
        if( CurrentSeconds != CurrentSecondsOld )
        {
            // all values 64 bit
            CurrentRdtscValue = rdtsc();
            RdtscDiffValue = CurrentRdtscValue - OldRdtscValue;
            uint64_t RdtscKCounts = RdtscDiffValue>>10; // divide by 1024
    
            uint32_t RdtscKCountsHi    = RdtscKCounts >> 32;
            uint32_t RdtscKCountsLo    = RdtscKCounts & 0xFFFFFFFF;
    
            if(RdtscKCountsHi==0)
            {
                printformat("\nRdtsc/ms: %d\n",(RdtscKCountsLo/1000)<<10 );
            }
            else
            {
                printformat("\nRdtscKCountsHi: %d RdtscKCountsLo: %d\n",
    	                       RdtscKCountsHi,    RdtscKCountsLo );
            }
            //...
        }
        //...
    }
    

    Funktioniert bestens! 🙂
    Allerdings benötigen wir da einen Mittelwert aus mehreren Messsungen, wobei man die ersten verwerfen muss, wie man im Test sehr gut sieht. Das könnten wir im EHCI-Modul einsetzen, um unabhängig vom Timer-Interrupt Delays durchführen zu können.

    Anmerkung:
    uint64_t RdtscKCounts = RdtscDiffValue>>10; // divide by 1024
    Diese Zeile anstelle direkte Division durch 1000 ist notwendig, weil der x86 hier keine Funktionen zur Verfügung stellt für unsigned long long. Die Korrektur (RdtscKCountsLo/1000)<<10 erfolgt dann auf 32-Bit-Niveau.


  • Mod

    Rev. 252:

    ckernel.c: CPU Frequenz (MHz) in Statuszeile ergänzt. Ausdruck im normalen Bildschirmbereich ausgeblendet. Bitte prüfen, ob es überall stimmt. Was passiert, wenn man PCs vor Pentium verwendet?


  • Mod

    Rev. 253:

    Zwischenschritt zum Test von delay(...µs) anstelle sleepMilliSeconds(...ms).
    Hat irgendwo noch eine Loop zuviel in ehci.c 😃


  • Mod

    Rev. 254:

    in usb2.c waren auch noch sleepMilliSeconds(...), die im INT geblockt haben.
    Zwar immer noch nicht rund, aber jetzt stimmt die Basis zum Experimentieren, zumindest halbwegs.


  • Mod

    Rev. 255:
    Zwischenlösung.
    Hauptproblem: Host System Error bei Aktivieren der asychronen Liste, der bisher nicht sicher überwunden werden kann.



  • Erhard Henkes schrieb:

    Zwar immer noch nicht rund, aber jetzt stimmt die Basis zum Experimentieren, zumindest halbwegs.

    Sorry dass ich mich nochmal einmische.
    Aber vor einigen Tagen hat jemand ein Entwicklungskit für USB empfohlen, ich glaube mit einem ARM-Prozessor. Ich vermute, dass ihr es mit sowas einfacher hättet. Wenn nicht, betrachtet dieses Posting bitte als hinfällig. 😉


  • Mod

    Rev. 256:

    Eine Version, in der jede Funktion bei EHCI und USB in der Abfolge angezeigt und mit 2 sec Pausen (delay 2000000) versehen wird, um das Debuggen zu erleichtern.

    Diese Version läuft OHNE "Host System Error" auf meinem Entwicklungs-PC hoch!

    Tobiking und Cuervo et. al.:
    Bitte testen! Bin gespannt. Tobiking hat leider immer noch unerklärlichen Host System Error.

    Wenn der Fehler auch bei euch verschwindet oder die Ursache gefunden wird, müssen wir gemeinsam heraus finden, was der wesentliche Punkt ist, um den Host System Error sicher zu vermeiden.

    @Z: das Problem liegt eher im Bereich EHCI, evtl. sogar PCI. USB liegt im Wesentlichen noch vor uns. Wir quälen uns mit EHCI, um möglichst viele Mitstreiter mitzunehmen, aber wir sind auf dem richtigen Weg, auch wenn er etwas serpentinenreich ist.


  • Mod

    Rev. 258: (Rev. 257 fehlerhaft)

    pciDev_t pciDev_Array[PCIARRAYSIZE];

    DeactivateLegacySupport(uint32_t num) mit Debug-Prints bereichert. Offenbar Problem beim "Wait for BIOS-Semaphore being not set". EHCI muss dem Pre-OS (BIOS) entrissen werden! 😉
    Wenn sowohl BIOS als OS dern HC beherrschen dürfen, muss es zwangsläufig krachen!


  • Mod

    Rev. 259:

    pci_write_byte-Fkt. korrigiert (Danke an XanClic 👍 )

    BIOS ---> OS geht jetzt bei EHCI ext. cap. 🙂

    Leider immer noch HostSystemError nach dem Einschalten der AsyncList bei meinem PC mit Ext.Cap.


  • Mod

    Rev. 260:

    usb2.c: ohne "doorbell" läuft es besser

    Interrupt on Async Advance Doorbell R/W. This bit is used as a doorbell by software to tell the host controller to issue an interrupt the next time it advances asynchronous schedule. Software must write a 1 to this bit to ring the doorbell. When the host controller has evicted all appropriate cached schedule state, it sets the Interrupt on Async Advance status bit in the USBSTS register. If the Interrupt on Async Advance Enable bit in the USBINTR register is a one then the host controller will assert an interrupt at the next interrupt threshold. See Section 4.8.2 for operational details. The host controller sets this bit to a zero after it has set the Interrupt on Async Advance status bit in the USBSTS register to a one. Software should not write a one to this bit when the asynchronous schedule is disabled. Doing so will yield undefined results.


  • Mod

    Rev. 261:

    ehci.c: Fehler in DeactivateLegacySupport korrigiert


  • Mod

    Rev. 262:

    nur kleine Veränderungen

    Der "Host System Error", der bei einigen Systemen noch kommt, kann wie folgt unterdrückt werden:

    in ehci.c, Funktion void createQH(void address, void* firstQTD, uint32_t device)*

    // uint32_t physNext = paging_get_phys_addr(kernel_pd, firstQTD);
    	// head->qtd.next = physNext;
    	/// TEST
    	head->qtd.next = 0x1;
    

    Damit sind die QTD vom QH entkoppelt. Was das bedeutet, ist bisher unklar.


  • Mod

    Rev. 263:

    ehci.c: QTD kann nun auch NULL anstelle firstQTD annehmen, damit man QH ohne QTD erzeugen kann.


  • Mod

    Rev. 264:

    ehci.c: Fehler in DeactivateLegacySupport behoben

    jetzt: if(failed){/* manueller Versuch */} <--- könnte das Problem BIOS=1 && OS=1 bei störrischem BIOS lösen. Macht es aber offensichtlich nicht (Test bei Tobiking).



  • Revision 265:

    - Hello-Programm auf 0.5 aktualisiert (kleiner Zeilenfehler behoben)
    - makefile: clear-target ergänzt, clear.bat beigelegt
    - Shell wird jetzt mit der start.asm der Usertools kompiliert
    - HELLO.ELF statt hello.elf



  • Revision 266:

    - printf -> kprintf;
    - printformat -> printf (Deswegen sind so viele Dateien geändert)
    - Das neue printf und i2hex in userlib übernommen; my_stdarg.h mit userlib mitgeliefert
    - typedefs aus os.h in userlib übernommen
    - TTT auf Version 5.1 aktualisiert (Man kann nicht mehr gewinnen und zugleich Remis spielen, mglw. Verbesserung der Lauffähigkeit auf manchen PCs)


  • Mod

    Revision 267:

    ehci.c: Vereinfachungen in der Ausgabe zur besseren Übersicht

    interrupts.asm:
    DO_IDT_ENTRY SYSCALL_NUMBER, 0x0008, 0xEE00
    DO_IDT_ENTRY CONTEXT_SWITCH_CALL, 0x0008, 0x8E00 <---

    syscall.c, video.c: nur Formatierung/Kommentare

    User-Programm: TTT (hello.elf) Zahleneingabe wird abgebrochen
    (Prompt (=Totalabbruch) bzw. unerwartete Fehlermeldung, dass Zahl bereits verwendet wird).

    Irgendwas bei der Ausführung der User-Programme ist "kaputt".
    DO_IDT_ENTRY CONTEXT_SWITCH_CALL, 0x0008, 0xEE00 hilft auch nichts, also OK.


Anmelden zum Antworten