does not work yet. Sound starts but then stops after a few seconds, whole thing hangs. Published so as I can import through mbed CLI.

Dependencies:   mbed sinelookup SDFileSystem_Copy_of_mbed_version I2S

Committer:
roryhand
Date:
Tue Oct 23 19:02:45 2018 +0000
Revision:
5:5b120a2d9249
Parent:
4:1a9482a07ee2
Child:
6:fd6ae534d120
chsnged to work with 8khz file (does not work yet)

Who changed what in which revision?

UserRevisionLine numberNew contents of line
roryhand 0:004cb0595aa8 1
roryhand 0:004cb0595aa8 2 // 24/03/2018 update - I appear to be able to address the device and write something, as I am getting an ACK returned from the i2c write() function.
roryhand 0:004cb0595aa8 3 //however if i use the write function with 4 arguments (as opposed to just 1 argument) then it doesnt work
roryhand 0:004cb0595aa8 4 //only works with the 1 argument version!!!
roryhand 0:004cb0595aa8 5
roryhand 0:004cb0595aa8 6
roryhand 0:004cb0595aa8 7 //THIS VERSION WORKED, CHANGED SOME THINGS, THEN CHANGED THEM BACK. NOW IT NO LONGER WORKS!!!!
roryhand 0:004cb0595aa8 8 #include "mbed.h"
roryhand 0:004cb0595aa8 9 #include "sinelookup.h"
roryhand 0:004cb0595aa8 10 #include "I2S.h"
roryhand 0:004cb0595aa8 11 #define sample_freq 48000
roryhand 0:004cb0595aa8 12 DigitalOut myled(LED1);
roryhand 0:004cb0595aa8 13 DigitalOut led2(LED2);
roryhand 0:004cb0595aa8 14 DigitalOut led3(LED3);
roryhand 0:004cb0595aa8 15 Ticker sampletick;
roryhand 0:004cb0595aa8 16 Timer t;
roryhand 0:004cb0595aa8 17 #include "SDFileSystem.h"
roryhand 0:004cb0595aa8 18 #include "WOLFSON_config.h"
roryhand 0:004cb0595aa8 19 Serial pc(USBTX, USBRX); // tx, rx //FOR DEBUGGING PROGRAM USING GNU SCREEN
roryhand 0:004cb0595aa8 20 DigitalOut cs(p8);
roryhand 0:004cb0595aa8 21 I2S i2s(I2S_TRANSMIT,p5,p6,p7);
roryhand 0:004cb0595aa8 22 I2C i2c(p9, p10);
roryhand 0:004cb0595aa8 23
roryhand 0:004cb0595aa8 24 SDFileSystem sd(p11, p12, p13, p8, "sd"); // the new pinout that i am using
roryhand 0:004cb0595aa8 25
roryhand 0:004cb0595aa8 26 typedef struct uFMT_STRUCT{
roryhand 0:004cb0595aa8 27 short comp_code;
roryhand 0:004cb0595aa8 28 short num_channels;
roryhand 0:004cb0595aa8 29 unsigned sample_rate;
roryhand 0:004cb0595aa8 30 unsigned avg_Bps;
roryhand 0:004cb0595aa8 31 short block_align;
roryhand 0:004cb0595aa8 32 short sig_bps;
roryhand 0:004cb0595aa8 33 } FMT_STRUCT;
roryhand 0:004cb0595aa8 34
roryhand 0:004cb0595aa8 35 typedef struct uDATA_STRUCT {
roryhand 0:004cb0595aa8 36 unsigned subchunk2_ID;
roryhand 0:004cb0595aa8 37 unsigned subchunk2_size;
roryhand 0:004cb0595aa8 38 char * data_buf;
roryhand 0:004cb0595aa8 39 }DATA_STRUCT;
roryhand 0:004cb0595aa8 40 short hello;
roryhand 0:004cb0595aa8 41 int i = 0;
roryhand 0:004cb0595aa8 42 int h = 0;
roryhand 0:004cb0595aa8 43 int bufflen = 1;
roryhand 0:004cb0595aa8 44 int buffer[1];
roryhand 0:004cb0595aa8 45 int AudioFormat, NumChannels, SampleRate, BitsPerSample ;
roryhand 0:004cb0595aa8 46 char *slice_buf;
roryhand 5:5b120a2d9249 47 short *data_sptr;
roryhand 3:6fba0a044d85 48 unsigned char *data_bptr;
roryhand 3:6fba0a044d85 49 int *data_wptr;
roryhand 3:6fba0a044d85 50 unsigned channel;
roryhand 0:004cb0595aa8 51 int newvar;
roryhand 3:6fba0a044d85 52 long slice, num_slices;
roryhand 3:6fba0a044d85 53 int verbosity = 0;
roryhand 0:004cb0595aa8 54 //long long slice_value;
roryhand 5:5b120a2d9249 55 int slice_value[1];
roryhand 0:004cb0595aa8 56 FILE *my_wav;
roryhand 0:004cb0595aa8 57 FMT_STRUCT wav_format;
roryhand 0:004cb0595aa8 58 DATA_STRUCT wav_data;
roryhand 0:004cb0595aa8 59
roryhand 0:004cb0595aa8 60 Ticker flipper;
roryhand 0:004cb0595aa8 61 //test
roryhand 0:004cb0595aa8 62 void flip() {
roryhand 0:004cb0595aa8 63 led2 = !led2;
roryhand 0:004cb0595aa8 64 }
roryhand 0:004cb0595aa8 65
roryhand 0:004cb0595aa8 66
roryhand 0:004cb0595aa8 67 void isr()
roryhand 0:004cb0595aa8 68 {
roryhand 3:6fba0a044d85 69 buffer[0] = (*data_sptr)>>1;
roryhand 3:6fba0a044d85 70 myled = 1;
roryhand 3:6fba0a044d85 71 int bufflen = sizeof(buffer);
roryhand 5:5b120a2d9249 72 if(verbosity){
roryhand 4:1a9482a07ee2 73 printf("buffer data: %d \n\r",buffer);
roryhand 4:1a9482a07ee2 74 printf("data_sptr data: %d \n\r",data_sptr);
roryhand 5:5b120a2d9249 75 }
roryhand 3:6fba0a044d85 76 //t.start();
roryhand 0:004cb0595aa8 77 //buffer[0] = (int*)data_sptr;
roryhand 0:004cb0595aa8 78 //buffer[0] = newvar;
roryhand 0:004cb0595aa8 79 //buffer[0] = sine16lookup[i];//>>1;//sine16lookup[i];//scale down volume a bit on amp//how would this scale down the volume a bit??
roryhand 0:004cb0595aa8 80 //buffer[0] = *fp;
roryhand 0:004cb0595aa8 81 //printf("value: %d",data_sptr);
roryhand 4:1a9482a07ee2 82 i2s.write(data_sptr, bufflen);//Send next PWM value to amp
roryhand 3:6fba0a044d85 83 //t.stop();
roryhand 3:6fba0a044d85 84 //printf("The time taken was %f seconds\n", t.read());
roryhand 3:6fba0a044d85 85 myled = 0;
roryhand 0:004cb0595aa8 86 }
roryhand 1:ec4e2020522c 87
roryhand 0:004cb0595aa8 88
roryhand 1:ec4e2020522c 89
roryhand 0:004cb0595aa8 90
roryhand 0:004cb0595aa8 91 void wm8731_setup(int chip_addr, int addr, int cmd){
roryhand 0:004cb0595aa8 92 addr = addr << 1;
roryhand 0:004cb0595aa8 93 addr = addr|((cmd >> 8 ))& 0x01;//mess around with order of operations
roryhand 0:004cb0595aa8 94 cmd = cmd&0xFF;
roryhand 0:004cb0595aa8 95 i2c.start();
roryhand 0:004cb0595aa8 96 i2c.write( chip_addr );
roryhand 0:004cb0595aa8 97 i2c.write( addr );
roryhand 0:004cb0595aa8 98 i2c.write( cmd );
roryhand 0:004cb0595aa8 99 i2c.stop();
roryhand 0:004cb0595aa8 100 }
roryhand 0:004cb0595aa8 101
roryhand 0:004cb0595aa8 102
roryhand 0:004cb0595aa8 103 void wm8731_config(void){
roryhand 0:004cb0595aa8 104 wm8731_setup( WM8731_ADDRESS, WM8731_REG_RESET, _WM8731_RESET );//1
roryhand 0:004cb0595aa8 105 wm8731_setup( WM8731_ADDRESS, WM8731_REG_LLINE_IN, _WM8731_LEFT_LINEIN );//2
roryhand 0:004cb0595aa8 106 wm8731_setup( WM8731_ADDRESS, WM8731_REG_RLINE_IN, _WM8731_RIGHT_LINEIN );//3
roryhand 0:004cb0595aa8 107 wm8731_setup( WM8731_ADDRESS, WM8731_REG_LHPHONE_OUT, _WM8731_LEFT_HP );//4
roryhand 0:004cb0595aa8 108 wm8731_setup( WM8731_ADDRESS, WM8731_REG_RHPHONE_OUT, _WM8731_RIGHT_HP );//5
roryhand 0:004cb0595aa8 109 wm8731_setup( WM8731_ADDRESS, WM8731_REG_ANALOG_PATH, _WM8731_ANALOGAUDIO );//6
roryhand 0:004cb0595aa8 110 wm8731_setup( WM8731_ADDRESS, WM8731_REG_DIGITAL_PATH, _WM8731_DIGITALAUDIO );//7
roryhand 0:004cb0595aa8 111 wm8731_setup( WM8731_ADDRESS, WM8731_REG_PDOWN_CTRL, _WM8731_POWER );//8
roryhand 0:004cb0595aa8 112 wm8731_setup( WM8731_ADDRESS, WM8731_REG_DIGITAL_IF, _WM8731_DAIF );//9
roryhand 0:004cb0595aa8 113 wm8731_setup( WM8731_ADDRESS, WM8731_REG_SAMPLING_CTRL, _WM8731_SAMPLING );//10
roryhand 0:004cb0595aa8 114 }
roryhand 0:004cb0595aa8 115
roryhand 0:004cb0595aa8 116 void wm8731_configTEST(void){
roryhand 0:004cb0595aa8 117 int addr = WM8731_REG_RESET;
roryhand 0:004cb0595aa8 118 int cmd = _WM8731_RESET;
roryhand 0:004cb0595aa8 119 addr = addr << 1;
roryhand 0:004cb0595aa8 120 addr = addr|((cmd >> 8 ))& 0x01;//mess around with order of operations
roryhand 0:004cb0595aa8 121 cmd = cmd&0xFF;
roryhand 0:004cb0595aa8 122 i2c.start();
roryhand 0:004cb0595aa8 123 i2c.write( WM8731_ADDRESS );
roryhand 0:004cb0595aa8 124 i2c.write( addr );
roryhand 0:004cb0595aa8 125 i2c.write( cmd );
roryhand 0:004cb0595aa8 126 i2c.stop();
roryhand 0:004cb0595aa8 127
roryhand 0:004cb0595aa8 128 addr = WM8731_REG_LLINE_IN;
roryhand 0:004cb0595aa8 129 cmd = _WM8731_LEFT_LINEIN;
roryhand 0:004cb0595aa8 130 addr = addr << 1;
roryhand 0:004cb0595aa8 131 addr = addr|((cmd >> 8 )) & 0x01;
roryhand 0:004cb0595aa8 132 cmd = cmd&0xFF;
roryhand 0:004cb0595aa8 133 i2c.start();
roryhand 0:004cb0595aa8 134 i2c.write( WM8731_ADDRESS );//take Fergus' suggestion and declare these to known values EARLIER in program
roryhand 0:004cb0595aa8 135 i2c.write( addr );
roryhand 0:004cb0595aa8 136 i2c.write( cmd );
roryhand 0:004cb0595aa8 137 i2c.stop();
roryhand 0:004cb0595aa8 138
roryhand 0:004cb0595aa8 139
roryhand 0:004cb0595aa8 140 addr = WM8731_REG_RLINE_IN;
roryhand 0:004cb0595aa8 141 cmd = _WM8731_RIGHT_LINEIN;
roryhand 0:004cb0595aa8 142 addr = addr << 1;
roryhand 0:004cb0595aa8 143 addr = addr|((cmd >> 8 )) & 0x01;
roryhand 0:004cb0595aa8 144 cmd = cmd&0xFF;
roryhand 0:004cb0595aa8 145 i2c.start();
roryhand 0:004cb0595aa8 146 i2c.write( WM8731_ADDRESS );//take Fergus' suggestion and declare these to known values EARLIER in program
roryhand 0:004cb0595aa8 147 i2c.write( addr );
roryhand 0:004cb0595aa8 148 i2c.write( cmd );
roryhand 0:004cb0595aa8 149 i2c.stop();
roryhand 0:004cb0595aa8 150
roryhand 0:004cb0595aa8 151
roryhand 0:004cb0595aa8 152 //4
roryhand 0:004cb0595aa8 153 addr = WM8731_REG_LHPHONE_OUT;
roryhand 0:004cb0595aa8 154 cmd = _WM8731_LEFT_HP;
roryhand 0:004cb0595aa8 155 addr = addr << 1;
roryhand 0:004cb0595aa8 156 addr = addr|((cmd >> 8 )) & 0x01;
roryhand 0:004cb0595aa8 157 cmd = cmd&0xFF;
roryhand 0:004cb0595aa8 158 i2c.start();
roryhand 0:004cb0595aa8 159 i2c.write( WM8731_ADDRESS );
roryhand 0:004cb0595aa8 160 i2c.write( addr );//WM8731_REG_LHPHONE_OUT, _WM8731_LEFT_HP
roryhand 0:004cb0595aa8 161 i2c.write(cmd);
roryhand 0:004cb0595aa8 162 i2c.stop();
roryhand 0:004cb0595aa8 163
roryhand 0:004cb0595aa8 164 //5
roryhand 0:004cb0595aa8 165 addr = WM8731_REG_RHPHONE_OUT;
roryhand 0:004cb0595aa8 166 cmd = _WM8731_RIGHT_HP;
roryhand 0:004cb0595aa8 167 addr = addr << 1;
roryhand 0:004cb0595aa8 168 addr = addr|((cmd >> 8 )) & 0x01;
roryhand 0:004cb0595aa8 169 cmd = cmd&0xFF;
roryhand 0:004cb0595aa8 170 i2c.start();
roryhand 0:004cb0595aa8 171 i2c.write( WM8731_ADDRESS );//WM8731_REG_RHPHONE_OUT, _WM8731_RIGHT_HP
roryhand 0:004cb0595aa8 172 i2c.write( addr );
roryhand 0:004cb0595aa8 173 i2c.write( cmd );
roryhand 0:004cb0595aa8 174 i2c.stop();
roryhand 0:004cb0595aa8 175
roryhand 0:004cb0595aa8 176
roryhand 0:004cb0595aa8 177 //6
roryhand 0:004cb0595aa8 178 addr = WM8731_REG_ANALOG_PATH;
roryhand 0:004cb0595aa8 179 cmd = _WM8731_ANALOGAUDIO;
roryhand 0:004cb0595aa8 180 addr = addr << 1;
roryhand 0:004cb0595aa8 181 addr = addr|((cmd >> 8 )) & 0x01;
roryhand 0:004cb0595aa8 182 cmd = cmd&0xFF;
roryhand 0:004cb0595aa8 183 i2c.start();
roryhand 0:004cb0595aa8 184 i2c.write( WM8731_ADDRESS );//WM8731_REG_ANALOG_PATH, _WM8731_ANALOGAUDIO
roryhand 0:004cb0595aa8 185 i2c.write( addr );
roryhand 0:004cb0595aa8 186 i2c.write( cmd );
roryhand 0:004cb0595aa8 187 i2c.stop();
roryhand 0:004cb0595aa8 188
roryhand 0:004cb0595aa8 189 //7
roryhand 0:004cb0595aa8 190 addr = WM8731_REG_DIGITAL_PATH;
roryhand 0:004cb0595aa8 191 cmd = _WM8731_DIGITALAUDIO;
roryhand 0:004cb0595aa8 192 addr = addr << 1;
roryhand 0:004cb0595aa8 193 addr = addr|((cmd >> 8 )) & 0x01;
roryhand 0:004cb0595aa8 194 cmd = cmd&0xFF;
roryhand 0:004cb0595aa8 195 i2c.start();
roryhand 0:004cb0595aa8 196 i2c.write( WM8731_ADDRESS );//WM8731_REG_DIGITAL_PATH, _WM8731_DIGITALAUDIO
roryhand 0:004cb0595aa8 197 i2c.write( addr );
roryhand 0:004cb0595aa8 198 i2c.write( cmd );
roryhand 0:004cb0595aa8 199 i2c.stop();
roryhand 0:004cb0595aa8 200
roryhand 0:004cb0595aa8 201 //8
roryhand 0:004cb0595aa8 202 addr = WM8731_REG_PDOWN_CTRL;
roryhand 0:004cb0595aa8 203 cmd = _WM8731_POWER;
roryhand 0:004cb0595aa8 204 addr = addr << 1;
roryhand 0:004cb0595aa8 205 addr = addr|((cmd >> 8 )) & 0x01;
roryhand 0:004cb0595aa8 206 cmd = cmd&0xFF;
roryhand 0:004cb0595aa8 207 i2c.start();
roryhand 0:004cb0595aa8 208 i2c.write( WM8731_ADDRESS );//WM8731_REG_PDOWN_CTRL, _WM8731_POWER)
roryhand 0:004cb0595aa8 209 i2c.write( addr );
roryhand 0:004cb0595aa8 210 i2c.write( cmd );
roryhand 0:004cb0595aa8 211 i2c.stop();
roryhand 0:004cb0595aa8 212
roryhand 0:004cb0595aa8 213
roryhand 0:004cb0595aa8 214 //9
roryhand 0:004cb0595aa8 215 addr = WM8731_REG_DIGITAL_IF;
roryhand 0:004cb0595aa8 216 cmd = _WM8731_DAIF;
roryhand 0:004cb0595aa8 217 addr = addr << 1;
roryhand 0:004cb0595aa8 218 addr = addr|((cmd >> 8 )) & 0x01;
roryhand 0:004cb0595aa8 219 cmd = cmd&0xFF;
roryhand 0:004cb0595aa8 220 i2c.start();
roryhand 0:004cb0595aa8 221 i2c.write( WM8731_ADDRESS );
roryhand 0:004cb0595aa8 222 i2c.write( addr );//WM8731_REG_DIGITAL_IF, _WM8731_DAIF
roryhand 0:004cb0595aa8 223 i2c.write( cmd );
roryhand 0:004cb0595aa8 224 i2c.stop();
roryhand 0:004cb0595aa8 225
roryhand 0:004cb0595aa8 226
roryhand 0:004cb0595aa8 227 //10
roryhand 0:004cb0595aa8 228 addr = WM8731_REG_SAMPLING_CTRL;
roryhand 0:004cb0595aa8 229 cmd = _WM8731_SAMPLING;
roryhand 0:004cb0595aa8 230 addr = addr << 1;
roryhand 0:004cb0595aa8 231 addr = addr|((cmd >> 8 )) & 0x01;
roryhand 0:004cb0595aa8 232 cmd = cmd&0xFF;
roryhand 0:004cb0595aa8 233 i2c.start();
roryhand 0:004cb0595aa8 234 i2c.write( WM8731_ADDRESS );//WM8731_REG_SAMPLING_CTRL, _WM8731_SAMPLING
roryhand 0:004cb0595aa8 235 i2c.write( addr );
roryhand 0:004cb0595aa8 236 i2c.write( cmd );
roryhand 0:004cb0595aa8 237 i2c.stop();
roryhand 0:004cb0595aa8 238
roryhand 0:004cb0595aa8 239
roryhand 0:004cb0595aa8 240
roryhand 0:004cb0595aa8 241
roryhand 0:004cb0595aa8 242 //11
roryhand 0:004cb0595aa8 243 addr = WM8731_REG_ACTIVE_CTRL;
roryhand 0:004cb0595aa8 244 cmd = _WM8731_ACTIVATE;
roryhand 0:004cb0595aa8 245 addr = addr << 1;
roryhand 0:004cb0595aa8 246 addr = addr|((cmd >> 8 )) & 0x01;
roryhand 0:004cb0595aa8 247 cmd = cmd&0xFF;
roryhand 0:004cb0595aa8 248 i2c.start();
roryhand 0:004cb0595aa8 249 i2c.write( WM8731_ADDRESS );//WM8731_REG_SAMPLING_CTRL, _WM8731_SAMPLING
roryhand 0:004cb0595aa8 250 i2c.write( addr );
roryhand 0:004cb0595aa8 251 i2c.write( cmd );//there is also a deactive version!!
roryhand 0:004cb0595aa8 252 i2c.stop();
roryhand 0:004cb0595aa8 253
roryhand 0:004cb0595aa8 254
roryhand 0:004cb0595aa8 255
roryhand 0:004cb0595aa8 256 }
roryhand 0:004cb0595aa8 257
roryhand 0:004cb0595aa8 258 int main() {
roryhand 0:004cb0595aa8 259 FMT_STRUCT wav_format;
roryhand 0:004cb0595aa8 260 char data[2];
roryhand 0:004cb0595aa8 261 pc.printf("Beginning of program\n");
roryhand 0:004cb0595aa8 262 data[0] = 0x0F;
roryhand 0:004cb0595aa8 263 data[1] = 0x00;
roryhand 0:004cb0595aa8 264 FILE *my_wav;
roryhand 0:004cb0595aa8 265 //my_wav = fopen("/sd/mydir/gp40.wav", "rb");//i think that it is "w" for write, "r" for read.
roryhand 5:5b120a2d9249 266 //my_wav = fopen("/sd/mydir/gp40_48K.wav", "rb");//i think that it is "w" for write, "r" for read.
roryhand 5:5b120a2d9249 267 //my_wav = fopen("/sd/mydir/gp40_48K_quieter.wav", "rb");//i think that it is "w" for write, "r" for read.
roryhand 5:5b120a2d9249 268 my_wav = fopen("/sd/mydir/gp40_8K.wav","rb");
roryhand 5:5b120a2d9249 269 //my_wav = fopen("/sd/mydir/emd_645.wav", "rb");
roryhand 0:004cb0595aa8 270 fseek(my_wav, 20, SEEK_SET); // set pointer to byte 20
roryhand 0:004cb0595aa8 271 fread(&AudioFormat, 2, 1, my_wav); // check file is PCM
roryhand 0:004cb0595aa8 272 if (AudioFormat==0x01) {
roryhand 0:004cb0595aa8 273 printf("Wav file is PCM data\n\r");
roryhand 0:004cb0595aa8 274 }
roryhand 0:004cb0595aa8 275 else {
roryhand 0:004cb0595aa8 276 printf("Wav file is not PCM data\n\r");
roryhand 0:004cb0595aa8 277 }
roryhand 0:004cb0595aa8 278
roryhand 0:004cb0595aa8 279 fseek (my_wav,20,SEEK_SET);
roryhand 0:004cb0595aa8 280 fread(&wav_format,sizeof(wav_format),1,my_wav);
roryhand 0:004cb0595aa8 281 printf("%d block align\n",wav_format.block_align);
roryhand 0:004cb0595aa8 282 printf(" %d channels\n",wav_format.num_channels);
roryhand 0:004cb0595aa8 283
roryhand 0:004cb0595aa8 284
roryhand 0:004cb0595aa8 285 fseek(my_wav, 36, SEEK_SET);
roryhand 0:004cb0595aa8 286 fread(&wav_data.subchunk2_ID,4,1,my_wav);
roryhand 0:004cb0595aa8 287 fseek(my_wav, 40, SEEK_SET);
roryhand 0:004cb0595aa8 288 fread(&wav_data.subchunk2_size,4,1,my_wav);
roryhand 0:004cb0595aa8 289 printf("DATA chunck\n");
roryhand 0:004cb0595aa8 290 printf(" %d subchunk 2 ID\n",wav_data.subchunk2_ID);
roryhand 0:004cb0595aa8 291 printf(" %d subchunk 2 size\n",wav_data.subchunk2_size);
roryhand 0:004cb0595aa8 292
roryhand 0:004cb0595aa8 293
roryhand 0:004cb0595aa8 294
roryhand 0:004cb0595aa8 295
roryhand 0:004cb0595aa8 296
roryhand 0:004cb0595aa8 297
roryhand 0:004cb0595aa8 298 i2c.frequency(100000);
roryhand 0:004cb0595aa8 299 long j = 0;
roryhand 0:004cb0595aa8 300
roryhand 0:004cb0595aa8 301 printf("set up the codec\n\r");
roryhand 3:6fba0a044d85 302 while(j <1000){
roryhand 0:004cb0595aa8 303 wm8731_configTEST();
roryhand 3:6fba0a044d85 304 j = j + 1;
roryhand 3:6fba0a044d85 305 }
roryhand 0:004cb0595aa8 306 //i2s audio data transfer code??
roryhand 0:004cb0595aa8 307 i2s.stereomono(I2S_STEREO);
roryhand 0:004cb0595aa8 308 i2s.masterslave(I2S_MASTER);//MASTER definitely works!
roryhand 0:004cb0595aa8 309 i2s.frequency(sample_freq);
roryhand 0:004cb0595aa8 310 int yes = i2s.setup_ok();
roryhand 0:004cb0595aa8 311 pc.printf("Setup went ok?: %d\n", yes);//0 = ack, 1 = Nack*/
roryhand 0:004cb0595aa8 312 printf("can we get to this point? 1\n\r");
roryhand 0:004cb0595aa8 313 led3 = 1;
roryhand 0:004cb0595aa8 314 //myled = 1;
roryhand 0:004cb0595aa8 315 led2 = 1;
roryhand 0:004cb0595aa8 316 printf("can we get to this point? 2\n\r");
roryhand 0:004cb0595aa8 317
roryhand 0:004cb0595aa8 318 myled = 1;
roryhand 0:004cb0595aa8 319 i2s.start();
roryhand 0:004cb0595aa8 320 //while (1) {
roryhand 0:004cb0595aa8 321 fread(&wav_format,sizeof(wav_format),1,my_wav);
roryhand 0:004cb0595aa8 322 printf("wav_format %d\n\r",wav_format);
roryhand 1:ec4e2020522c 323
roryhand 0:004cb0595aa8 324
roryhand 0:004cb0595aa8 325 fseek(my_wav,20,SEEK_SET);
roryhand 0:004cb0595aa8 326 fread(&wav_format,sizeof(wav_format),1,my_wav);
roryhand 0:004cb0595aa8 327 fseek(my_wav,36,SEEK_SET);
roryhand 0:004cb0595aa8 328 fread(&wav_data,sizeof(wav_data),1,my_wav);
roryhand 2:05b426733282 329 int num_slices = wav_data.subchunk2_size/wav_format.block_align;
roryhand 0:004cb0595aa8 330 printf("wav_data.subchunk2_size: %d\n\r",wav_data.subchunk2_size);
roryhand 0:004cb0595aa8 331 printf("wav_format.block_align: %d\n\r",wav_format.block_align);
roryhand 0:004cb0595aa8 332 printf("num_slices: %d\n\r",num_slices);
roryhand 0:004cb0595aa8 333 printf("num_slices*wav_format.block_align %d\n\r",num_slices*wav_format.block_align);
roryhand 0:004cb0595aa8 334 printf("wav_format.num_channels*wav_format.sig_bps/8: %d\n\r",wav_format.num_channels*wav_format.sig_bps/8);
roryhand 3:6fba0a044d85 335 printf("chunk_size - sizeof(wav_format) %d\n\r",wav_data.subchunk2_size-sizeof(wav_format));
roryhand 0:004cb0595aa8 336 printf("sizeof(wav_format): %d\n\r",sizeof(wav_format));
roryhand 3:6fba0a044d85 337 printf("do we egt to this point:\n\r");
roryhand 4:1a9482a07ee2 338 //sampletick.attach(&isr,1/96000);
roryhand 5:5b120a2d9249 339 //sampletick.attach(&isr,1000000/48000);
roryhand 0:004cb0595aa8 340 //while(!feof(my_wav)){
roryhand 0:004cb0595aa8 341 //while(1){
roryhand 0:004cb0595aa8 342 //if (wav_data.subchunk2_size > sizeof(wav_format)){
roryhand 0:004cb0595aa8 343 //fseek(my_wav,wav_data.subchunk2_size-sizeof(wav_format),SEEK_CUR);
roryhand 0:004cb0595aa8 344 /*if(wav_data.subchunk2_size > (num_slices*wav_format.block_align)){
roryhand 0:004cb0595aa8 345 fseek(my_wav,wav_data.subchunk2_size - (num_slices*wav_format.block_align),SEEK_CUR);
roryhand 0:004cb0595aa8 346 printf("chunk_size - sizeof(wav_format) %d\n\r",wav_data.subchunk2_size-sizeof(wav_format));
roryhand 0:004cb0595aa8 347 printf("sizeof(wav_format): %d\n\r",sizeof(wav_format));
roryhand 0:004cb0595aa8 348 }
roryhand 0:004cb0595aa8 349 else {
roryhand 0:004cb0595aa8 350
roryhand 0:004cb0595aa8 351 break;
roryhand 0:004cb0595aa8 352 }*/
roryhand 0:004cb0595aa8 353
roryhand 3:6fba0a044d85 354 slice_buf=(char *)malloc(wav_format.block_align);
roryhand 2:05b426733282 355 for (slice=0;slice<num_slices;slice+=1) {
roryhand 3:6fba0a044d85 356 //t.start();
roryhand 3:6fba0a044d85 357 fread(slice_buf,wav_format.block_align,1,my_wav);//THIS IS WHERE HE READS IN THE DATA, TO SLICE_BUF. BUT USES WAV_FORMAT.BLOCKALIGN AS HIS SIZE GUIDE
roryhand 2:05b426733282 358 //I do not understand why he is not "seeking" through the file first though...
roryhand 3:6fba0a044d85 359 if (feof(my_wav)){
roryhand 2:05b426733282 360 printf("Oops -- not enough slices in the wave file\n");
roryhand 2:05b426733282 361 exit(1);
roryhand 2:05b426733282 362 }
roryhand 5:5b120a2d9249 363 data_sptr=(short *)slice_buf; // 16 bit samples
roryhand 2:05b426733282 364 data_bptr=(unsigned char *)slice_buf; // 8 bit samples
roryhand 2:05b426733282 365 data_wptr=(int *)slice_buf; // 32 bit samples
roryhand 5:5b120a2d9249 366 slice_value[1]=0;
roryhand 2:05b426733282 367 for (channel=0;channel<wav_format.num_channels;channel++) {
roryhand 2:05b426733282 368 switch (wav_format.sig_bps) {
roryhand 2:05b426733282 369 case 16:
roryhand 5:5b120a2d9249 370 int mybuffer[1];
roryhand 5:5b120a2d9249 371 mybuffer[0] = data_sptr[channel];// - 32768;
roryhand 5:5b120a2d9249 372 i2s.write(data_sptr,2);
roryhand 5:5b120a2d9249 373 wait_us(0.1);
roryhand 2:05b426733282 374 if (verbosity)
roryhand 5:5b120a2d9249 375 printf("16 bit channel %d data=%d\n\r ",channel,data_sptr[channel]);
roryhand 5:5b120a2d9249 376 slice_value[1]+=data_sptr[channel];
roryhand 2:05b426733282 377 break;
roryhand 2:05b426733282 378 case 32:
roryhand 2:05b426733282 379 if (verbosity)
roryhand 2:05b426733282 380 printf("32 bit channel %d data=%d ",channel,data_wptr[channel]);
roryhand 5:5b120a2d9249 381 slice_value[1]+=data_wptr[channel];
roryhand 2:05b426733282 382 break;
roryhand 2:05b426733282 383 case 8:
roryhand 2:05b426733282 384 if (verbosity)
roryhand 2:05b426733282 385 printf("8 bit channel %d data=%d ",channel,(int)data_bptr[channel]);
roryhand 5:5b120a2d9249 386 slice_value[1]+=data_bptr[channel];
roryhand 2:05b426733282 387 break;
roryhand 2:05b426733282 388 }
roryhand 2:05b426733282 389 }
roryhand 5:5b120a2d9249 390 slice_value[1]/=wav_format.num_channels;
roryhand 2:05b426733282 391
roryhand 2:05b426733282 392 // slice_value is now averaged. Next it needs to be scaled to an unsigned 16 bit value
roryhand 2:05b426733282 393 // with DC offset so it can be written to the DAC.
roryhand 2:05b426733282 394 switch (wav_format.sig_bps) {
roryhand 5:5b120a2d9249 395 case 8: slice_value[1]<<=8;
roryhand 2:05b426733282 396 break;
roryhand 5:5b120a2d9249 397 case 16: slice_value[1]+=32768;
roryhand 2:05b426733282 398 break;
roryhand 5:5b120a2d9249 399 case 32: slice_value[1]>>=16;
roryhand 5:5b120a2d9249 400 slice_value[1]+=32768;
roryhand 2:05b426733282 401 break;
roryhand 2:05b426733282 402 }
roryhand 5:5b120a2d9249 403 if (verbosity)
roryhand 5:5b120a2d9249 404 {
roryhand 5:5b120a2d9249 405 printf("data_sptr data: %d \n\r",data_sptr);
roryhand 5:5b120a2d9249 406 printf("slice_value data: %d \n\r",slice_value);
roryhand 5:5b120a2d9249 407 }
roryhand 5:5b120a2d9249 408 int mynewvar[1];
roryhand 5:5b120a2d9249 409 //i2s.write(data_sptr,2);
roryhand 3:6fba0a044d85 410 //t.stop();
roryhand 3:6fba0a044d85 411 //printf("The time taken was %f seconds\n", t.read());
roryhand 3:6fba0a044d85 412 }
roryhand 3:6fba0a044d85 413 /* dac_data=(short unsigned)slice_value;
roryhand 2:05b426733282 414 if (verbosity)
roryhand 2:05b426733282 415 printf("sample %d wptr %d slice_value %d dac_data %u\n",slice,DAC_wptr,(int)slice_value,dac_data);
roryhand 2:05b426733282 416 DAC_fifo[DAC_wptr]=dac_data;
roryhand 2:05b426733282 417 DAC_wptr=(DAC_wptr+1) & 0xff;
roryhand 2:05b426733282 418 while (DAC_wptr==DAC_rptr) {
roryhand 2:05b426733282 419 }
roryhand 3:6fba0a044d85 420 }*/
roryhand 3:6fba0a044d85 421
roryhand 2:05b426733282 422
roryhand 1:ec4e2020522c 423
roryhand 5:5b120a2d9249 424 //sampletick.detach();
roryhand 0:004cb0595aa8 425 i2s.stop();
roryhand 0:004cb0595aa8 426
roryhand 0:004cb0595aa8 427 fclose(my_wav);
roryhand 0:004cb0595aa8 428 printf("File is now closed.");
roryhand 0:004cb0595aa8 429 return 0;
roryhand 0:004cb0595aa8 430 }
roryhand 0:004cb0595aa8 431