source: mainline/uspace/drv/bus/usb/xhci/trb_ring.h@ ef1a3a8

lfn serial ticket/834-toolchain-update topic/msim-upgrade topic/simplify-dev-export
Last change on this file since ef1a3a8 was 9620a54, checked in by Petr Manek <petr.manek@…>, 8 years ago

Small changes. Temporarily fixed no device problem for endpoint logging. Added similar macro for device logging. Changed log messages to adopt these macros. TRB rings can be freed again. Made ring finalizers noexcept. Upon detach, the entire slot is disabled prior to unregistering endpoints in order to prevent invalid HC commands. Removed active endpoints count from XHCI device. Device context is freed in HC, so DCBAA is not touched from anywhere else.

  • Property mode set to 100644
File size: 4.3 KB
Line 
1/*
2 * Copyright (c) 2017 Ondrej Hlavaty
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 *
9 * - Redistributions of source code must retain the above copyright
10 * notice, this list of conditions and the following disclaimer.
11 * - Redistributions in binary form must reproduce the above copyright
12 * notice, this list of conditions and the following disclaimer in the
13 * documentation and/or other materials provided with the distribution.
14 * - The name of the author may not be used to endorse or promote products
15 * derived from this software without specific prior written permission.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
18 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
19 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
20 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
21 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
22 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 */
28
29/** @addtogroup drvusbxhci
30 * @{
31 */
32/** @file
33 * TRB Ring is a data structure for communication between HC and software.
34 *
35 * Despite this description, it is not used as an hardware structure - all but
36 * the Event ring is used as buffer of the TRBs itself, linked by Link TRB to
37 * form a (possibly multi-segment) circular buffer.
38 *
39 * This data structure abstracts this behavior.
40 */
41
42#ifndef XHCI_TRB_RING_H
43#define XHCI_TRB_RING_H
44
45#include <adt/list.h>
46#include <fibril_synch.h>
47#include <libarch/config.h>
48
49typedef struct trb_segment trb_segment_t;
50typedef struct xhci_hc xhci_hc_t;
51typedef struct xhci_trb xhci_trb_t;
52typedef struct xhci_erst_entry xhci_erst_entry_t;
53
54/**
55 * A TRB ring of which the software is a producer - command / transfer.
56 */
57typedef struct xhci_trb_ring {
58 list_t segments; /* List of assigned segments */
59 int segment_count; /* Number of segments assigned */
60
61 /*
62 * As the link TRBs connect physical addresses, we need to keep track of
63 * active segment in virtual memory. The enqueue ptr should always belong
64 * to the enqueue segment.
65 */
66 trb_segment_t *enqueue_segment;
67 xhci_trb_t *enqueue_trb;
68
69 uintptr_t dequeue; /* Last reported position of the dequeue pointer */
70 bool pcs; /* Producer Cycle State: section 4.9.2 */
71
72 fibril_mutex_t guard;
73} xhci_trb_ring_t;
74
75int xhci_trb_ring_init(xhci_trb_ring_t *);
76void xhci_trb_ring_fini(xhci_trb_ring_t *);
77int xhci_trb_ring_enqueue(xhci_trb_ring_t *, xhci_trb_t *, uintptr_t *);
78int xhci_trb_ring_enqueue_multiple(xhci_trb_ring_t *, xhci_trb_t *, size_t, uintptr_t *);
79
80/**
81 * Get the initial value to fill into CRCR.
82 */
83static inline uintptr_t xhci_trb_ring_get_dequeue_ptr(xhci_trb_ring_t *ring)
84{
85 return ring->dequeue;
86}
87
88/**
89 * When an event is received by the upper layer, it needs to update the dequeue
90 * pointer inside the ring. Otherwise, the ring will soon show up as full.
91 */
92void xhci_trb_ring_update_dequeue(xhci_trb_ring_t *, uintptr_t);
93uintptr_t xhci_trb_ring_get_dequeue_ptr(xhci_trb_ring_t *);
94
95/**
96 * A TRB ring of which the software is a consumer (event rings).
97 */
98typedef struct xhci_event_ring {
99 list_t segments; /* List of assigned segments */
100 int segment_count; /* Number of segments assigned */
101
102 trb_segment_t *dequeue_segment; /* Current segment of the dequeue ptr */
103 xhci_trb_t *dequeue_trb; /* Next TRB to be processed */
104 uintptr_t dequeue_ptr; /* Physical address of the ERDP to be reported to the HC */
105
106 xhci_erst_entry_t *erst; /* ERST given to the HC */
107
108 bool ccs; /* Consumer Cycle State: section 4.9.2 */
109
110 fibril_mutex_t guard;
111} xhci_event_ring_t;
112
113int xhci_event_ring_init(xhci_event_ring_t *);
114void xhci_event_ring_fini(xhci_event_ring_t *);
115int xhci_event_ring_dequeue(xhci_event_ring_t *, xhci_trb_t *);
116
117#endif
Note: See TracBrowser for help on using the repository browser.