1094332d3Sopenharmony_ci/*
2094332d3Sopenharmony_ci * Copyright (c) 2020-2022 Huawei Device Co., Ltd.
3094332d3Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4094332d3Sopenharmony_ci * you may not use this file except in compliance with the License.
5094332d3Sopenharmony_ci * You may obtain a copy of the License at
6094332d3Sopenharmony_ci *
7094332d3Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
8094332d3Sopenharmony_ci *
9094332d3Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10094332d3Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11094332d3Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12094332d3Sopenharmony_ci * See the License for the specific language governing permissions and
13094332d3Sopenharmony_ci * limitations under the License.
14094332d3Sopenharmony_ci */
15094332d3Sopenharmony_ci
16094332d3Sopenharmony_ci/**
17094332d3Sopenharmony_ci * @addtogroup USB
18094332d3Sopenharmony_ci * @{
19094332d3Sopenharmony_ci *
20094332d3Sopenharmony_ci * @brief Declares USB-related APIs, including the custom data types and functions used to obtain descriptors,
21094332d3Sopenharmony_ci * interface objects, and request objects, and to submit requests.
22094332d3Sopenharmony_ci *
23094332d3Sopenharmony_ci * @since 1.0
24094332d3Sopenharmony_ci * @version 1.0
25094332d3Sopenharmony_ci */
26094332d3Sopenharmony_ci
27094332d3Sopenharmony_ci/**
28094332d3Sopenharmony_ci * @file usb_object.h
29094332d3Sopenharmony_ci *
30094332d3Sopenharmony_ci * @brief Defines USB common data types, including the enumerated values returned by
31094332d3Sopenharmony_ci * functions and definitions of other common data structures.
32094332d3Sopenharmony_ci *
33094332d3Sopenharmony_ci * @since 1.0
34094332d3Sopenharmony_ci * @version 1.0
35094332d3Sopenharmony_ci */
36094332d3Sopenharmony_ci#ifndef USB_OBJECT_H
37094332d3Sopenharmony_ci#define USB_OBJECT_H
38094332d3Sopenharmony_ci
39094332d3Sopenharmony_ci#include <stdint.h>
40094332d3Sopenharmony_ci#include <pthread.h>
41094332d3Sopenharmony_ci#include <sys/time.h>
42094332d3Sopenharmony_ci#include "securec.h"
43094332d3Sopenharmony_ci#include "hdf_base.h"
44094332d3Sopenharmony_ci#include "hdf_slist.h"
45094332d3Sopenharmony_ci#include "hdf_dlist.h"
46094332d3Sopenharmony_ci#include "hdf_log.h"
47094332d3Sopenharmony_ci#include "osal_mem.h"
48094332d3Sopenharmony_ci#include "osal_mutex.h"
49094332d3Sopenharmony_ci#include "osal_sem.h"
50094332d3Sopenharmony_ci#include "osal_thread.h"
51094332d3Sopenharmony_ci#include "osal_time.h"
52094332d3Sopenharmony_ci#include "osal_atomic.h"
53094332d3Sopenharmony_ci
54094332d3Sopenharmony_ci/**
55094332d3Sopenharmony_ci * @brief Defines the maximum object ID.
56094332d3Sopenharmony_ci */
57094332d3Sopenharmony_ci#define MAX_OBJECT_ID       (0x7FFFFFFF)
58094332d3Sopenharmony_ci
59094332d3Sopenharmony_ci/**
60094332d3Sopenharmony_ci * @brief Defines the USB request status type.
61094332d3Sopenharmony_ci *
62094332d3Sopenharmony_ci * You can use this function to check the request execution status.
63094332d3Sopenharmony_ci */
64094332d3Sopenharmony_citypedef enum {
65094332d3Sopenharmony_ci    /** Request completed */
66094332d3Sopenharmony_ci    USB_REQUEST_COMPLETED,
67094332d3Sopenharmony_ci    /** Request completed beforehand */
68094332d3Sopenharmony_ci    USB_REQUEST_COMPLETED_SHORT,
69094332d3Sopenharmony_ci    /** Request error */
70094332d3Sopenharmony_ci    USB_REQUEST_ERROR,
71094332d3Sopenharmony_ci    /** Request timeout */
72094332d3Sopenharmony_ci    USB_REQUEST_TIMEOUT,
73094332d3Sopenharmony_ci    /** Request canceled */
74094332d3Sopenharmony_ci    USB_REQUEST_CANCELLED,
75094332d3Sopenharmony_ci    /** Request stopped */
76094332d3Sopenharmony_ci    USB_REQUEST_STALL,
77094332d3Sopenharmony_ci    /** Device disconnected */
78094332d3Sopenharmony_ci    USB_REQUEST_NO_DEVICE,
79094332d3Sopenharmony_ci    /** Overflow error. The amount of sent data is more than requested. */
80094332d3Sopenharmony_ci    USB_REQUEST_OVERFLOW,
81094332d3Sopenharmony_ci} UsbRequestStatus;
82094332d3Sopenharmony_ci
83094332d3Sopenharmony_ci/**
84094332d3Sopenharmony_ci * @brief Defines the USB pipe direction.
85094332d3Sopenharmony_ci */
86094332d3Sopenharmony_citypedef enum {
87094332d3Sopenharmony_ci    /** Output direction (from the host to the device) */
88094332d3Sopenharmony_ci    USB_PIPE_DIRECTION_OUT = 0x00,
89094332d3Sopenharmony_ci    /** Input direction (from the device to the host) */
90094332d3Sopenharmony_ci    USB_PIPE_DIRECTION_IN = 0x80,
91094332d3Sopenharmony_ci} UsbPipeDirection;
92094332d3Sopenharmony_ci
93094332d3Sopenharmony_ci/**
94094332d3Sopenharmony_ci * @brief Defines the USB pipe type.
95094332d3Sopenharmony_ci */
96094332d3Sopenharmony_citypedef enum {
97094332d3Sopenharmony_ci    /** Control transfer */
98094332d3Sopenharmony_ci    USB_PIPE_TYPE_CONTROL = 0U,
99094332d3Sopenharmony_ci    /**
100094332d3Sopenharmony_ci     * Isochronous transfer is mainly used for transmitting time-dependent information, such as
101094332d3Sopenharmony_ci     * audio and video data,at a constant rate. Each isochronous transfer involves one or multiple
102094332d3Sopenharmony_ci     * isochronous transactions, each containing token packets and data packets but no handshake packets.
103094332d3Sopenharmony_ci     * This transfer mode ensures the timeliness of transfer but does not guarantee the correctness
104094332d3Sopenharmony_ci     * of data due to the absence of handshake.
105094332d3Sopenharmony_ci     * Different from bulk transfer, isochronous transfer allows a certain bit error rate (BER)
106094332d3Sopenharmony_ci     * under certain conditions, so as to ensure that
107094332d3Sopenharmony_ci     *  audio and video data are transmitted on a real-time basis.
108094332d3Sopenharmony_ci     */
109094332d3Sopenharmony_ci    USB_PIPE_TYPE_ISOCHRONOUS = 1U,
110094332d3Sopenharmony_ci    /** Bulk transfer */
111094332d3Sopenharmony_ci    USB_PIPE_TYPE_BULK = 2U,
112094332d3Sopenharmony_ci    /** Interrupt transfer */
113094332d3Sopenharmony_ci    USB_PIPE_TYPE_INTERRUPT = 3U,
114094332d3Sopenharmony_ci} UsbPipeType;
115094332d3Sopenharmony_ci
116094332d3Sopenharmony_ci/**
117094332d3Sopenharmony_ci * @brief Defines the USB interface status.
118094332d3Sopenharmony_ci */
119094332d3Sopenharmony_citypedef enum {
120094332d3Sopenharmony_ci    /** Normal */
121094332d3Sopenharmony_ci    USB_INTERFACE_STATUS_NORMAL,
122094332d3Sopenharmony_ci    /** Interface addition */
123094332d3Sopenharmony_ci    USB_INTERFACE_STATUS_ADD,
124094332d3Sopenharmony_ci    /** Interface removal */
125094332d3Sopenharmony_ci    USB_INTERFACE_STATUS_REMOVE,
126094332d3Sopenharmony_ci    /** Other status */
127094332d3Sopenharmony_ci    USB_INTERFACE_STATUS_OTHER,
128094332d3Sopenharmony_ci} UsbInterfaceStatus;
129094332d3Sopenharmony_ci
130094332d3Sopenharmony_ci/**
131094332d3Sopenharmony_ci * @brief Defines the USB basic object, which is contained in the data structure provided for users.
132094332d3Sopenharmony_ci * It is used to mark an external object and create an object linked list.
133094332d3Sopenharmony_ci */
134094332d3Sopenharmony_cistruct UsbObject {
135094332d3Sopenharmony_ci    /** Basic object ID */
136094332d3Sopenharmony_ci    int32_t objectId;
137094332d3Sopenharmony_ci    /** Bidirectional linked list header */
138094332d3Sopenharmony_ci    struct DListHead entry;
139094332d3Sopenharmony_ci};
140094332d3Sopenharmony_ci
141094332d3Sopenharmony_ci#endif /* USB_OBJECT_H */
142094332d3Sopenharmony_ci/** @} */