100 WINPR_ATTR_NODISCARD int (*isoch_transfer)(
102 UINT32 EndpointAddress, UINT32 TransferFlags, UINT32 StartFrame, UINT32 ErrorCount,
103 BOOL NoAck,
const BYTE* packetDescriptorData, UINT32 NumberOfPackets, UINT32 BufferSize,
104 const BYTE* Buffer, t_isoch_transfer_cb cb, UINT32 Timeout);
106 WINPR_ATTR_NODISCARD BOOL (*control_transfer)(IUDEVICE* idev, UINT32 RequestId,
107 UINT32 EndpointAddress, UINT32 TransferFlags,
108 BYTE bmRequestType, BYTE Request, UINT16 Value,
109 UINT16 Index, UINT32* UrbdStatus,
110 UINT32* BufferSize, BYTE* Buffer, UINT32 Timeout);
112 WINPR_ATTR_NODISCARD int (*bulk_or_interrupt_transfer)(
114 UINT32 EndpointAddress, UINT32 TransferFlags, BOOL NoAck, UINT32 BufferSize,
115 const BYTE* data, t_isoch_transfer_cb cb, UINT32 Timeout);
117 WINPR_ATTR_NODISCARD int (*select_configuration)(IUDEVICE* idev, UINT32 bConfigurationValue);
119 WINPR_ATTR_NODISCARD int (*select_interface)(IUDEVICE* idev, BYTE InterfaceNumber,
120 BYTE AlternateSetting);
122 WINPR_ATTR_NODISCARD int (*control_pipe_request)(IUDEVICE* idev, UINT32 RequestId,
123 UINT32 EndpointAddress, UINT32* UsbdStatus,
126 WINPR_ATTR_NODISCARD UINT32 (*control_query_device_text)(IUDEVICE* idev, UINT32 TextType,
127 UINT16 LocaleId, UINT8* BufferSize,
130 WINPR_ATTR_NODISCARD int (*os_feature_descriptor_request)(
131 IUDEVICE* idev, UINT32 RequestId, BYTE Recipient, BYTE InterfaceNumber, BYTE Ms_PageIndex,
132 UINT16 Ms_featureDescIndex, UINT32* UsbdStatus, UINT32* BufferSize, BYTE* Buffer,
135 void (*cancel_all_transfer_request)(IUDEVICE* idev);
137 WINPR_ATTR_NODISCARD int (*cancel_transfer_request)(IUDEVICE* idev, UINT32 RequestId);
139 WINPR_ATTR_NODISCARD int (*query_device_descriptor)(IUDEVICE* idev,
int offset);
141 WINPR_ATTR_NODISCARD BOOL (*detach_kernel_driver)(IUDEVICE* idev);
143 WINPR_ATTR_NODISCARD BOOL (*attach_kernel_driver)(IUDEVICE* idev);
145 WINPR_ATTR_NODISCARD int (*query_device_port_status)(IUDEVICE* idev, UINT32* UsbdStatus,
146 UINT32* BufferSize, BYTE* Buffer);
151 WINPR_ATTR_NODISCARD int (*isCompositeDevice)(IUDEVICE* idev);
153 WINPR_ATTR_NODISCARD int (*isExist)(IUDEVICE* idev);
154 WINPR_ATTR_NODISCARD int (*isAlreadySend)(IUDEVICE* idev);
155 WINPR_ATTR_NODISCARD int (*isChannelClosed)(IUDEVICE* idev);
157 void (*setAlreadySend)(IUDEVICE* idev);
158 void (*setChannelClosed)(IUDEVICE* idev);
159 void (*markChannelClosed)(IUDEVICE* idev);
160 WINPR_ATTR_NODISCARD
char* (*getPath)(IUDEVICE* idev);
162 void (*free)(IUDEVICE* idev);
164 BASIC_DEV_STATE_DEFINED(channelManager, IWTSVirtualChannelManager*);
165 BASIC_DEV_STATE_DEFINED(channelID, UINT32);
166 BASIC_DEV_STATE_DEFINED(UsbDevice, UINT32);
167 BASIC_DEV_STATE_DEFINED(ReqCompletion, UINT32);
168 BASIC_DEV_STATE_DEFINED(bus_number, BYTE);
169 BASIC_DEV_STATE_DEFINED(dev_number, BYTE);
170 BASIC_DEV_STATE_DEFINED(port_number, UINT8);
173 BASIC_DEV_STATE_DEFINED(p_udev,
void*);
174 BASIC_DEV_STATE_DEFINED(p_prev,
void*);
175 BASIC_DEV_STATE_DEFINED(p_next,
void*);
181 void (*free)(IUDEVMAN* idevman);
184 void (*rewind)(IUDEVMAN* idevman);
185 WINPR_ATTR_NODISCARD BOOL (*has_next)(IUDEVMAN* idevman);
186 WINPR_ATTR_NODISCARD BOOL (*unregister_udevice)(IUDEVMAN* idevman, BYTE bus_number,
188 WINPR_ATTR_NODISCARD size_t (*register_udevice)(IUDEVMAN* idevman, BYTE bus_number,
189 BYTE dev_number, UINT16 idVendor,
190 UINT16 idProduct, UINT32 flag);
191 WINPR_ATTR_NODISCARD IUDEVICE* (*get_next)(IUDEVMAN* idevman);
192 WINPR_ATTR_NODISCARD IUDEVICE* (*get_udevice_by_UsbDevice)(IUDEVMAN* idevman, UINT32 UsbDevice);
193 WINPR_ATTR_NODISCARD IUDEVICE* (*get_udevice_by_ChannelID)(IUDEVMAN* idevman, UINT32 channelID);
196 WINPR_ATTR_NODISCARD int (*isAutoAdd)(IUDEVMAN* idevman);
199 BASIC_DEVMAN_STATE_DEFINED(device_num, UINT32);
200 BASIC_DEVMAN_STATE_DEFINED(next_device_id, UINT32);
203 void (*loading_lock)(IUDEVMAN* idevman);
204 void (*loading_unlock)(IUDEVMAN* idevman);
205 WINPR_ATTR_NODISCARD BOOL (*initialize)(IUDEVMAN* idevman, UINT32 channelId);
206 WINPR_ATTR_NODISCARD UINT (*listener_created_callback)(IUDEVMAN* idevman);
209 UINT32 controlChannelId;