Sourcecode Fortschritt
-
0.0.4.133 - Rev: 1520
usb:
if (usbDev->usbSpec == 0x0100 || usbDev->usbSpec == 0x0110 || usbDev->usbSpec == 0x0200 || usbDev->usbSpec == 0x0201 || usbDev->usbSpec == 0x0210 || usbDev->usbSpec == 0x0213 ||usbDev->usbSpec == 0x0300)
eine Menge gültiger deviceBCDs
-
Version 0.0.4.134:
- Changelog und TODO für nächstes Release hinzugefügt
- xHCI:
-- Status-Transactions für In und Out
-- Überflüssiges delay in xhci_portCheck() entfernt
-- inBuffer/inLength auf 0 gesetzt in xhci_outTransaction()
- Codeformatierung korrigiert
-
0.0.4.135 - Rev: 1522
xhci: Sonderfall SET_ADDRESS - xhci sendet hier einen Command - in die xhci-Transactions verlagert. Anstecken eines Sticks und Auslesen weiterer Daten klappt nun. Noch stark experimentell.
-
0.0.4.136 - Rev: 1523
xhci: Ablauf weiter verbessert, DEBUGs für die Funktionen eingebaut zur besseren Übersicht.
-
0.0.4.137 - Rev: 1524
xhci: wir verwenden für den pEP-Index DCI-1!
Also pEP[0] für EP1Eingesteckt hochfahren => EP0 state = 0!
Später anstecken => EP0 state = 1!Nun muss man nur noch herausfinden, wo der EP0 state von 0 auf 1 umspringt bzw. nicht.
Eingesteckt hochfahren => EP0 state = 0!
portCheck
detectDeviceUSB: GET_DESCRIPTOR Device
xhci_setupTransfer
before Xfer: slot: 4, EP0 state: 0,
xhci_setupTransaction. req = 6 loVal = 0
setEnqueueXfer
xhci_inTransaction
setEnqueueXfer
xhci_outTransaction
setEnqueueXfer
xhci_issueTransfer
Doorbell at slotNr.: 4
setEnqueueXferPtr
ringDoorbellDevice slot: 4 target: 1
Broken free (file: kernel/storage/xhci.c, line: 1298, addr: 0000000Ah)
after Xfer: slot: 4, EP0 state: 0,
Completion: Success Port:4 c:1 type:Port Status Change
- - - - - - - - - - - press key - - - - - - - - - - -
Invalid USB version 00.20!
- - - - - - - - - - - press key - - - - - - - - - - -Später anstecken => EP0 state = 1!
portCheck
detectDeviceUSB: GET_DESCRIPTOR Device
xhci_setupTransfer
before Xfer: slot: 4, EP0 state: 1,
xhci_setupTransaction. req = 6 loVal = 0
setEnqueueXfer
xhci_inTransaction
setEnqueueXfer
xhci_outTransaction
setEnqueueXfer
xhci_issueTransfer
Doorbell at slotNr.: 4
setEnqueueXferPtr
ringDoorbellDevice slot: 4 target: 1
Broken free (file: kernel/storage/xhci.c, line: 1298, addr: FFFFFFFFh)
after Xfer: slot: 4, EP0 state: 1,
Completion: Success Port:4 c:1 type:Port Status Change
Completion: Success Port:4 c:1 type:Port Status Change
Completion: EP Not Enabled c:1 type:xHC Event
Completion: EP Not Enabled c:1 type:xHC Event
Completion: Success slot:4 EP:1 ED:0 XferLen:0 c:1 type:Xfer Event
- - - - - - - - - - - press key - - - - - - - - - - -
USB 02.10
endpoint 0 mps: 64 byte.vendor: 0BDAh
product: 0301h release number: 01.29
manufacturer: 0001h product: 0002h
serial number: 0003h number of config.: 1
numInterfaceMSD: 255- - - - - - - - - - - press key - - - - - - - - - - -
-
0.0.4.138 - Rev: 1525
xhci: portsEnabled flag eingebaut für den reset-Vorgang in detectDevice.
vmware reagiert nun endlich mit den bereits angesteckten usb-devices.
Beim test-PC gibt es mit bereits beim Hochfahren angesteckte usb-devices noch Probleme (attached, but not enabled).
-
0.0.4.139 - Rev: 1526
xhci.c: experimentelle Version
-
0.0.4.140 - Rev: 1527
xhci: enablePorts in prepareSlots umbenannt. Resetvorgang zur Verbesserung der Transparenz nur noch in detectDevice, in prepareSlots gestrichen.
Der eigentliche EnablePort/Device-Vorgang erfolgt durch Reset des Ports.
vmware: klappt
test-PC: Port Power (PP), aber kein PED (Port Enabled Detect)
-
0.0.4.141 - Rev: 1528
xhci.h/c: Modul mit Erfahrungen der letzten Versionen verbessert.
Aktuell: vmware und test-PC starten usb-Transfer mit angehängtem Stick, beim test-PC klappt der nachträgliche Attach nicht (PP, aber kein PED nach Reset)
-
0.0.4.142 - Rev: 1529
xhci: neue Funktion showStates(...)
vmware: klappt
test-PC: angehängt Hochfahren klappt prinzipiell.
test-PC: späteres Einstecken: PLS 7 -> 9 (hot reset) ??? PED klappt nicht.
-
Version 0.0.4.143:
- Ineffizientes byteweises Lesen und Schreiben im FAT-Treiber eliminiert; Unnötige Schreib-/Lesevorgänge entfernt
- Fehlende Initialisierungen von TDBuffer in xHCI ergänzt
- Fehlerkorrektur im Floppytreiber: Floppy läuft nun auch in Bochs 2.6.2
- Fehlerkorrektur im Devicemanager: Motor nach Schreibvorgängen abgeschaltet
- Kleine Codestil-Korrekturen
- NextRelease.txt ergänzt
-
0.0.4.144 - Rev: 1531
xhci: Ablauf verbessert. Address Cmd mit BSR=1 in detectDevice ermöglicht beim test-PC den Port Link State - Übergang von 7 nach 0 (ohne: 7 nach 9). Damit ist nun ein Setzen des PED im PORTSC beim späteren Anstecken eines Sticks möglich.vmware: reset und usb Ablauf ok
test-PC:
angesteckt hochfahren: reset OK, usb-Ablauf OK bzw. nicht OK (device abhängig)
später anstecken: reset OK, usb-Ablauf OK
-
0.0.4.145 - Rev: 1532
xhci.h/c: CmdRing- u. TransferRing Management aufgebaut bez. LinkTRB (in beide stellt die Software TRBs ein)
TODO:
- Auf Richtigkeit prüfen
- HACK mit Ringzeiger beseitigen (phys./virt. Address)
- EventRing Management analog aufbauen (dort stellt der xHC TRBs ein)
- Mehrere Transferringe und Eventringe ermöglichen
-
0.0.4.146 - Rev: 1533
video.c: Korrektur bez. writeInfo(...)
xhci.h/c: Ring Management weiter ausgebaut (Cmd u. Transfer klappt, Event noch nicht)
*(xhci-Fehler: delay anstelle sleep schafft Probleme in detectDevice)
*
-
0.0.4.147 - Rev: 1534
xhci.h/c: delay durch sleep ersetzt. DEBUG erweitert für event-ring
vmware klappt wieder
test-PC steigt aus (wegen showCounter in start...)
-
0.0.4.148 - Rev: 1535
xhci: Fehler im Event-Ring beseitigt
nach dem korrekten Rücksprung:
vmware: rast bis zum Ende durch (?)
test-PC: bleibt am Anfang stehen (xHC schiebt offensichtlich nichts mehr nach)
-
0.0.4.149 - Rev: 1536
xhci: weitere Versuche zur Optimierung des Eventringes
test-PC: bisher interessantes Verhalten, wenn auch noch nicht korrekt, zumindest wird der Eventring nach dem Rücksprung wieder bearbeitet.
-
0.0.4.150 - Rev: 1537
xhci: prepareEventRing geschaffen zur Verbesserung der Übersicht. showEvent so eingestellt, dass der EventRing den wrap back durchführt und cyclisch mit neuen Events startet (allerdings nach wrap back verzögert).
Zum Testen wurde Folgendes eingestellt:const uint16_t TRB_PER_SEGMENT = x->evtSegmentSize = 40; // at least 16!
test-PC und vmware: Reset/Ctrl Transfers laufen sowohl angehängt und als auch später angesteckt (beim PC).
-
0.0.4.151 - Rev: 1538
xhci: weiter entwickelt, eher experimentell.
Event-Ring läuft auf test-PC (damit sind die cmd/transfer/event-Ringe bez. xhci funktionsfähig)
-
0.0.4.152 - Rev: 1539
xhci: Verbesserungen im Debug (z.B. Zuordnung Event zu Command über die phys. Adresse)