Changeset 0db3ad6 in mainline for uspace/drv/uhci-hcd/uhci.c


Ignore:
Timestamp:
2011-03-12T12:39:43Z (14 years ago)
Author:
Jan Vesely <jano.vesely@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
7f810b3, dd6f59f
Parents:
fb1d4990
Message:

Only check connections of there is a chance for a finished one

Set IOC on the last packet of data transfer

File:
1 edited

Legend:

Unmodified
Added
Removed
  • uspace/drv/uhci-hcd/uhci.c

    rfb1d4990 r0db3ad6  
    372372        assert(instance);
    373373        /* TODO: Check interrupt cause here */
    374         transfer_list_remove_finished(&instance->transfers_interrupt);
    375         transfer_list_remove_finished(&instance->transfers_control_slow);
    376         transfer_list_remove_finished(&instance->transfers_control_full);
    377         transfer_list_remove_finished(&instance->transfers_bulk_full);
     374        /* Lower 2 bits are transaction error and transaction complete */
     375        if (status & 0x3) {
     376                transfer_list_remove_finished(&instance->transfers_interrupt);
     377                transfer_list_remove_finished(&instance->transfers_control_slow);
     378                transfer_list_remove_finished(&instance->transfers_control_full);
     379                transfer_list_remove_finished(&instance->transfers_bulk_full);
     380        }
    378381}
    379382/*----------------------------------------------------------------------------*/
     
    390393
    391394        while (1) {
     395                /* read and ack interrupts */
    392396                uint16_t status = pio_read_16(&instance->registers->usbsts);
     397                pio_write_16(&instance->registers->usbsts, 0x1f);
    393398                if (status != 0)
    394399                        usb_log_debug2("UHCI status: %x.\n", status);
    395                 status |= 1;
    396400                uhci_interrupt(instance, status);
    397                 pio_write_16(&instance->registers->usbsts, 0x1f);
    398401                async_usleep(UHCI_CLEANER_TIMEOUT);
    399402        }
Note: See TracChangeset for help on using the changeset viewer.