.. _nrf53_audio_unicast_client_app: nRF5340 Audio: Unicast client ############################# .. contents:: :local: :depth: 2 The nRF5340 Audio unicast client application implements the :ref:`CIS gateway mode `. In this mode, one Connected Isochronous Group (CIG) can be used with two Connected Isochronous Streams (CIS). Transmitting unidirectional or transceiving bidirectional audio happens using CIG and CIS. The following limitations apply to this application: * One CIG with two CIS. * Audio input: USB or I2S (Line in or using Pulse Density Modulation). * Audio output: USB or I2S/Analog headset output. * Configuration: 16 bit, several bit rates ranging from 32 kbps to 124 kbps. .. _nrf53_audio_unicast_client_app_requirements: Requirements ************ The application shares the :ref:`requirements common to all nRF5340 Audio application `. .. _nrf53_audio_unicast_client_app_ui: User interface ************** Most of the user interface mappings are common across all nRF5340 Audio applications. See the :ref:`nrf53_audio_app_ui` page for detailed overview. This application uses specific mapping for the following user interface elements: * Long-pressed on the unicast client device during startup: * **BTN5** - Clears the previously stored bonding information. * Pressed on the unicast client device during playback: * **PLAY/PAUSE** - Starts or pauses the playback of the stream. * **VOL-** - Turns the playback volume down (and unmutes). * **VOL+** - Turns the playback volume up (and unmutes). * **BTN 4** - Sends a test tone generated on the device. Use this tone to check the synchronization of headsets. * **BTN5** - Mutes the playback volume (and unmutes). * **LED1** - Blinking blue - Kit is streaming audio to a headset. * **RGB** - Solid green - The device is programmed as the gateway. .. _nrf53_audio_unicast_client_app_configuration: Configuration ************* By default, if you have not made any changes to :file:`.conf` files at :file:`applications/nrf5340_audio/`, the nRF5340 build script tries to build the CIS applications in the CIS unidirectional mode. To switch to the bidirectional mode, see :ref:`nrf53_audio_app_configuration_select_bidirectional`. For other configuration options, see :ref:`nrf53_audio_app_configuration` and :ref:`nrf53_audio_app_fota`. For information about how to configure applications in the |NCS|, see :ref:`configure_application`. .. _nrf53_audio_unicast_client_app_building: Building and running ******************** This application can be found under :file:`applications/nrf5340_audio/unicast_client` in the nRF Connect SDK folder structure, but it uses :file:`.conf` files at :file:`applications/nrf5340_audio/`. The nRF5340 Audio DK comes preprogrammed with basic firmware that indicates if the kit is functional. See :ref:`nrf53_audio_app_dk_testing_out_of_the_box` for more information. To build the application, see :ref:`nrf53_audio_app_building`. .. _nrf53_audio_unicast_client_app_testing: Testing ******* After building and programming the application, you can test the default CIS gateway mode using one unicast client device and at least one CIS headset device. The recommended approach is to use another nRF5340 Audio DK programmed with the :ref:`unicast server application `, but you can also use an external CIS headset device. .. note:: |nrf5340_audio_external_devices_note| The following testing scenario assumes you are using USB as the audio source on the gateway. This is the default setting. Complete the following steps to test the unidirectional CIS mode for one gateway and at least one headset device: 1. Make sure that the development kits are still plugged into the USB ports and are turned on. .. note:: |usb_known_issues| **LED3** starts blinking green on every device to indicate the ongoing CPU activity on the application core. #. Wait for the **LED1** on the gateway to start blinking blue. This happens shortly after programming the development kit and indicates that the gateway device is connected to at least one headset and ready to send data. #. Search the list of audio devices listed in the sound settings of your operating system for *nRF5340 USB Audio* (gateway) and select it as the output device. #. Connect headphones to the **HEADPHONE** audio jack on the headset device. #. Start audio playback on your PC from any source. #. Wait for **LED1** to blink blue on the headset. When they do, the audio stream has started on the headset. .. note:: The audio outputs only to the left channel of the audio jack, even if the given headset is configured as the right headset. This is because of the mono hardware codec chip used on the development kits. If you want to play stereo sound using one development kit, you must connect an external hardware codec chip that supports stereo. #. Wait for **LED2** to light up solid green on the headsets to indicate that the audio synchronization is achieved. #. Press the **VOL-** button on the gateway. The playback volume decreases for the headset. #. Press the **PLAY/PAUSE** button on any one of the devices. The playback stops for the headset and the streaming state for all devices is set to paused. #. Press the **BTN 4** button on the gateway multiple times. For each button press, the audio stream playback is stopped and the gateway sends a test tone to the headset. These tones can be used as audio cues to check the synchronization between two headsets. For other testing options, refer to :ref:`nrf53_audio_unicast_client_app_ui`. After the kits have paired for the first time, they are now bonded. This means the Long-Term Key (LTK) is stored on each side, and that the kits will only connect to each other unless the bonding information is cleared. To clear the bonding information, press and hold **BTN 5** during boot or reprogram all the development kits. When you finish testing, power off the nRF5340 Audio development kits by switching the power switch from On to Off. .. _nrf53_audio_unicast_client_app_testing_steps_cis_walkie_talkie: Testing the walkie-talkie demo ============================== Testing the walkie-talkie demo is identical to the default testing procedure, except for the following differences: * You must enable the Kconfig option mentioned in :ref:`nrf53_audio_app_configuration_enable_walkie_talkie` before building the application. * Instead of controlling the playback, you can speak through the PDM microphones. The line is open all the time, no need to press any buttons to talk, but the volume control works as in the default testing procedure. Dependencies ************ For the list of dependencies, check the application's source files.