Ignore:
File:
1 edited

Legend:

Unmodified
Added
Removed
  • uspace/drv/ohci/iface.c

    r4125b7d r0ede0c3  
    5555
    5656        size_t res_bw;
    57         endpoint_t *ep = hc_get_endpoint(*hc,
     57        endpoint_t *ep = usb_endpoint_manager_get_ep(&(*hc)->ep_manager,
    5858            target.address, target.endpoint, direction, &res_bw);
    5959        if (ep == NULL) {
     
    118118        hc_t *hc = fun_to_hc(fun);
    119119        assert(hc);
    120         usb_log_debug("Address bind %d-%" PRIun ".\n", address, handle);
     120        usb_log_debug("Address bind %d-%d.\n", address, handle);
    121121        usb_device_keeper_bind(&hc->manager, address, handle);
    122122        return EOK;
     
    164164        }
    165165        const size_t size = max_packet_size;
     166        int ret;
    166167
    167168        usb_log_debug("Register endpoint %d:%d %s %s(%d) %zu(%zu) %u.\n",
     
    169170            usb_str_speed(speed), direction, size, max_packet_size, interval);
    170171
    171         return hc_add_endpoint(hc, address, endpoint, speed, transfer_type,
    172             direction, max_packet_size, size, interval);
     172        endpoint_t *ep = malloc(sizeof(endpoint_t));
     173        if (ep == NULL)
     174                return ENOMEM;
     175        ret = endpoint_init(ep, address, endpoint, direction,
     176            transfer_type, speed, max_packet_size);
     177        if (ret != EOK) {
     178                free(ep);
     179                return ret;
     180        }
     181
     182        ret = usb_endpoint_manager_register_ep(&hc->ep_manager, ep, size);
     183        if (ret != EOK) {
     184                endpoint_destroy(ep);
     185        }
     186        return ret;
    173187}
    174188/*----------------------------------------------------------------------------*/
     
    181195        usb_log_debug("Unregister endpoint %d:%d %d.\n",
    182196            address, endpoint, direction);
    183         return hc_remove_endpoint(hc, address, endpoint, direction);
     197        return usb_endpoint_manager_unregister_ep(&hc->ep_manager, address,
     198            endpoint, direction);
    184199}
    185200/*----------------------------------------------------------------------------*/
     
    213228        ret = hc_schedule(hc, batch);
    214229        if (ret != EOK) {
    215                 usb_transfer_batch_dispose(batch);
     230                batch_dispose(batch);
    216231        }
    217232        return ret;
     
    247262        ret = hc_schedule(hc, batch);
    248263        if (ret != EOK) {
    249                 usb_transfer_batch_dispose(batch);
     264                batch_dispose(batch);
    250265        }
    251266        return ret;
     
    281296        ret = hc_schedule(hc, batch);
    282297        if (ret != EOK) {
    283                 usb_transfer_batch_dispose(batch);
     298                batch_dispose(batch);
    284299        }
    285300        return ret;
     
    315330        ret = hc_schedule(hc, batch);
    316331        if (ret != EOK) {
    317                 usb_transfer_batch_dispose(batch);
     332                batch_dispose(batch);
    318333        }
    319334        return ret;
     
    331346 * @param[in] setup_packet Setup packet buffer (in USB endianess, allocated
    332347 *      and deallocated by the caller).
    333  * @param[in] setup_size Size of @p setup_packet buffer in bytes.
     348 * @param[in] setup_packet_size Size of @p setup_packet buffer in bytes.
    334349 * @param[in] data_buffer Data buffer (in USB endianess, allocated and
    335350 *      deallocated by the caller).
    336  * @param[in] size Size of @p data_buffer buffer in bytes.
     351 * @param[in] data_buffer_size Size of @p data_buffer buffer in bytes.
    337352 * @param[in] callback Callback to be issued once the transfer is complete.
    338353 * @param[in] arg Pass-through argument to the callback.
     
    355370        ret = hc_schedule(hc, batch);
    356371        if (ret != EOK) {
    357                 usb_transfer_batch_dispose(batch);
     372                batch_dispose(batch);
    358373        }
    359374        return ret;
     
    371386 * @param[in] setup_packet Setup packet buffer (in USB endianess, allocated
    372387 *      and deallocated by the caller).
    373  * @param[in] setup_size Size of @p setup_packet buffer in bytes.
     388 * @param[in] setup_packet_size Size of @p setup_packet buffer in bytes.
    374389 * @param[in] data_buffer Buffer where to store the data (in USB endianess,
    375390 *      allocated and deallocated by the caller).
    376  * @param[in] size Size of @p data_buffer buffer in bytes.
     391 * @param[in] data_buffer_size Size of @p data_buffer buffer in bytes.
    377392 * @param[in] callback Callback to be issued once the transfer is complete.
    378393 * @param[in] arg Pass-through argument to the callback.
     
    394409        ret = hc_schedule(hc, batch);
    395410        if (ret != EOK) {
    396                 usb_transfer_batch_dispose(batch);
     411                batch_dispose(batch);
    397412        }
    398413        return ret;
Note: See TracChangeset for help on using the changeset viewer.