punk@13
|
1 #include <stdio.h>
|
punk@13
|
2 #include <pthread.h>
|
punk@13
|
3 #include <semaphore.h>
|
punk@13
|
4
|
punk@13
|
5 #include "asim/provides/connected_application.h"
|
punk@13
|
6 #include "asim/provides/stats_device.h"
|
punk@13
|
7 //#include "asim/provides/SndfileWavUtil.h"
|
punk@13
|
8
|
punk@13
|
9 #include "asim/rrr/client_stub_AUDIOCORERRR.h"
|
punk@13
|
10
|
punk@13
|
11 using namespace std;
|
punk@13
|
12
|
punk@68
|
13 #define NUM_VOICES 2
|
punk@68
|
14
|
punk@13
|
15 pthread_mutex_t CONNECTED_APPLICATION_CLASS::lock;
|
punk@13
|
16 pthread_cond_t CONNECTED_APPLICATION_CLASS::cond;
|
punk@13
|
17 sem_t CONNECTED_APPLICATION_CLASS::throttle;
|
punk@13
|
18
|
punk@68
|
19
|
punk@13
|
20 // constructor
|
punk@13
|
21 CONNECTED_APPLICATION_CLASS::CONNECTED_APPLICATION_CLASS(VIRTUAL_PLATFORM vp) :
|
rlm@23
|
22
|
rlm@23
|
23 clientStub(new AUDIOCORERRR_CLIENT_STUB_CLASS(this))
|
punk@13
|
24 {
|
punk@64
|
25 printf("SendSide Created\n");
|
punk@13
|
26 }
|
punk@13
|
27
|
punk@13
|
28 // destructor
|
punk@13
|
29 CONNECTED_APPLICATION_CLASS::~CONNECTED_APPLICATION_CLASS()
|
punk@13
|
30 {
|
punk@13
|
31 }
|
punk@13
|
32
|
punk@13
|
33 // init
|
punk@13
|
34 void
|
punk@13
|
35 CONNECTED_APPLICATION_CLASS::Init()
|
punk@13
|
36 {
|
punk@13
|
37
|
punk@64
|
38 printf("InitSend Side\n");
|
punk@13
|
39 pthread_mutex_init(&lock, NULL);
|
punk@13
|
40 pthread_cond_init(&cond, NULL);
|
punk@65
|
41 sem_init(&throttle, 0, 256);
|
punk@13
|
42
|
punk@13
|
43 // enable stats
|
punk@64
|
44 //STATS_DEVICE_SERVER_CLASS::GetInstance()->SetupStats();
|
punk@13
|
45 }
|
punk@13
|
46
|
punk@57
|
47 //This isn't called.
|
punk@13
|
48 void
|
punk@13
|
49 CONNECTED_APPLICATION_CLASS::UpdateSemaphore()
|
punk@13
|
50 {
|
punk@64
|
51 printf("UpdateSemaphore\n");
|
punk@13
|
52 sem_post(&throttle);
|
punk@13
|
53 }
|
punk@13
|
54
|
punk@13
|
55 void
|
punk@13
|
56 CONNECTED_APPLICATION_CLASS::EndSimulation()
|
punk@13
|
57 {
|
punk@13
|
58 printf("EndSimulation Called\n");
|
punk@13
|
59 fflush(stdout);
|
punk@13
|
60 pthread_mutex_lock(&lock);
|
punk@13
|
61 // Do something about the race occuring here
|
punk@13
|
62 pthread_cond_signal(&cond);
|
punk@13
|
63 pthread_mutex_unlock(&lock);
|
punk@13
|
64 printf("EndSimulation done\n");
|
punk@13
|
65 fflush(stdout);
|
punk@13
|
66 }
|
punk@13
|
67
|
punk@13
|
68 // main
|
punk@13
|
69 void
|
punk@13
|
70 CONNECTED_APPLICATION_CLASS::Main()
|
punk@13
|
71 {
|
rlm@34
|
72 //rlm: two files
|
punk@13
|
73 FILE *inputFile;
|
punk@52
|
74 FILE *inputFile1;
|
punk@13
|
75 UINT16 sample;
|
punk@52
|
76 UINT16 sample1;
|
rlm@34
|
77
|
punk@68
|
78 Bool fileFini[NUM_VOICES] = {false, false};
|
rlm@34
|
79 //rlm: not sure if normal ints are ok here; using UINT16 because I know it works
|
punk@52
|
80 UINT16 channel0 = 0;
|
punk@52
|
81 UINT16 channel1 = 1;
|
punk@31
|
82
|
punk@31
|
83 //init processor
|
punk@31
|
84 int sleepCount = 0;
|
punk@31
|
85 int result = 0;
|
punk@31
|
86
|
punk@68
|
87 int numcCoreFin = 0;
|
punk@31
|
88
|
punk@64
|
89 printf("SendSide Main\n");
|
punk@31
|
90 fflush(stdout);
|
punk@31
|
91
|
punk@13
|
92 // Convert input wav to pcm
|
rlm@34
|
93
|
rlm@34
|
94 //rlm: for now we are going to going to just have 2 files with "common names"
|
rlm@34
|
95
|
punk@13
|
96 generate_pcm("input.wav","input.pcm");
|
punk@52
|
97 generate_pcm("input1.wav", "input1.pcm");
|
rlm@34
|
98
|
punk@13
|
99
|
punk@13
|
100 //Send data to the machine here.
|
rlm@34
|
101 //rlm: two files
|
punk@13
|
102 inputFile = fopen("input.pcm","r");
|
punk@53
|
103 inputFile1 = fopen("input1.pcm", "r");
|
rlm@34
|
104
|
punk@52
|
105 assert(inputFile1);
|
punk@13
|
106 assert(inputFile);
|
punk@13
|
107
|
punk@13
|
108 int count = 0;
|
punk@13
|
109
|
punk@65
|
110 sleep(1);
|
punk@57
|
111 printf("main:samples about to start sending %d\n", count);
|
punk@13
|
112
|
rlm@34
|
113 //rlm: here we read both files. later refactor into a function.
|
rlm@34
|
114 // also, this will terminate when the FIRST file reaches its end.
|
punk@68
|
115 while( !feof(inputFile) || !feof(inputFile1))
|
punk@68
|
116 {
|
punk@68
|
117
|
punk@65
|
118 sem_wait(&throttle);
|
punk@65
|
119
|
punk@37
|
120 if(count%1000 == 0)
|
punk@37
|
121 printf("main: %d\n", count);
|
punk@37
|
122 count++;
|
punk@37
|
123
|
rlm@34
|
124 //rlm: two files.
|
punk@68
|
125
|
punk@68
|
126 if (!fileFini[0])
|
punk@68
|
127 {
|
punk@68
|
128 if (fread(&sample, 2, 1, inputFile))
|
punk@68
|
129 clientStub->SendUnprocessedStream((UINT32)channel0 , Data,(UINT32)sample);
|
punk@68
|
130 else{
|
punk@68
|
131 fileFini[0] = true;
|
punk@68
|
132 numCoreFini++;
|
punk@68
|
133 if (numCoreFini >= NUM_VOICES) // Need lock on last eof
|
punk@68
|
134 // Need to put lock here to prevent potential race condition
|
punk@68
|
135 pthread_mutex_lock(&lock);
|
punk@68
|
136 clientStub->SendUnprocessedStream((UINT32)channel0, EndOfFile,0);
|
punk@68
|
137 }
|
punk@68
|
138 }
|
punk@68
|
139 if !fileFini[1])
|
punk@68
|
140 {
|
punk@68
|
141 if (fread(&sample1, 2 , 1, inputFile1))
|
punk@68
|
142 clientStub->SendUnprocessedStream((UINT32)channel1 , Data,(UINT32)sample1);
|
punk@68
|
143 else{
|
punk@68
|
144 fileFini[1] = true;
|
punk@68
|
145 numCoreFini++;
|
punk@68
|
146 if (numCoreFini >= NUM_VOICES) // Need lock on last eof
|
punk@68
|
147 // Need to put lock here to prevent potential race condition
|
punk@68
|
148 pthread_mutex_lock(&lock);
|
punk@68
|
149 clientStub->SendUnprocessedStream((UINT32)channel1, EndOfFile,0);
|
punk@68
|
150 }
|
punk@68
|
151 }
|
punk@68
|
152 }
|
punk@13
|
153
|
punk@13
|
154 printf("main: out of loop\n");
|
punk@13
|
155 printf("main: wait for end of file\n");
|
punk@13
|
156
|
punk@13
|
157 pthread_cond_wait(&cond, &lock);
|
punk@13
|
158 pthread_mutex_unlock(&lock);
|
punk@13
|
159
|
rlm@23
|
160 printf("main: last data out\n");
|
punk@13
|
161
|
punk@13
|
162 // Convert input wav to pcm
|
rlm@34
|
163 // this part is ok because there is always only one input file.
|
punk@13
|
164 generate_wav("out_hw.pcm","input.wav","out_hw.wav");
|
punk@13
|
165
|
punk@13
|
166 printf("generate wav done\n");
|
punk@13
|
167
|
punk@50
|
168 // printf("If you missed it, core %s", coreFin ? "PASSED\n" : "FAILED\n");
|
punk@13
|
169 // Dump the stats file
|
punk@13
|
170
|
punk@13
|
171 STATS_DEVICE_SERVER_CLASS::GetInstance()->DumpStats();
|
punk@13
|
172 STATS_DEVICE_SERVER_CLASS::GetInstance()->EmitFile();
|
punk@13
|
173
|
punk@31
|
174 fflush(stdout);
|
punk@53
|
175 // exit(0);
|
punk@31
|
176 }
|