diff core/RTAudio.cpp @ 178:a156a694864d

-p flag now indicates the buffer size in audio samples. Closes #1520
author Giulio Moro <giuliomoro@yahoo.it>
date Sat, 02 Jan 2016 13:08:39 +0100
parents 3b364fb8c4ee
children e23c304d264f
line wrap: on
line diff
--- a/core/RTAudio.cpp	Mon Dec 28 17:50:51 2015 +0100
+++ b/core/RTAudio.cpp	Sat Jan 02 13:08:39 2016 +0100
@@ -80,8 +80,10 @@
 
 // initAudio() prepares the infrastructure for running PRU-based real-time
 // audio, but does not actually start the calculations.
-// periodSize indicates the number of _sensor_ frames per period: the audio period size
-// is twice this value. In total, the audio latency in frames will be 4*periodSize,
+// periodSize indicates the number of audio frames per period: the analog period size
+// will depend on the number of analog channels, in such a way that
+// analogPeriodSize = 4*periodSize/numAnalogChannels
+// In total, the audio latency in frames will be 2*periodSize,
 // plus any latency inherent in the ADCs and DACs themselves.
 // useAnalog indicates whether to enable the ADC and DAC or just use the audio codec.
 // numAnalogChannels indicates how many ADC and DAC channels to use.
@@ -142,35 +144,33 @@
 	else
 		settings->numAnalogChannels = 2;
 
-	// Sanity check the combination of channels and period size
-	if(settings->numAnalogChannels <= 4 && settings->periodSize < 2) {
-		cout << "Error: " << settings->numAnalogChannels << " channels and period size of " << settings->periodSize << " not supported.\n";
-		return 1;
-	}
-	if(settings->numAnalogChannels <= 2 && settings->periodSize < 4) {
-		cout << "Error: " << settings->numAnalogChannels << " channels and period size of " << settings->periodSize << " not supported.\n";
-		return 1;
-	}
-
 	// Initialise the rendering environment: sample rates, frame counts, numbers of channels
 	gContext.audioSampleRate = 44100.0;
 	gContext.audioChannels = 2;
 
 	if(settings->useAnalog) {
-		gContext.audioFrames = settings->periodSize * settings->numAnalogChannels / 4;
+		gContext.audioFrames = settings->periodSize;
 
-		gContext.analogFrames = settings->periodSize;
+		gContext.analogFrames = gContext.audioFrames * 4 / settings->numAnalogChannels;
 		gContext.analogChannels = settings->numAnalogChannels;
 		gContext.analogSampleRate = gContext.audioSampleRate * 4.0 / (float)settings->numAnalogChannels;
 	}
 	else {
-		gContext.audioFrames = settings->periodSize * 2;
+		gContext.audioFrames = settings->periodSize;
 
 		gContext.analogFrames = 0;
 		gContext.analogChannels = 0;
 		gContext.analogSampleRate = 0;
 	}
 
+	// Sanity check the combination of channels and period size
+	if( (gContext.analogChannels <= 4 && gContext.analogFrames < 2) ||
+			(gContext.analogChannels <= 2 && gContext.analogFrames < 4))
+	{
+		cout << "Error: " << gContext.analogChannels << " channels and period size of " << gContext.analogFrames << " not supported.\n";
+		return 1;
+	}
+
 	// For now, digital frame rate is equal to audio frame rate
 	if(settings->useDigital) {
 		gContext.digitalFrames = gContext.audioFrames;
@@ -200,7 +200,7 @@
 	}
 
 	// Get the PRU memory buffers ready to go
-	if(gPRU->initialise(0, settings->periodSize, settings->numAnalogChannels, true)) {
+	if(gPRU->initialise(0, gContext.analogFrames, gContext.analogChannels, true)) {
 		cout << "Error: unable to initialise PRU\n";
 		return 1;
 	}