#include <USBAudio.h>
Public Member Functions | |
USBAudio (bool connect=true, uint32_t frequency_rx=48000, uint8_t channel_count_rx=1, uint32_t frequency_tx=8000, uint8_t channel_count_tx=1, uint32_t buffer_ms=10, uint16_t vendor_id=0x7bb8, uint16_t product_id=0x1111, uint16_t product_release=0x0100) | |
Basic constructor. More... | |
USBAudio (USBPhy *phy, uint32_t frequency_rx, uint8_t channel_count_rx, uint32_t frequency_tx, uint8_t channel_count_tx, uint32_t buffer_ms, uint16_t vendor_id, uint16_t product_id, uint16_t product_release) | |
Fully featured constructor. More... | |
virtual | ~USBAudio () |
Destroy this object. More... | |
void | connect () |
Connect USBAudio. More... | |
void | disconnect () |
Disconnect USBAudio. More... | |
bool | read (uint8_t *buf, uint32_t size) |
Read audio data. More... | |
void | read_nb (uint8_t *buf, uint32_t size, uint32_t *actual) |
Nonblocking audio data read. More... | |
uint32_t | read_overflows (bool clear=false) |
Return the number read packets dropped due to overflow. More... | |
bool | read_ready () |
Check if the audio read channel is open. More... | |
void | read_wait_ready () |
Wait until the audio read channel is open. More... | |
bool | write (uint8_t *buf, uint32_t size) |
Write audio data. More... | |
void | write_nb (uint8_t *buf, uint32_t size, uint32_t *actual) |
Nonblocking audio data write. More... | |
uint32_t | write_underflows (bool clear=false) |
Return the number write packets not sent due to underflow. More... | |
bool | write_ready () |
Check if the audio write channel is open. More... | |
void | write_wait_ready () |
Wait until the audio write channel is open. More... | |
float | get_volume () |
Get current volume between 0.0 and 1.0. More... | |
void | attach (mbed::Callback< void()> &cb) |
Attach a Callback to update the volume. More... | |
void | attach_tx (mbed::Callback< void(AudioEvent)> &cb) |
attach a Callback to Tx Done More... | |
void | attach_rx (mbed::Callback< void(AudioEvent)> &cb) |
attach a Callback to Rx Done More... | |
Protected Member Functions | |
virtual void | callback_state_change (DeviceState new_state) |
Called when USB changes state. More... | |
virtual void | callback_request (const setup_packet_t *setup) |
Called by USBDevice on Endpoint0 request. More... | |
virtual void | callback_request_xfer_done (const setup_packet_t *setup, bool aborted) |
Called by USBDevice on data stage completion. More... | |
void | init () |
Initialize this instance. More... | |
void | deinit () |
Power down this instance. More... | |
bool | configured () |
Check if the device is configured. More... | |
void | sof_enable () |
Enable the start of frame interrupt. More... | |
void | sof_disable () |
Disable the start of frame interrupt. More... | |
bool | endpoint_add (usb_ep_t endpoint, uint32_t max_packet, usb_ep_type_t type, mbed::Callback< void()> callback=nullptr) |
Add an endpoint. More... | |
template<typename T > | |
bool | endpoint_add (usb_ep_t endpoint, uint32_t max_packet, usb_ep_type_t type, void(T::*callback)()) |
Add an endpoint. More... | |
void | endpoint_remove (usb_ep_t endpoint) |
Remove an endpoint. More... | |
void | endpoint_remove_all () |
Remove all non-zero endpoints. More... | |
void | endpoint_stall (usb_ep_t endpoint) |
Stall an endpoint. More... | |
void | endpoint_unstall (usb_ep_t endpoint) |
Un-stall an endpoint. More... | |
uint32_t | endpoint_max_packet_size (usb_ep_t endpoint) |
Get the current maximum size for this endpoint. More... | |
void | endpoint_abort (usb_ep_t endpoint) |
Abort the current transfer on this endpoint. More... | |
bool | read_start (usb_ep_t endpoint, uint8_t *buffer, uint32_t size) |
start a read on the given endpoint More... | |
uint32_t | read_finish (usb_ep_t endpoint) |
Get the status of a read. More... | |
bool | write_start (usb_ep_t endpoint, uint8_t *buffer, uint32_t size) |
Write a data to the given endpoint. More... | |
uint32_t | write_finish (usb_ep_t endpoint) |
Get the status of a write. More... | |
virtual void | callback_power (bool powered) |
Called by USBDevice layer on power state change. More... | |
virtual void | callback_sof (int frame_number) |
Called by USBDevice layer on each new USB frame. More... | |
virtual void | callback_reset () |
Called by USBDevice layer on bus reset. More... | |
void | complete_request (RequestResult result, uint8_t *data=NULL, uint32_t size=0) |
Called to complete the setup stage of a callback request. More... | |
void | complete_request_xfer_done (bool success) |
Called to complete the data stage of a callback request. More... | |
void | complete_set_configuration (bool success) |
Called to complete a set configuration command. More... | |
void | complete_set_interface (bool success) |
Called to complete a set interface command. More... | |
uint8_t * | find_descriptor (uint8_t descriptor_type, uint8_t index=0) |
Find a descriptor type inside the configuration descriptor. More... | |
const usb_ep_table_t * | endpoint_table () |
Get the endpoint table of this device. More... | |
virtual void | start_process () |
Callback called to indicate the USB processing needs to be done. More... | |
virtual void | lock () |
Acquire exclusive access to this instance USBDevice. More... | |
virtual void | unlock () |
Release exclusive access to this instance USBDevice. More... | |
virtual void | assert_locked () |
Assert that the current thread of execution holds the lock. More... | |
USBAudio example.
Definition at line 69 of file USBAudio.h.
USBAudio | ( | bool | connect = true , |
uint32_t | frequency_rx = 48000 , |
||
uint8_t | channel_count_rx = 1 , |
||
uint32_t | frequency_tx = 8000 , |
||
uint8_t | channel_count_tx = 1 , |
||
uint32_t | buffer_ms = 10 , |
||
uint16_t | vendor_id = 0x7bb8 , |
||
uint16_t | product_id = 0x1111 , |
||
uint16_t | product_release = 0x0100 |
||
) |
Basic constructor.
Construct this object optionally connecting.
connect | Call connect on initialization |
frequency_rx | frequency in Hz (default: 48000) |
channel_count_rx | channel number (1 or 2) (default: 1) |
frequency_tx | frequency in Hz (default: 8000) |
channel_count_tx | channel number (1 or 2) (default: 1) |
buffer_ms | time audio can be buffered without overflowing in milliseconds |
vendor_id | Your vendor_id |
product_id | Your product_id |
product_release | Your product_release |
USBAudio | ( | USBPhy * | phy, |
uint32_t | frequency_rx, | ||
uint8_t | channel_count_rx, | ||
uint32_t | frequency_tx, | ||
uint8_t | channel_count_tx, | ||
uint32_t | buffer_ms, | ||
uint16_t | vendor_id, | ||
uint16_t | product_id, | ||
uint16_t | product_release | ||
) |
Fully featured constructor.
Construct this object with the supplied USBPhy and parameters. The user this object is responsible for calling connect() or init().
phy | USB phy to use |
frequency_rx | frequency in Hz (default: 48000) |
channel_count_rx | channel number (1 or 2) (default: 1) |
frequency_tx | frequency in Hz (default: 8000) |
channel_count_tx | channel number (1 or 2) (default: 1) |
buffer_ms | time audio can be buffered without overflowing in milliseconds |
vendor_id | Your vendor_id |
product_id | Your product_id |
product_release | Your product_release |
|
virtual |
Destroy this object.
Any classes which inherit from this class must call deinit before this destructor runs.
|
protectedvirtualinherited |
Assert that the current thread of execution holds the lock.
void attach | ( | mbed::Callback< void()> & | cb | ) |
Attach a Callback to update the volume.
cb | Callback to attach |
void attach_rx | ( | mbed::Callback< void(AudioEvent)> & | cb | ) |
attach a Callback to Rx Done
cb | Callback to attach |
void attach_tx | ( | mbed::Callback< void(AudioEvent)> & | cb | ) |
attach a Callback to Tx Done
cb | Callback to attach |
|
protectedvirtualinherited |
Called by USBDevice layer on power state change.
powered | true if device is powered, false otherwise |
Warning: Called in ISR context
Definition at line 342 of file USBDevice.h.
|
protectedvirtual |
|
protectedvirtual |
Called by USBDevice on data stage completion.
The function complete_request_xfer_done must be always be called in response to this callback.
setup | Setup packet of the current request |
aborted | false if the operation was aborted, true otherwise |
Warning: Called in ISR context
Implements USBDevice.
|
protectedvirtualinherited |
Called by USBDevice layer on bus reset.
complete_reset must be called after the device is fully reset.
Warning: Called in ISR context
Reimplemented in USBCDC_ECM, USBCDC, and USBTester.
Definition at line 370 of file USBDevice.h.
|
protectedvirtualinherited |
Called by USBDevice layer on each new USB frame.
Callbacks are enabled and disabled by calling sof_enable and sof_disable.
frame_number | The current frame number |
Warning: Called in ISR context
Definition at line 357 of file USBDevice.h.
|
protectedvirtual |
|
protectedinherited |
Called to complete the setup stage of a callback request.
Possible options that can be passed as a result are:
result | The result of the setup phase. |
data | Buffer to send or receive if the result is Send or Receive |
size | Size to transfer if the result is Send or Receive |
|
protectedinherited |
Called to complete the data stage of a callback request.
success | true if the operation was successful, false otherwise |
|
protectedinherited |
Called to complete a set configuration command.
success | true if the configuration was set, false otherwise |
|
protectedinherited |
Called to complete a set interface command.
success | true if the interface was set, false otherwise |
|
inherited |
Check if the device is configured.
void connect | ( | ) |
Connect USBAudio.
|
inherited |
Power down this instance.
Disable interrupts and stop sending events. This method can be used for temporary power-saving; This call can allow USB to be temporarily disabled to permit power saving. However, it is up to the user to make sure all the transfers have concluded (for example when USB power is lost). USBDevice::connect can be used to resume USB operation.
void disconnect | ( | ) |
Disconnect USBAudio.
This unblocks all calls to read_ready and write_ready.
|
inherited |
Abort the current transfer on this endpoint.
endpoint | endpoint with transfer to abort |
|
inherited |
Add an endpoint.
endpoint | Endpoint to enable |
max_packet | Maximum size of a packet which can be sent or received on this endpoint |
type | Endpoint type - USB_EP_TYPE_BULK, USB_EP_TYPE_INT or USB_EP_TYPE_ISO |
callback | Method pointer to be called when a packet is transferred |
|
inherited |
Add an endpoint.
endpoint | Endpoint to enable |
max_packet | Maximum size of a packet which can be sent or received on this endpoint |
type | Endpoint type - USB_EP_TYPE_BULK, USB_EP_TYPE_INT or USB_EP_TYPE_ISO |
callback | Method pointer to be called when a packet is transferred |
Definition at line 162 of file USBDevice.h.
|
inherited |
Get the current maximum size for this endpoint.
Return the currently configured maximum packet size, wMaxPacketSize, for this endpoint.
|
inherited |
Remove an endpoint.
endpoint | Endpoint to disable |
|
inherited |
Remove all non-zero endpoints.
|
inherited |
Stall an endpoint.
If there is an ongoing transfer on this endpoint then it will be aborted.
endpoint | Endpoint to stall |
|
protectedinherited |
|
inherited |
Un-stall an endpoint.
Un-stalling an endpoint resets data toggle back to DATA0. Additionally, if there is an ongoing transfer on this endpoint it will be aborted.
endpoint | Endpoint to un-stall |
|
protectedinherited |
Find a descriptor type inside the configuration descriptor.
descriptor_type | Type of descriptor to find |
index | Configuration descriptor index ( 0 if only one configuration present ) |
float get_volume | ( | ) |
Get current volume between 0.0 and 1.0.
|
inherited |
Initialize this instance.
This function must be called before calling any other functions of this class, unless specifically
|
protectedvirtualinherited |
Acquire exclusive access to this instance USBDevice.
bool read | ( | uint8_t * | buf, |
uint32_t | size | ||
) |
Read audio data.
buf | pointer on a buffer which will be filled with audio data |
size | size to read |
|
inherited |
Get the status of a read.
endpoint | endpoint to get the status of |
void read_nb | ( | uint8_t * | buf, |
uint32_t | size, | ||
uint32_t * | actual | ||
) |
Nonblocking audio data read.
Read the available audio data.
buf | pointer on a buffer which will be filled with audio data |
size | size to read |
actual | size actually read |
uint32_t read_overflows | ( | bool | clear = false | ) |
Return the number read packets dropped due to overflow.
clear | Reset the overflow count back to 0 |
bool read_ready | ( | ) |
Check if the audio read channel is open.
|
inherited |
start a read on the given endpoint
Start a read on the given endpoint. The data buffer must remain unchanged until the transfer either completes or is aborted.
endpoint | endpoint to read data from |
buffer | buffer to fill with read data |
size | The size of data to read. This must be greater than or equal to the max packet size for this endpoint |
void read_wait_ready | ( | ) |
Wait until the audio read channel is open.
|
inherited |
Disable the start of frame interrupt.
Stop calling USBDevice::callback_sof.
|
inherited |
Enable the start of frame interrupt.
Call USBDevice::callback_sof on every frame.
|
protectedvirtualinherited |
Callback called to indicate the USB processing needs to be done.
Implements USBPhyEvents.
|
protectedvirtualinherited |
Release exclusive access to this instance USBDevice.
bool write | ( | uint8_t * | buf, |
uint32_t | size | ||
) |
Write audio data.
buf | pointer to audio data to write |
size | size to write |
|
inherited |
Get the status of a write.
endpoint | endpoint to get the status of |
void write_nb | ( | uint8_t * | buf, |
uint32_t | size, | ||
uint32_t * | actual | ||
) |
Nonblocking audio data write.
Write the available audio data.
buf | pointer to audio data to write |
size | size to write |
actual | actual size written |
bool write_ready | ( | ) |
Check if the audio write channel is open.
|
inherited |
Write a data to the given endpoint.
Write data to an endpoint. The data sent must remain unchanged until the transfer either completes or is aborted.
endpoint | endpoint to write data to |
buffer | data to write |
size | the size of data to send. This must be less than or equal to the max packet size of this endpoint |
uint32_t write_underflows | ( | bool | clear = false | ) |
Return the number write packets not sent due to underflow.
clear | Reset the underflow count back to 0 |
void write_wait_ready | ( | ) |
Wait until the audio write channel is open.