Pārlūkot izejas kodu

Recover quickly from usb audio buffer underflow

teensy4-core
PaulStoffregen pirms 8 gadiem
vecāks
revīzija
f86ae59f14
2 mainītis faili ar 13 papildinājumiem un 1 dzēšanām
  1. +12
    -1
      teensy3/usb_audio.cpp
  2. +1
    -0
      teensy3/usb_audio.h

+ 12
- 1
teensy3/usb_audio.cpp Parādīt failu

@@ -41,6 +41,7 @@ audio_block_t * AudioInputUSB::incoming_right;
audio_block_t * AudioInputUSB::ready_left;
audio_block_t * AudioInputUSB::ready_right;
uint16_t AudioInputUSB::incoming_count;
uint8_t AudioInputUSB::underflow_flag;

#define DMABUFATTR __attribute__ ((section(".dmabuffers"), aligned (4)))
uint16_t usb_audio_receive_buffer[AUDIO_RX_SIZE/2] DMABUFATTR;
@@ -54,6 +55,7 @@ void AudioInputUSB::begin(void)
incoming_right = NULL;
ready_left = NULL;
ready_right = NULL;
underflow_flag = 1;
// update_responsibility = update_setup();
// TODO: update responsibility is tough, partly because the USB
// interrupts aren't sychronous to the audio library block size,
@@ -138,7 +140,15 @@ void usb_audio_receive_callback(unsigned int len)
}
AudioInputUSB::incoming_left = left;
AudioInputUSB::incoming_right = right;
count = 0;
if (AudioInputUSB::underflow_flag) {
AudioInputUSB::underflow_flag = 0;
memset(left->data + count, 0, AUDIO_BLOCK_SAMPLES);
memset(right->data + count, 0, AUDIO_BLOCK_SAMPLES);
count = AUDIO_BLOCK_SAMPLES/2;
serial_print("*");
} else {
count = 0;
}
}
}
AudioInputUSB::incoming_count = count;
@@ -159,6 +169,7 @@ void AudioInputUSB::update(void)
//serial_phex(c);
//serial_print(".");
if (!left || !right) {
underflow_flag = 1;
//serial_print("#"); // buffer underrun - PC sending too slow
}
if (left) {

+ 1
- 0
teensy3/usb_audio.h Parādīt failu

@@ -31,6 +31,7 @@ private:
static audio_block_t *ready_left;
static audio_block_t *ready_right;
static uint16_t incoming_count;
static uint8_t underflow_flag;
};

#endif // __cplusplus

Notiek ielāde…
Atcelt
Saglabāt