|
#define | ARM_SAI_API_VERSION ARM_DRIVER_VERSION_MAJOR_MINOR(1,2) /* API version */ |
|
#define | _ARM_Driver_SAI_(n) Driver_SAI##n |
|
#define | ARM_Driver_SAI_(n) _ARM_Driver_SAI_(n) |
|
#define | ARM_SAI_CONTROL_Msk (0xFFUL) |
|
#define | ARM_SAI_CONFIGURE_TX (0x01UL) |
| Configure Transmitter; arg1 and arg2 provide additional configuration.
|
|
#define | ARM_SAI_CONFIGURE_RX (0x02UL) |
| Configure Receiver; arg1 and arg2 provide additional configuration.
|
|
#define | ARM_SAI_CONTROL_TX (0x03UL) |
| Control Transmitter; arg1.0: 0=disable (default), 1=enable; arg1.1: mute.
|
|
#define | ARM_SAI_CONTROL_RX (0x04UL) |
| Control Receiver; arg1.0: 0=disable (default), 1=enable.
|
|
#define | ARM_SAI_MASK_SLOTS_TX (0x05UL) |
| Mask Transmitter slots; arg1 = mask (bit: 0=active, 1=inactive); all configured slots are active by default.
|
|
#define | ARM_SAI_MASK_SLOTS_RX (0x06UL) |
| Mask Receiver slots; arg1 = mask (bit: 0=active, 1=inactive); all configured slots are active by default.
|
|
#define | ARM_SAI_ABORT_SEND (0x07UL) |
| Abort ARM_SAI_Send.
|
|
#define | ARM_SAI_ABORT_RECEIVE (0x08UL) |
| Abort ARM_SAI_Receive.
|
|
#define | ARM_SAI_MODE_Pos 8 |
|
#define | ARM_SAI_MODE_Msk (1UL << ARM_SAI_MODE_Pos) |
|
#define | ARM_SAI_MODE_MASTER (1UL << ARM_SAI_MODE_Pos) |
| Master Mode.
|
|
#define | ARM_SAI_MODE_SLAVE (0UL << ARM_SAI_MODE_Pos) |
| Slave Mode (default)
|
|
#define | ARM_SAI_SYNCHRONIZATION_Pos 9 |
|
#define | ARM_SAI_SYNCHRONIZATION_Msk (1UL << ARM_SAI_SYNCHRONIZATION_Pos) |
|
#define | ARM_SAI_ASYNCHRONOUS (0UL << ARM_SAI_SYNCHRONIZATION_Pos) |
| Asynchronous (default)
|
|
#define | ARM_SAI_SYNCHRONOUS (1UL << ARM_SAI_SYNCHRONIZATION_Pos) |
| Synchronous.
|
|
#define | ARM_SAI_PROTOCOL_Pos 10 |
|
#define | ARM_SAI_PROTOCOL_Msk (7UL << ARM_SAI_PROTOCOL_Pos) |
|
#define | ARM_SAI_PROTOCOL_USER (0UL << ARM_SAI_PROTOCOL_Pos) |
| User defined (default)
|
|
#define | ARM_SAI_PROTOCOL_I2S (1UL << ARM_SAI_PROTOCOL_Pos) |
| I2S.
|
|
#define | ARM_SAI_PROTOCOL_MSB_JUSTIFIED (2UL << ARM_SAI_PROTOCOL_Pos) |
| MSB (left) justified.
|
|
#define | ARM_SAI_PROTOCOL_LSB_JUSTIFIED (3UL << ARM_SAI_PROTOCOL_Pos) |
| LSB (right) justified.
|
|
#define | ARM_SAI_PROTOCOL_PCM_SHORT (4UL << ARM_SAI_PROTOCOL_Pos) |
| PCM with short frame.
|
|
#define | ARM_SAI_PROTOCOL_PCM_LONG (5UL << ARM_SAI_PROTOCOL_Pos) |
| PCM with long frame.
|
|
#define | ARM_SAI_PROTOCOL_AC97 (6UL << ARM_SAI_PROTOCOL_Pos) |
| AC'97.
|
|
#define | ARM_SAI_DATA_SIZE_Pos 13 |
|
#define | ARM_SAI_DATA_SIZE_Msk (0x1FUL << ARM_SAI_DATA_SIZE_Pos) |
|
#define | ARM_SAI_DATA_SIZE(n) ((((n)-1UL)&0x1FUL) << ARM_SAI_DATA_SIZE_Pos) |
| Data size in bits (8..32)
|
|
#define | ARM_SAI_BIT_ORDER_Pos 18 |
|
#define | ARM_SAI_BIT_ORDER_Msk (1UL << ARM_SAI_BIT_ORDER_Pos) |
|
#define | ARM_SAI_MSB_FIRST (0UL << ARM_SAI_BIT_ORDER_Pos) |
| Data is transferred with MSB first (default)
|
|
#define | ARM_SAI_LSB_FIRST (1UL << ARM_SAI_BIT_ORDER_Pos) |
| Data is transferred with LSB first; User Protocol only (ignored otherwise)
|
|
#define | ARM_SAI_MONO_MODE (1UL << 19) |
| Mono Mode (only for I2S, MSB/LSB justified)
|
|
#define | ARM_SAI_COMPANDING_Pos 20 |
|
#define | ARM_SAI_COMPANDING_Msk (3UL << ARM_SAI_COMPANDING_Pos) |
|
#define | ARM_SAI_COMPANDING_NONE (0UL << ARM_SAI_COMPANDING_Pos) |
| No companding (default)
|
|
#define | ARM_SAI_COMPANDING_A_LAW (2UL << ARM_SAI_COMPANDING_Pos) |
| A-Law companding.
|
|
#define | ARM_SAI_COMPANDING_U_LAW (3UL << ARM_SAI_COMPANDING_Pos) |
| u-Law companding
|
|
#define | ARM_SAI_CLOCK_POLARITY_Pos 23 |
|
#define | ARM_SAI_CLOCK_POLARITY_Msk (1UL << ARM_SAI_CLOCK_POLARITY_Pos) |
|
#define | ARM_SAI_CLOCK_POLARITY_0 (0UL << ARM_SAI_CLOCK_POLARITY_Pos) |
| Drive on falling edge, Capture on rising edge (default)
|
|
#define | ARM_SAI_CLOCK_POLARITY_1 (1UL << ARM_SAI_CLOCK_POLARITY_Pos) |
| Drive on rising edge, Capture on falling edge.
|
|
#define | ARM_SAI_MCLK_PIN_Pos 24 |
|
#define | ARM_SAI_MCLK_PIN_Msk (3UL << ARM_SAI_MCLK_PIN_Pos) |
|
#define | ARM_SAI_MCLK_PIN_INACTIVE (0UL << ARM_SAI_MCLK_PIN_Pos) |
| MCLK not used (default)
|
|
#define | ARM_SAI_MCLK_PIN_OUTPUT (1UL << ARM_SAI_MCLK_PIN_Pos) |
| MCLK is output (Master only)
|
|
#define | ARM_SAI_MCLK_PIN_INPUT (2UL << ARM_SAI_MCLK_PIN_Pos) |
| MCLK is input (Master only)
|
|
#define | ARM_SAI_FRAME_LENGTH_Pos 0 |
|
#define | ARM_SAI_FRAME_LENGTH_Msk (0x3FFUL << ARM_SAI_FRAME_LENGTH_Pos) |
|
#define | ARM_SAI_FRAME_LENGTH(n) ((((n)-1UL)&0x3FFUL) << ARM_SAI_FRAME_LENGTH_Pos) |
| Frame length in bits (8..1024); default depends on protocol and data.
|
|
#define | ARM_SAI_FRAME_SYNC_WIDTH_Pos 10 |
|
#define | ARM_SAI_FRAME_SYNC_WIDTH_Msk (0xFFUL << ARM_SAI_FRAME_SYNC_WIDTH_Pos) |
|
#define | ARM_SAI_FRAME_SYNC_WIDTH(n) ((((n)-1UL)&0xFFUL) << ARM_SAI_FRAME_SYNC_WIDTH_Pos) |
| Frame Sync width in bits (1..256); default=1; User Protocol only (ignored otherwise)
|
|
#define | ARM_SAI_FRAME_SYNC_POLARITY_Pos 18 |
|
#define | ARM_SAI_FRAME_SYNC_POLARITY_Msk (1UL << ARM_SAI_FRAME_SYNC_POLARITY_Pos) |
|
#define | ARM_SAI_FRAME_SYNC_POLARITY_HIGH (0UL << ARM_SAI_FRAME_SYNC_POLARITY_Pos) |
| Frame Sync is active high (default); User Protocol only (ignored otherwise)
|
|
#define | ARM_SAI_FRAME_SYNC_POLARITY_LOW (1UL << ARM_SAI_FRAME_SYNC_POLARITY_Pos) |
| Frame Sync is active low; User Protocol only (ignored otherwise)
|
|
#define | ARM_SAI_FRAME_SYNC_EARLY (1UL << 19) |
| Frame Sync one bit before the first bit of the frame; User Protocol only (ignored otherwise)
|
|
#define | ARM_SAI_SLOT_COUNT_Pos 20 |
|
#define | ARM_SAI_SLOT_COUNT_Msk (0x1FUL << ARM_SAI_SLOT_COUNT_Pos) |
|
#define | ARM_SAI_SLOT_COUNT(n) ((((n)-1UL)&0x1FUL) << ARM_SAI_SLOT_COUNT_Pos) |
| Number of slots in frame (1..32); default=1; User Protocol only (ignored otherwise)
|
|
#define | ARM_SAI_SLOT_SIZE_Pos 25 |
|
#define | ARM_SAI_SLOT_SIZE_Msk (3UL << ARM_SAI_SLOT_SIZE_Pos) |
|
#define | ARM_SAI_SLOT_SIZE_DEFAULT (0UL << ARM_SAI_SLOT_SIZE_Pos) |
| Slot size is equal to data size (default)
|
|
#define | ARM_SAI_SLOT_SIZE_16 (1UL << ARM_SAI_SLOT_SIZE_Pos) |
| Slot size = 16 bits; User Protocol only (ignored otherwise)
|
|
#define | ARM_SAI_SLOT_SIZE_32 (3UL << ARM_SAI_SLOT_SIZE_Pos) |
| Slot size = 32 bits; User Protocol only (ignored otherwise)
|
|
#define | ARM_SAI_SLOT_OFFSET_Pos 27 |
|
#define | ARM_SAI_SLOT_OFFSET_Msk (0x1FUL << ARM_SAI_SLOT_OFFSET_Pos) |
|
#define | ARM_SAI_SLOT_OFFSET(n) (((n)&0x1FUL) << ARM_SAI_SLOT_OFFSET_Pos) |
| Offset of first data bit in slot (0..31); default=0; User Protocol only (ignored otherwise)
|
|
#define | ARM_SAI_AUDIO_FREQ_Msk (0x0FFFFFUL) |
| Audio frequency mask.
|
|
#define | ARM_SAI_MCLK_PRESCALER_Pos 20 |
|
#define | ARM_SAI_MCLK_PRESCALER_Msk (0xFFFUL << ARM_SAI_MCLK_PRESCALER_Pos) |
|
#define | ARM_SAI_MCLK_PRESCALER(n) ((((n)-1UL)&0xFFFUL) << ARM_SAI_MCLK_PRESCALER_Pos) |
| MCLK prescaler; Audio_frequency = MCLK/n; n = 1..4096 (default=1)
|
|
#define | ARM_SAI_ERROR_SYNCHRONIZATION (ARM_DRIVER_ERROR_SPECIFIC - 1) |
| Specified Synchronization not supported.
|
|
#define | ARM_SAI_ERROR_PROTOCOL (ARM_DRIVER_ERROR_SPECIFIC - 2) |
| Specified Protocol not supported.
|
|
#define | ARM_SAI_ERROR_DATA_SIZE (ARM_DRIVER_ERROR_SPECIFIC - 3) |
| Specified Data size not supported.
|
|
#define | ARM_SAI_ERROR_BIT_ORDER (ARM_DRIVER_ERROR_SPECIFIC - 4) |
| Specified Bit order not supported.
|
|
#define | ARM_SAI_ERROR_MONO_MODE (ARM_DRIVER_ERROR_SPECIFIC - 5) |
| Specified Mono mode not supported.
|
|
#define | ARM_SAI_ERROR_COMPANDING (ARM_DRIVER_ERROR_SPECIFIC - 6) |
| Specified Companding not supported.
|
|
#define | ARM_SAI_ERROR_CLOCK_POLARITY (ARM_DRIVER_ERROR_SPECIFIC - 7) |
| Specified Clock polarity not supported.
|
|
#define | ARM_SAI_ERROR_AUDIO_FREQ (ARM_DRIVER_ERROR_SPECIFIC - 8) |
| Specified Audio frequency not supported.
|
|
#define | ARM_SAI_ERROR_MCLK_PIN (ARM_DRIVER_ERROR_SPECIFIC - 9) |
| Specified MCLK Pin setting not supported.
|
|
#define | ARM_SAI_ERROR_MCLK_PRESCALER (ARM_DRIVER_ERROR_SPECIFIC - 10) |
| Specified MCLK Prescaler not supported.
|
|
#define | ARM_SAI_ERROR_FRAME_LENGTH (ARM_DRIVER_ERROR_SPECIFIC - 11) |
| Specified Frame length not supported.
|
|
#define | ARM_SAI_ERROR_FRAME_LENGHT (ARM_DRIVER_ERROR_SPECIFIC - 11) |
| Specified Frame length not supported.
|
|
#define | ARM_SAI_ERROR_FRAME_SYNC_WIDTH (ARM_DRIVER_ERROR_SPECIFIC - 12) |
| Specified Frame Sync width not supported.
|
|
#define | ARM_SAI_ERROR_FRAME_SYNC_POLARITY (ARM_DRIVER_ERROR_SPECIFIC - 13) |
| Specified Frame Sync polarity not supported.
|
|
#define | ARM_SAI_ERROR_FRAME_SYNC_EARLY (ARM_DRIVER_ERROR_SPECIFIC - 14) |
| Specified Frame Sync early not supported.
|
|
#define | ARM_SAI_ERROR_SLOT_COUNT (ARM_DRIVER_ERROR_SPECIFIC - 15) |
| Specified Slot count not supported.
|
|
#define | ARM_SAI_ERROR_SLOT_SIZE (ARM_DRIVER_ERROR_SPECIFIC - 16) |
| Specified Slot size not supported.
|
|
#define | ARM_SAI_ERROR_SLOT_OFFESET (ARM_DRIVER_ERROR_SPECIFIC - 17) |
| Specified Slot offset not supported.
|
|
#define | ARM_SAI_EVENT_SEND_COMPLETE (1UL << 0) |
| Send completed.
|
|
#define | ARM_SAI_EVENT_RECEIVE_COMPLETE (1UL << 1) |
| Receive completed.
|
|
#define | ARM_SAI_EVENT_TX_UNDERFLOW (1UL << 2) |
| Transmit data not available.
|
|
#define | ARM_SAI_EVENT_RX_OVERFLOW (1UL << 3) |
| Receive data overflow.
|
|
#define | ARM_SAI_EVENT_FRAME_ERROR (1UL << 4) |
| Sync Frame error in Slave mode (optional)
|
|