Merge branch 'for-3.5-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/tj...
[firefly-linux-kernel-4.4.55.git] / sound / usb / endpoint.h
1 #ifndef __USBAUDIO_ENDPOINT_H
2 #define __USBAUDIO_ENDPOINT_H
3
4 #define SND_USB_ENDPOINT_TYPE_DATA     0
5 #define SND_USB_ENDPOINT_TYPE_SYNC     1
6
7 struct snd_usb_endpoint *snd_usb_add_endpoint(struct snd_usb_audio *chip,
8                                               struct usb_host_interface *alts,
9                                               int ep_num, int direction, int type);
10
11 int snd_usb_endpoint_set_params(struct snd_usb_endpoint *ep,
12                                 struct snd_pcm_hw_params *hw_params,
13                                 struct audioformat *fmt,
14                                 struct snd_usb_endpoint *sync_ep);
15
16 int  snd_usb_endpoint_start(struct snd_usb_endpoint *ep);
17 void snd_usb_endpoint_stop(struct snd_usb_endpoint *ep,
18                            int force, int can_sleep, int wait);
19 int  snd_usb_endpoint_activate(struct snd_usb_endpoint *ep);
20 int  snd_usb_endpoint_deactivate(struct snd_usb_endpoint *ep);
21 void snd_usb_endpoint_free(struct list_head *head);
22
23 int snd_usb_endpoint_implict_feedback_sink(struct snd_usb_endpoint *ep);
24
25 void snd_usb_handle_sync_urb(struct snd_usb_endpoint *ep,
26                              struct snd_usb_endpoint *sender,
27                              const struct urb *urb);
28
29 #endif /* __USBAUDIO_ENDPOINT_H */