diff core/I2c_Codec.cpp @ 145:8ff5668bbbad

Further updates and refactoring of the I2c_Codec class
author Giulio Moro <giuliomoro@yahoo.it>
date Mon, 14 Sep 2015 21:38:09 +0100
parents d064234468cd
children e9a2f31dff7b 94751ad27fd6
line wrap: on
line diff
--- a/core/I2c_Codec.cpp	Mon Sep 14 17:31:24 2015 +0100
+++ b/core/I2c_Codec.cpp	Mon Sep 14 21:38:09 2015 +0100
@@ -43,20 +43,33 @@
 	// see datasehet for TLV320AIC3104 from page 44
 	if(writeRegister(0x02, 0x00))	// Codec sample rate register: fs_ref / 1
 		return 1;
+	//	The sampling frequency is given as f_{S(ref)} = (PLLCLK_IN × K × R)/(2048 × P)
+	// The master clock PLLCLK_IN is 12MHz
+	// K can be varied in intervals of resolution of 0.0001 up to 63.9999
+	// using P=8 and R=1 gives a resolution of 0.0732421875Hz ( 0.000166% at 44.1kHz)
+	// to obtain Fs=44100 we need to have K=60.2112
+
+	if(setPllP(8))
+		return 1;
+	if(setPllR(1))
+		return 1;
+	if(setAudioSamplingRate(44100)) //this will automatically find and set K for the given P and R so that Fs=44100
+		return 1;
 //	if(writeRegister(0x03, 0x91))	// PLL register A: enable
 //		return 1;
-	if(setPllP(1))
-		return 1;
 //	if(writeRegister(0x04, 0x1C))	// PLL register B
 //		return 1;
 //	if(writeRegister(0x05, 0x52))	// PLL register C
 //		return 1;
 //	if(writeRegister(0x06, 0x40))	// PLL register D
 //		return 1;
-	if(setPllD(5264)) //7.5264 gives 44.1kHz nominal value with a 12MHz master clock
-		return 1;
-	if(setPllJ(7))
-		return 1;
+//	if(writeRegister(0x0B, 0x01))	// Audio codec overflow flag register: PLL R = 1
+//		return 1;
+
+//	if(setPllD(5264)) //7.5264 gives 44.1kHz nominal value with a 12MHz master clock
+//		return 1;
+//	if(setPllJ(7))
+//		return 1;
 	if(dual_rate) {
 		if(writeRegister(0x07, 0xEA))	// Codec datapath register: 44.1kHz; dual rate; standard datapath
 			return 1;
@@ -71,10 +84,6 @@
 		return 1;
 	if(writeRegister(0x0A, 0x00))	// Audio serial control register C: 0 bit offset
 		return 1;
-//	if(writeRegister(0x0B, 0x01))	// Audio codec overflow flag register: PLL R = 1
-//		return 1;
-	if(setPllR(1))
-		return 1;
 	if(writeRegister(0x0C, 0x00))	// Digital filter register: disabled
 		return 1;
 	if(writeRegister(0x0D, 0x00))	// Headset / button press register A: disabled
@@ -205,8 +214,6 @@
 	return 0;
 }
 int I2c_Codec::setAudioSamplingRate(float newSamplingRate){
-	int pllP=getPllP(); //TODO: create get/set for pllP and pllR
-	int pllR=1;
 	long int PLLCLK_IN=12000000;
 	//	f_{S(ref)} = (PLLCLK_IN × K × R)/(2048 × P)
 	float k = ((double)(newSamplingRate * pllP * 2048.0f/(float)pllR)) / PLLCLK_IN ;