Sourcecode Fortschritt


  • Mod

    version = "0.0.3.97 - Rev: 1298"

    ohci.h/c: noch einige Korrekturen, es hakt aber immer noch gewaltig. ^^



  • Version 0.0.3.98:

    - OHCI aufgeräumt, kleinere Fehler behoben
    - Kein #PF bei OHCI mehr, wenn usbTransferStringUnicode aufgerufen wird
    - Kein #PF bei unbekanntem Partitionstyp mehr
    - SCSI-Commands werden bis zu 5 mal wiederholt bei Fehlschlag
    - Kleinigkeiten & Codestil


  • Mod

    version = "0.0.3.99 - Rev: 1300"

    ohci.c: Ausgaben verbessert, Zeitschleifen in issueTransfer

    Hauptproblem: Device: no response to IN or no handshake (OUT). (bei Setup Transaction)


  • Mod

    version = "0.0.3.100 - Rev: 1301"

    ohci.h/c: weitere Veränderungen (hoffentlich Fehler behoben, usb läuft noch nicht)

    Wichtiger Hinweis: // #define _EHCI_ENABLE_ in os.h
    Wer den EHCI nutzen möchte, dies bitte vorher aktivieren.


  • Mod

    version = "0.0.3.101 - Rev: 1302"

    ohci.c: Ausgaben erweitert zur Kontrolle ( skip, halted in HeadPointer )
    EHCI wieder enabled


  • Mod

    version = "0.0.3.102 - Rev: 1303"

    ohci weiter entwickelt. Immer noch Fehler beim ersten TD (setup).

    VBox zeigt übrigens immer toggle 0 an, obwohl ohci.c sauber togglet. Auch buffer werden nicht angezeigt. Tests mit PCs sind aussagekräftiger.



  • Version 0.0.3.103:

    - PCNet: "Undefined error" hinter _NETWORK_DIAGNOSIS_ versteckt
    - createQTD_SETUP und createQTD_IO vereinheitlicht: Beide allokieren einen Puffer.
    - restrict zu VCcompatibility.h hinzugefügt


  • Mod

    version = "0.0.3.104 - Rev: 1305"

    ohci.c: ausgaben weiter verbessert, CLE,CLF umpositoniert, Haltestellen eingefügt für VBox Debugger


  • Mod

    version = "0.0.3.105 - Rev: 1306"

    ohci.c: buffer zusätzlich ausgegeben zur Kontrolle

    ED, TD, TD-buffer sieht alles gut aus.

    CLE als Hauptschalter

    Bei Fehler:
    - CLF (Control List Filled) auf 0
    - currentED auf 0
    - ED->HeadP Halted-Bit auf 0
    - Fehlerausgabe via condition Feld (Status)


  • Mod

    version = "0.0.3.106 - Rev: 1307"

    ohci.c: weiter optimiert (z.B. Rücksetzen des HeadPtr Halted Bit) - transfer läuft noch nicht


  • Mod

    version = "0.0.3.107 - Rev: 1308"

    ohci_ und ehci_request zu usb_request vereinigt.
    usb1.h/c gelöscht.


  • Mod

    version = "0.0.3.108 - Rev: 1309"

    ohci-Ausgaben reduziert (hinter define)

    In VBox: Device Not Responding

    http://www.ti.com/lit/ug/sprufm8/sprufm8.pdf

    The USB1.1 host controller ignores upstream traffic from downstream devices for about 3 ms after the host controller state (HCCONTROL.HCFS) changes from USB resume state to USB operational state. If any TDs cause generation of downstream packets during that time, the downstream packets are sent, but downstream device responses are ignored. Any such TDs are aborted with completion codes marked as Device Not Responding. TDs on any of the lists (periodic, control, bulk, and isochronous) can cause such an occurrence.


  • Mod

    version = "0.0.3.109 - Rev: 1310"

    ohci - Zwischenstand


  • Mod

    version = "0.0.3.110 - Rev: 1311"

    ohci.h/c: erweitert um einige Port-Funktionen analog EHCI.

    Transfer läuft aber noch nicht (Fehler: Device not responding, wie bisher)


  • Mod

    version = "0.0.3.111 - Rev: 1312"

    ohci.c: Die erste Transaktion verläuft inzwischen nach Status-Meldung erfolgreich! Nun sind wir - auch bei ohci - endlich im Thema usb angekommen. 🙂
    (ehci läuft schon lange)

    Hinweis: Wer EHCI testen will, bitte erst in os.h per define aktivieren (versehentlich noch ausgeschaltet)

    TODO: Abarbeiten der TDs analysieren unter Berücksichtigung, dass "done" TDs ausgehängt werden.


  • Mod

    version = "0.0.3.112 - Rev: 1313"

    Reihenfolge verändert/ergänzt in ohci_setupUSBDevice:

    - usbTransferDevice
    - usbTransferEnumerate
    - usbTransferDevice

    Leider schlagen irgendwo noch interrupts zu.
    Aber man sieht bei dieser Version (mit Glück), dass die In-Transaktion erfolgreich durchgeführt werden kann

    TODO: bitte helfen, den Interrupt-Fehler zu finden, damit wir wieder vernünftig testen können

    if (val & OHCI_INT_RHSC) // root hub status change
    {
      // printf("Root hub status change.");
         handledInterrupts |= OHCI_INT_RHSC;
         scheduler_insertTask(create_cthread(&ohci_portCheck, "OHCI Ports"));        
    }
    

    Hier liegt wohl ein Problem. VBox hat hier alleine schon 8 Ports.

    Weiter geht's hier:

    void ohci_portCheck()
    {
      //...
      if (o->OpRegs->HcRhPortStatus[j] & OHCI_PORT_CCS) // connected
      ohci_showPortstatus(o,j);
    

    Das Problem (Absturz VBox) beginnt hier:

    ohci_resetPort(o, j);
    

  • Mod

    version = "0.0.3.113 - Rev: 1314" (experimentelle Version)

    Verbesserte Version: Damit sieht man die ersten erfolgreichen Transaktionen (setup, in). Anschließend "freeze" (VBox muss abgeschossen werden).

    Freeze ist hier:

    o->ports[portNumber]->num = 1 + usbTransferEnumerate(&o->ports[portNumber]->port, portNumber);
    

    Korrekte Darstellung der usb-Version 01.10:

    printf("\nUSB %y.%y\t", BYTE2(usbDev->usbSpec), BYTE1(usbDev->usbSpec));
    

  • Mod

    version = "0.0.3.114 - Rev: 1315"

    ohci funktioniert! Problem ist momentan im usb-Transfer enumerate (set address)

    screenshot: http://www.henkessoft.de/OS_Dev/Bilder/rev.1315_OHCI_USB.PNG

    Endlich! 🙂

    Nun müssen wir den Freeze finden und das usb-Problem, aber das ist sicher machbar, wenn man endlich mal die übertragenen Daten sehen kann. 😃


  • Mod

    version = "0.0.3.115 - Rev: 1316"

    endlich freeze-free (delay anstelle sleep...)
    sof-check in jetziger Form gestrichen (Programm ist nicht in die while-loop eingetreten). In spec steht: "Perform SOF check" und "Time available?". Diese beiden Punkte werden bisher ignoriert.

    Probleme:
    - Bei EHCI/UHCI- oder EHCI/OHCI-Übergang "prellt" das OS, sodass schnell alle 10 Konsolen (0-9) verbraucht sind.
    - Bei OHCI klappen die IO-Transfers mit 0 byte (handshake) noch nicht (egal ob OUT oder IN)
    - OHCI und PC läuft noch nicht (freeze wegen ständiger interrupts)
    - Emulator VBox (0.4.12) auf Host Win XP bei USB völlig unzuverlässig (ehenkes)


  • Mod

    version = "0.0.3.116 - Rev: 1317"

    ohci: wieder testbar mit VBox

    if (val & OHCI_INT_RHSC) // root hub status change
    {
       // printf("Root hub status change.");
       handledInterrupts |= OHCI_INT_RHSC;
       // scheduler_insertTask(create_cthread(&ohci_portCheck, "OHCI Ports"));   
       ohci_portCheck();   
    }
    

Anmelden zum Antworten