changeset 53:2991344775f8 pygar svn.54

[svn r54] mixer integrated
author punk
date Sun, 09 May 2010 10:58:40 -0400 (2010-05-09)
parents 49049f97312c
children 9b4f237e77e1
files modules/bluespec/Pygar/core/AudioCoreRRR.cpp modules/bluespec/Pygar/core/AudioCoreSystem.cpp modules/bluespec/Pygar/core/Mixer.bsv modules/bluespec/Pygar/core/Processor.bsv modules/bluespec/Pygar/core/audioCorePipeline.bsv
diffstat 5 files changed, 59 insertions(+), 44 deletions(-) [+]
line wrap: on
line diff
     1.1 --- a/modules/bluespec/Pygar/core/AudioCoreRRR.cpp	Thu May 06 08:57:53 2010 -0400
     1.2 +++ b/modules/bluespec/Pygar/core/AudioCoreRRR.cpp	Sun May 09 10:58:40 2010 -0400
     1.3 @@ -120,8 +120,8 @@
     1.4        }
     1.5  
     1.6        // Long term this should be in the data portion.  But until I have code running, keep it here.
     1.7 -      count++;
     1.8 -      if (count == 2)
     1.9 +      //      count++;
    1.10 +      //if (count == 2)
    1.11          CONNECTED_APPLICATION_CLASS::EndSimulation(); 
    1.12      break;
    1.13  
     2.1 --- a/modules/bluespec/Pygar/core/AudioCoreSystem.cpp	Thu May 06 08:57:53 2010 -0400
     2.2 +++ b/modules/bluespec/Pygar/core/AudioCoreSystem.cpp	Sun May 09 10:58:40 2010 -0400
     2.3 @@ -92,7 +92,7 @@
     2.4    //Send data to the machine here.
     2.5    //rlm: two files
     2.6    inputFile = fopen("input.pcm","r");
     2.7 -  inputFile = fopen("input1.pcm", "r");
     2.8 +  inputFile1 = fopen("input1.pcm", "r");
     2.9    
    2.10    assert(inputFile1);
    2.11    assert(inputFile);
    2.12 @@ -159,5 +159,5 @@
    2.13    STATS_DEVICE_SERVER_CLASS::GetInstance()->EmitFile();
    2.14  
    2.15    fflush(stdout);
    2.16 -  exit(0);
    2.17 +  //  exit(0);
    2.18  }
     3.1 --- a/modules/bluespec/Pygar/core/Mixer.bsv	Thu May 06 08:57:53 2010 -0400
     3.2 +++ b/modules/bluespec/Pygar/core/Mixer.bsv	Sun May 09 10:58:40 2010 -0400
     3.3 @@ -27,8 +27,6 @@
     3.4  import FIFO::*;
     3.5  import FixedPoint::*;
     3.6  
     3.7 -`define MAX_VOICES 2
     3.8 -
     3.9  //AWB includes
    3.10  `include "asim/provides/low_level_platform_interface.bsh"
    3.11  `include "asim/provides/soft_connections.bsh"
    3.12 @@ -38,44 +36,40 @@
    3.13  `include "asim/provides/audio_pipe_types.bsh"
    3.14  `include "asim/provides/path_types.bsh"
    3.15  
    3.16 -interface PutMixerIn;
    3.17 -   method Action sendVoiceIn(AudioStream voiceInput);
    3.18 -endinterface 
    3.19 -
    3.20  interface Mixer;
    3.21 -   interface PutMixerIn toMixer;
    3.22 -   interface Get#(AudioProcessorUnit) mixerOut;
    3.23 +   method Action toMixer(AudioStream streamIn);
    3.24 +   interface Get#(AudioProcessorUnit) mainOut;
    3.25  endinterface
    3.26  
    3.27 -function Bool isAudioFini(Vector#(`MAX_VOICES, Reg#(Bool)) voiceStat);
    3.28 -   Bool result = True;
    3.29 -   for (Integer i = 0; i < `MAX_VOICES; i = i+1)
    3.30 -      begin
    3.31 -         result = voiceStat[i] && result;
    3.32 -      end
    3.33 -   return result; 
    3.34 -endfunction
    3.35 +module [CONNECTED_MODULE]  mkMixer#(Integer numVoices, Vector#(numVoices, Volume) scalars) (Mixer);
    3.36  
    3.37 -module [CONNECTED_MODULE]  mkMixer#(Vector#(`MAX_VOICES, Volume) scalars) (Mixer);
    3.38 +   function Bool isAudioFini(Vector#(numVoices, Reg#(Bool)) voiceStat);
    3.39 +     Bool result = True;
    3.40 +      for (Integer i = 0; i < numVoices; i = i+1)
    3.41 +        begin
    3.42 +          result = voiceStat[i] && result;
    3.43 +        end
    3.44 +     return result; 
    3.45 +   endfunction
    3.46  
    3.47  	 
    3.48    // Instantiate the modules
    3.49 -   Vector#(`MAX_VOICES, FIFO#(AudioPipeUnit)) voicesIn <- replicateM(mkFIFO());
    3.50 +   Vector#(numVoices, FIFO#(AudioPipeUnit)) voicesIn <- replicateM(mkFIFO());
    3.51  // <- newVector();
    3.52 -   Vector#(`MAX_VOICES, Reg#(Bool)) voiceFini <- replicateM(mkReg(False));
    3.53 +   Vector#(numVoices, Reg#(Bool)) voiceFini <- replicateM(mkReg(False));
    3.54  
    3.55     FIFO#(AudioProcessorUnit) masterFifo <- mkFIFO();
    3.56  
    3.57     rule sendEnd(isAudioFini(voiceFini));
    3.58        masterFifo.enq(tagged EndOfFile);
    3.59        //prep for reset
    3.60 -      for (Integer i = 0; i < `MAX_VOICES; i = i+1)
    3.61 +      for (Integer i = 0; i < numVoices; i = i+1)
    3.62  	 voiceFini[i] <= False;
    3.63     endrule
    3.64     
    3.65     rule processSample(!isAudioFini(voiceFini));  //implicit on all voiceFifos having data
    3.66        FixedPoint#(32,32) sum = 0;  //this should allow 16 voices at 16 bits without messing up
    3.67 -      for (Integer i = 0; i < `MAX_VOICES; i = i+1)
    3.68 +      for (Integer i = 0; i < numVoices; i = i+1)
    3.69  	 begin
    3.70  	    if (voicesIn[i].first() matches tagged Valid .data)
    3.71  	      begin
    3.72 @@ -91,17 +85,19 @@
    3.73  	    voicesIn[i].deq();
    3.74  	 end
    3.75        
    3.76 -       masterFifo.enq(tagged Sample truncate(fxptGetInt(sum >> `MAX_VOICES)));
    3.77 +       masterFifo.enq(tagged Sample truncate(fxptGetInt(sum >> numVoices)));
    3.78     endrule
    3.79   
    3.80    // Internal connections
    3.81  
    3.82 -   interface PutMixerIn toMixer;
    3.83 -      method Action sendVoiceIn(AudioStream voiceInput);
    3.84 -	 voicesIn[voiceInput.voice].enq(voiceInput.data);
    3.85 -      endmethod
    3.86 -   endinterface
    3.87 -      
    3.88 -   interface Get mixerOut = fifoToGet(masterFifo);
    3.89 +//   method Action loadMixerFifos(AudioStream voiceInput);
    3.90 +//      voicesIn[voiceInput.voice].enq(voiceInput.data);
    3.91 +//   endmethod
    3.92 + 
    3.93 +   method Action toMixer(AudioStream streamIn);
    3.94 +	 voicesIn[streamIn.voice].enq(streamIn.data);
    3.95 +   endmethod
    3.96 +   
    3.97 +   interface Get mainOut = fifoToGet(masterFifo);
    3.98  
    3.99  endmodule
     4.1 --- a/modules/bluespec/Pygar/core/Processor.bsv	Thu May 06 08:57:53 2010 -0400
     4.2 +++ b/modules/bluespec/Pygar/core/Processor.bsv	Sun May 09 10:58:40 2010 -0400
     4.3 @@ -501,7 +501,7 @@
     4.4                 5'd20 : wbQ.enq(tagged WB_ALU {dest:it.rdst, data:cp0_fromhost });
     4.5                 5'd21 : wbQ.enq(tagged WB_ALU {dest:it.rdst, data:cp0_tohost   });
     4.6  	       5'd25 : begin
     4.7 -			  $display( "**** EOF Requested\n ");
     4.8 +//			  $display( "**** EOF Requested\n ");
     4.9  			  let sample = inAudioFifo.first();
    4.10  			  case (sample) matches
    4.11  			     tagged EndOfFile :
    4.12 @@ -515,7 +515,7 @@
    4.13  			  endcase
    4.14  		       end
    4.15  	       5'd28 : begin
    4.16 -			  $display( "***** Reqesting Sample \n");
    4.17 +//			  $display( "***** Reqesting Sample \n");
    4.18  			  let sample = inAudioFifo.first();        // is this going to cause perf. delay?
    4.19  			  if (sample matches tagged Sample .audio) // if it is EOF another rule sets the cp0_audioEOF  
    4.20  	     		     wbQ.enq(tagged WB_ALU {dest:it.rdst, data:zext(pack(audio)) });  // do I need pack?
     5.1 --- a/modules/bluespec/Pygar/core/audioCorePipeline.bsv	Thu May 06 08:57:53 2010 -0400
     5.2 +++ b/modules/bluespec/Pygar/core/audioCorePipeline.bsv	Sun May 09 10:58:40 2010 -0400
     5.3 @@ -49,12 +49,16 @@
     5.4  module [CONNECTED_MODULE] mkConnectedApplication ();
     5.5     Core core <- mkCore(`VDEV_SCRATCH_MEMORYA);
     5.6     Core anotherCore <- mkCore(`VDEV_SCRATCH_MEMORYB);
     5.7 -
     5.8 +   Vector#(2, Volume) channelVols = replicate(127);
     5.9 +   Mixer mixer <- mkMixer(2, channelVols); //should be max voices but 2 for now
    5.10 +   
    5.11     Reg#(int) cycle <- mkReg(0);
    5.12 +   Reg#(int) sampleCount <-mkReg(0);
    5.13     Vector#(2, Reg#(Bool)) ac_fini <- replicateM(mkReg(False));
    5.14  
    5.15 -  // Services Samples 
    5.16 -  ClientStub_AUDIOCORERRR client_stub <- mkClientStub_AUDIOCORERRR();   
    5.17 +//   FIFO#(AudioProcessorUnit) coreOut <- mkFIFO();
    5.18 +   // Services Samples 
    5.19 +   ClientStub_AUDIOCORERRR client_stub <- mkClientStub_AUDIOCORERRR();   
    5.20    
    5.21  
    5.22     //-----------------------------------------------------------
    5.23 @@ -69,13 +73,28 @@
    5.24      $fdisplay(stderr, " => Cycle = %d", cycle);
    5.25    endrule
    5.26  
    5.27 +  // Send to Mixer
    5.28 +  // Right now this is sorta retarded in that I pass from the output fifo into a new fifo
    5.29 +  // But I have to mod a bunch of things to fix this and I am not sure I understand
    5.30 +  // things well enough to do this quickly.  So here it is as it is for now.
    5.31 +  rule mix;
    5.32 +    let coreOut <- core.sampleOutput.get();
    5.33 +    let anotherOut <- anotherCore.sampleOutput.get();
    5.34 +    mixer.toMixer(AudioStream {voice : 0, data : tagged Valid coreOut});
    5.35 +    mixer.toMixer(AudioStream {voice : 1, data : tagged Valid anotherOut});
    5.36 +  endrule
    5.37 +
    5.38    rule feedOutput;
    5.39 -     let pipelineData <- core.sampleOutput.get();
    5.40 +  //     let pipelineData <- core.sampleOutput.get();
    5.41 +     let pipeOut <- mixer.mainOut.get();
    5.42 +     
    5.43       AudioProcessorControl endOfFileTag = EndOfFile;
    5.44       AudioProcessorControl sampleTag = Data;
    5.45  
    5.46 -     $display("PIPE writes sample\n");
    5.47 -     case (pipelineData) matches
    5.48 +     sampleCount <= sampleCount+1;
    5.49 +     
    5.50 +     $display("PIPE writes sample %x\n", sampleCount);
    5.51 +     case (pipeOut) matches
    5.52  	tagged EndOfFile:
    5.53  	   begin
    5.54  	      client_stub.makeRequest_SendProcessedStream(zeroExtend(pack(endOfFileTag)),?);
    5.55 @@ -84,11 +103,11 @@
    5.56         tagged Sample .sample:
    5.57  	  client_stub.makeRequest_SendProcessedStream(zeroExtend(pack(sampleTag)), zeroExtend(pack(sample)));
    5.58       endcase
    5.59 -   endrule
    5.60 +  endrule
    5.61  
    5.62     // Programming ghetto style!
    5.63     // right now I am repeating this rule for my second core.
    5.64 -    (* conservative_implicit_conditions *)
    5.65 +/*    (* conservative_implicit_conditions *)
    5.66      rule feedAnotherOutput;
    5.67       let pipelineData <- anotherCore.sampleOutput.get();
    5.68       AudioProcessorControl endOfFileTag = EndOfFile;
    5.69 @@ -105,7 +124,7 @@
    5.70  	   client_stub.makeRequest_SendProcessedStream(zeroExtend(pack(sampleTag)), zeroExtend(pack(sample)));
    5.71       endcase
    5.72     endrule
    5.73 -
    5.74 +*/
    5.75  
    5.76     // Can generally just stick with the EOF but since I have two Cores no mixer...
    5.77    /*(* conservative_implicit_conditions *)