giuliomoro@19
|
1 /*
|
giuliomoro@19
|
2 *
|
giuliomoro@19
|
3 * First assignment for ECS732 RTDSP, to implement a 2-way audio crossover
|
giuliomoro@19
|
4 * using the BeagleBone Black.
|
giuliomoro@19
|
5 *
|
giuliomoro@19
|
6 * Andrew McPherson and Victor Zappi
|
giuliomoro@19
|
7 * Queen Mary, University of London
|
giuliomoro@19
|
8 */
|
giuliomoro@19
|
9
|
giuliomoro@19
|
10 #include "../include/render.h"
|
giuliomoro@19
|
11 #include <cmath>
|
giuliomoro@19
|
12 #include <rtdk.h>
|
giuliomoro@19
|
13
|
giuliomoro@19
|
14 /* TASK: declare any global variables you need here */
|
giuliomoro@19
|
15
|
giuliomoro@19
|
16 // initialise_render() is called once before the audio rendering starts.
|
giuliomoro@19
|
17 // Use it to perform any initialisation and allocation which is dependent
|
giuliomoro@19
|
18 // on the period size or sample rate.
|
giuliomoro@19
|
19 //
|
giuliomoro@19
|
20 // userData holds an opaque pointer to a data structure that was passed
|
giuliomoro@19
|
21 // in from the call to initAudio().
|
giuliomoro@19
|
22 //
|
giuliomoro@19
|
23 // Return true on success; returning false halts the program.
|
giuliomoro@19
|
24 int gNumMatrixGpioFrames=0;
|
giuliomoro@19
|
25 bool initialise_render(int numMatrixChannels, int numMatrixGpioChannels, int numAudioChannels,
|
giuliomoro@19
|
26 int numMatrixFramesPerPeriod,
|
giuliomoro@19
|
27 int numAudioFramesPerPeriod,
|
giuliomoro@19
|
28 float matrixSampleRate, float audioSampleRate,
|
giuliomoro@19
|
29 void *userData)
|
giuliomoro@19
|
30 {
|
giuliomoro@19
|
31 gNumMatrixChannels=numMatrixChannels;
|
giuliomoro@19
|
32 return true;
|
giuliomoro@19
|
33 }
|
giuliomoro@19
|
34
|
giuliomoro@19
|
35 // render() is called regularly at the highest priority by the audio engine.
|
giuliomoro@19
|
36 // Input and output are given from the audio hardware and the other
|
giuliomoro@19
|
37 // ADCs and DACs (if available). If only audio is available, numMatrixFrames
|
giuliomoro@19
|
38 // will be 0.
|
giuliomoro@19
|
39
|
giuliomoro@19
|
40 long int gCountFrames=0;
|
giuliomoro@19
|
41 void render(int numMatrixFrames, int numMatrixGpioFrames, int numAudioFrames, float *audioIn, float *audioOut,
|
giuliomoro@19
|
42 float *matrixIn, float *matrixOut, uint32_t *matrixGpio)
|
giuliomoro@19
|
43 /*
|
giuliomoro@19
|
44 * Hey, expect buffer underruns to happen here, as we are doing lots of printfs
|
giuliomoro@19
|
45 * */
|
giuliomoro@19
|
46 {
|
giuliomoro@19
|
47 gNumMatrixGpioFrames=numMatrixGpioFrames;
|
giuliomoro@19
|
48 if(gCountFrames==0){ //this will be executed only on the first call to render(), but the bits will go through this cycle for every subsequent buffer
|
giuliomoro@19
|
49 // that is, P8_29 will pulse at the beginning of each buffer
|
giuliomoro@19
|
50 }
|
giuliomoro@19
|
51 for(int i=1; i<gNumMatrixGpioFrames; i++)
|
giuliomoro@19
|
52 digitalWriteAll(i, GPIO_LOW); //write all channels on the given frame. Initialize them to zero
|
giuliomoro@19
|
53 digitalWrite(0, 4, GPIO_HIGH); // set pin 0 HIGH from the current frame to the end of the buffer
|
giuliomoro@19
|
54 for(int n=0; n<numMatrixFrames; n++) {
|
giuliomoro@19
|
55 for(int c=0; c<gNumMatrixChannels; c++)
|
giuliomoro@19
|
56 analogWriteFrame(c,n,0); //set channel c on frame n to 0, equivalent to matrixOut[n*numMatrixChannels+c]=0;
|
giuliomoro@19
|
57 }
|
giuliomoro@19
|
58 analogWrite(0,3,0.2); //set channel 0 to 0.2 from frame 3 onwards ...
|
giuliomoro@19
|
59 analogWrite(1,3,0.7); //set channel 1 to 0.7 from frame 3 onwards ...
|
giuliomoro@19
|
60 analogWrite(2,6,0.5); //set channel 2 to 0.5 from frame 6 onwards ...
|
giuliomoro@19
|
61 for(int n=0; n<numAudioFrames; n++){
|
giuliomoro@19
|
62 printf("Digital frame %d: 0x%08x;\n",n,matrixGpio[n]);
|
giuliomoro@19
|
63 }
|
giuliomoro@19
|
64 for(int n=0; n<numMatrixFrames; n++){
|
giuliomoro@19
|
65 printf("Analog out frame %d :",n);
|
giuliomoro@19
|
66 for(int c=0; c<gNumMatrixChannels; c++)
|
giuliomoro@19
|
67 printf("%.1f ",matrixOut[n*gNumMatrixChannels + c]);
|
giuliomoro@19
|
68 printf("\n");
|
giuliomoro@19
|
69 }
|
giuliomoro@19
|
70 }
|
giuliomoro@19
|
71 // cleanup_render() is called once at the end, after the audio has stopped.
|
giuliomoro@19
|
72 // Release any resources that were allocated in initialise_render().
|
giuliomoro@19
|
73
|
giuliomoro@19
|
74 void cleanup_render()
|
giuliomoro@19
|
75 {
|
giuliomoro@19
|
76 /* TASK:
|
giuliomoro@19
|
77 * If you allocate any memory, be sure to release it here.
|
giuliomoro@19
|
78 * You may or may not need anything in this function, depending
|
giuliomoro@19
|
79 * on your implementation.
|
giuliomoro@19
|
80 */
|
giuliomoro@19
|
81 }
|