changeset 41:16ba43f0a7c3 pygar svn.42

[svn r42] got channels working
author rlm
date Tue, 04 May 2010 22:32:52 -0400 (2010-05-05)
parents 7ac38b0f93fa
children ced2ebd41347
files modules/bluespec/Pygar/common/AudioProcessor.bsv modules/bluespec/Pygar/common/AudioProcessorRRR.cpp modules/bluespec/Pygar/common/AudioProcessorRRR.h modules/bluespec/Pygar/common/AudioProcessorRRR.rrr modules/bluespec/Pygar/core/AudioCoreRRR.rrr modules/bluespec/Pygar/core/AudioCoreSystem.cpp modules/bluespec/Pygar/core/audioCorePipeline.bsv
diffstat 7 files changed, 14 insertions(+), 247 deletions(-) [+]
line wrap: on
line diff
     1.1 --- a/modules/bluespec/Pygar/common/AudioProcessor.bsv	Tue May 04 19:53:09 2010 -0400
     1.2 +++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.3 @@ -1,77 +0,0 @@
     1.4 -// The MIT License
     1.5 -
     1.6 -// Copyright (c) 2009 Massachusetts Institute of Technology
     1.7 -
     1.8 -// Permission is hereby granted, free of charge, to any person obtaining a copy
     1.9 -// of this software and associated documentation files (the "Software"), to deal
    1.10 -// in the Software without restriction, including without limitation the rights
    1.11 -// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
    1.12 -// copies of the Software, and to permit persons to whom the Software is
    1.13 -// furnished to do so, subject to the following conditions:
    1.14 -
    1.15 -// The above copyright notice and this permission notice shall be included in
    1.16 -// all copies or substantial portions of the Software.
    1.17 -
    1.18 -// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
    1.19 -// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
    1.20 -// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
    1.21 -// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
    1.22 -// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
    1.23 -// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
    1.24 -// THE SOFTWARE.
    1.25 -
    1.26 -import Connectable::*;
    1.27 -import GetPut::*;
    1.28 -import ClientServer::*;
    1.29 -
    1.30 -//AWB includes
    1.31 -`include "asim/provides/low_level_platform_interface.bsh"
    1.32 -`include "asim/provides/soft_connections.bsh"
    1.33 -`include "asim/provides/common_services.bsh"
    1.34 -
    1.35 -// Local includes
    1.36 -`include "asim/provides/audio_processor_types.bsh"
    1.37 -`include "asim/provides/audio_pipeline.bsh"
    1.38 -
    1.39 -`include "asim/rrr/remote_client_stub_AUDIOPROCESSORRRR.bsh"
    1.40 -`include "asim/rrr/remote_server_stub_AUDIOPROCESSORRRR.bsh"
    1.41 -
    1.42 -
    1.43 -module [CONNECTED_MODULE] mkConnectedApplication ();
    1.44 -
    1.45 -   // Instantiate the rrr stubs
    1.46 -   ClientStub_AUDIOPROCESSORRRR client_stub <- mkClientStub_AUDIOPROCESSORRRR();
    1.47 -   ServerStub_AUDIOPROCESSORRRR server_stub <- mkServerStub_AUDIOPROCESSORRRR();
    1.48 -
    1.49 -   // Instantiate the audio pipeline
    1.50 -   AudioPipeline pipeline <- mkAudioPipeline();
    1.51 -
    1.52 -   rule feedInput;
    1.53 -     let command <- server_stub.acceptRequest_SendUnprocessedStream();
    1.54 -     AudioProcessorControl ctrl = unpack(truncate(command.ctrl));
    1.55 -
    1.56 -     if(ctrl == EndOfFile)
    1.57 -       begin
    1.58 -         pipeline.sampleInput.put(tagged EndOfFile);
    1.59 -       end
    1.60 -     else 
    1.61 -       begin
    1.62 -         pipeline.sampleInput.put(tagged Sample unpack(truncate(command.sample)));
    1.63 -       end
    1.64 -   endrule
    1.65 -
    1.66 -   rule feedOutput;
    1.67 -     let pipelineData <- pipeline.sampleOutput.get();
    1.68 -     AudioProcessorControl endOfFileTag = EndOfFile;
    1.69 -     AudioProcessorControl sampleTag = Data;
    1.70 -
    1.71 -     case (pipelineData) matches
    1.72 -       tagged EndOfFile: client_stub.makeRequest_SendProcessedStream(zeroExtend(pack(endOfFileTag)),?);
    1.73 -       tagged Sample .sample:client_stub.makeRequest_SendProcessedStream(zeroExtend(pack(sampleTag)),
    1.74 -                                                                         zeroExtend(pack(sample)));
    1.75 -     endcase
    1.76 -   endrule
    1.77 -
    1.78 -endmodule
    1.79 -
    1.80 -
     2.1 --- a/modules/bluespec/Pygar/common/AudioProcessorRRR.cpp	Tue May 04 19:53:09 2010 -0400
     2.2 +++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
     2.3 @@ -1,93 +0,0 @@
     2.4 -#include <cstdio>
     2.5 -#include <cstdlib>
     2.6 -#include <iostream>
     2.7 -#include <iomanip>
     2.8 -#include <stdio.h>
     2.9 -#include <sys/stat.h>
    2.10 -
    2.11 -#include "asim/rrr/service_ids.h"
    2.12 -
    2.13 -#include "asim/provides/connected_application.h"
    2.14 -
    2.15 -
    2.16 -
    2.17 -using namespace std;
    2.18 -
    2.19 -// ===== service instantiation =====
    2.20 -AUDIOPROCESSORRRR_SERVER_CLASS AUDIOPROCESSORRRR_SERVER_CLASS::instance;
    2.21 -
    2.22 -// constructor
    2.23 -AUDIOPROCESSORRRR_SERVER_CLASS::AUDIOPROCESSORRRR_SERVER_CLASS() :
    2.24 -    serverStub(new AUDIOPROCESSORRRR_SERVER_STUB_CLASS(this))
    2.25 -{
    2.26 -    // instantiate stub
    2.27 -    printf("AUDIOPROCESSORRR init called\n");
    2.28 -    outputFile = NULL;
    2.29 -}
    2.30 -
    2.31 -// destructor
    2.32 -AUDIOPROCESSORRRR_SERVER_CLASS::~AUDIOPROCESSORRRR_SERVER_CLASS()
    2.33 -{
    2.34 -    Cleanup();
    2.35 -}
    2.36 -
    2.37 -// init
    2.38 -void
    2.39 -AUDIOPROCESSORRRR_SERVER_CLASS::Init(PLATFORMS_MODULE p)
    2.40 -{
    2.41 -    parent = p;
    2.42 -}
    2.43 -
    2.44 -// uninit
    2.45 -void
    2.46 -AUDIOPROCESSORRRR_SERVER_CLASS::Uninit()
    2.47 -{
    2.48 -    Cleanup();
    2.49 -}
    2.50 -
    2.51 -// cleanup
    2.52 -void
    2.53 -AUDIOPROCESSORRRR_SERVER_CLASS::Cleanup()
    2.54 -{
    2.55 -    delete serverStub;
    2.56 -}
    2.57 -
    2.58 -
    2.59 -//
    2.60 -// RRR service methods
    2.61 -//
    2.62 -
    2.63 -void
    2.64 -AUDIOPROCESSORRRR_SERVER_CLASS::SendProcessedStream(UINT16 control, UINT16 data)
    2.65 -{
    2.66 -
    2.67 -  AudioProcessorControl audioProcessorControl = (AudioProcessorControl) control;
    2.68 -  switch(control) {
    2.69 -    case EndOfFile:
    2.70 -      if(outputFile != NULL) {
    2.71 -        fflush(outputFile);
    2.72 -        fclose(outputFile);
    2.73 -        outputFile = NULL;
    2.74 -      } else {
    2.75 -        outputFile = fopen("out_hw.pcm","w");
    2.76 -        assert(outputFile);
    2.77 -        fflush(outputFile);
    2.78 -        fclose(outputFile);
    2.79 -      }
    2.80 -
    2.81 -      CONNECTED_APPLICATION_CLASS::EndSimulation(); 
    2.82 -    break;
    2.83 -
    2.84 -    case Data:
    2.85 -      if(outputFile == NULL) {
    2.86 -        outputFile = fopen("out_hw.pcm","w");
    2.87 -        assert(outputFile);
    2.88 -      }
    2.89 -
    2.90 -      CONNECTED_APPLICATION_CLASS::UpdateSemaphore();  
    2.91 -      fwrite(&data, 2,1 , outputFile);
    2.92 -    break;
    2.93 -  }
    2.94 - 
    2.95 -}
    2.96 -
     3.1 --- a/modules/bluespec/Pygar/common/AudioProcessorRRR.h	Tue May 04 19:53:09 2010 -0400
     3.2 +++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
     3.3 @@ -1,50 +0,0 @@
     3.4 -
     3.5 -#ifndef _AUDIOPROCESSORRRR_
     3.6 -#define _AUDIOPROCESSORRRR_
     3.7 -
     3.8 -#include <stdio.h>
     3.9 -#include <sys/time.h>
    3.10 -
    3.11 -#include "asim/provides/low_level_platform_interface.h"
    3.12 -
    3.13 -#include "asim/provides/rrr.h"
    3.14 -
    3.15 -
    3.16 -
    3.17 -typedef class AUDIOPROCESSORRRR_SERVER_CLASS* AUDIOPROCESSORRRR_SERVER;
    3.18 -class AUDIOPROCESSORRRR_SERVER_CLASS: public RRR_SERVER_CLASS, public PLATFORMS_MODULE_CLASS
    3.19 -{
    3.20 -  private:
    3.21 -    // self-instantiation
    3.22 -    static AUDIOPROCESSORRRR_SERVER_CLASS instance;
    3.23 -    FILE *outputFile;
    3.24 -
    3.25 -    // server stub
    3.26 -    RRR_SERVER_STUB serverStub;
    3.27 -
    3.28 -    int count;    
    3.29 -
    3.30 -  public:
    3.31 -    AUDIOPROCESSORRRR_SERVER_CLASS();
    3.32 -    ~AUDIOPROCESSORRRR_SERVER_CLASS();
    3.33 -
    3.34 -    // static methods
    3.35 -    static AUDIOPROCESSORRRR_SERVER GetInstance() { return &instance; }
    3.36 -
    3.37 -    // required RRR methods
    3.38 -    void Init(PLATFORMS_MODULE);
    3.39 -    void Uninit();
    3.40 -    void Cleanup();
    3.41 -
    3.42 -    //
    3.43 -    // RRR service methods
    3.44 -    //
    3.45 -    void SendProcessedStream(UINT16 control, UINT16 data0);
    3.46 -};
    3.47 -
    3.48 -
    3.49 -
    3.50 -// include server stub
    3.51 -#include "asim/rrr/server_stub_AUDIOPROCESSORRRR.h"
    3.52 -
    3.53 -#endif
     4.1 --- a/modules/bluespec/Pygar/common/AudioProcessorRRR.rrr	Tue May 04 19:53:09 2010 -0400
     4.2 +++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
     4.3 @@ -1,14 +0,0 @@
     4.4 -service AUDIOPROCESSORRRR
     4.5 -{
     4.6 -    server sw (cpp, method) <- hw (bsv, connection) 
     4.7 -    {
     4.8 -       method SendProcessedStream (in UINT32[32] ctrl, in UINT32[32] sample);
     4.9 -    };
    4.10 -
    4.11 -    server hw (bsv, connection) <- sw (cpp, method)
    4.12 -    {
    4.13 -        method SendUnprocessedStream (in UINT32[32] ctrl, in UINT32[32] sample);
    4.14 -    };
    4.15 -
    4.16 -
    4.17 - };
     5.1 --- a/modules/bluespec/Pygar/core/AudioCoreRRR.rrr	Tue May 04 19:53:09 2010 -0400
     5.2 +++ b/modules/bluespec/Pygar/core/AudioCoreRRR.rrr	Tue May 04 22:32:52 2010 -0400
     5.3 @@ -3,9 +3,7 @@
     5.4      server hw (bsv, connection) <- sw (cpp, method)
     5.5      {
     5.6          method ReadCPUToHost  (out UINT32[32] regValue, in UINT32[32] dummy);
     5.7 -        method SendUnprocessedStream (in UINT32[32] ctrl, in UINT32[32] sample);
     5.8 -	//rlm: here it is modified to take N
     5.9 -//	method   SendUnprocessedStream (in UINT32[32] channel, in UINT32[32] ctrl, in UINT32[32] sample);
    5.10 +        method   SendUnprocessedStream (in UINT32[32] channel, in UINT32[32] ctrl, in UINT32[32] sample);
    5.11  
    5.12      };
    5.13  
    5.14 @@ -13,9 +11,7 @@
    5.15      {
    5.16         method SendProcessedStream (in UINT32[32] ctrl, in UINT32[32] sample);
    5.17  
    5.18 -// Not used by SCRATCHPAD
    5.19 -//     method MemoryRequestLoad  (in UINT32[32] address, out UINT32[32] value);
    5.20 -//     method MemoryRequestStore (in UINT32[32] address, in UINT32[32] value);
    5.21 +
    5.22      };
    5.23  
    5.24   };
     6.1 --- a/modules/bluespec/Pygar/core/AudioCoreSystem.cpp	Tue May 04 19:53:09 2010 -0400
     6.2 +++ b/modules/bluespec/Pygar/core/AudioCoreSystem.cpp	Tue May 04 22:32:52 2010 -0400
     6.3 @@ -69,7 +69,7 @@
     6.4  //UINT16 sample1;
     6.5  
     6.6    //rlm: not sure if normal ints are ok here; using UINT16 because I know it works
     6.7 -  UINT16 channel0 = 0;
     6.8 +  UINT16 channel0 = 5;
     6.9    //UINT16 channel1 = 1;
    6.10  
    6.11    //init processor 
    6.12 @@ -132,8 +132,8 @@
    6.13      
    6.14       printf("sending file\n");
    6.15      //rlm: two files.
    6.16 -     clientStub->SendUnprocessedStream( Data,(UINT32)sample);
    6.17 -     //clientStub->SendUnprocessedStream(channel0 , Data,(UINT32)sample);
    6.18 +    // clientStub->SendUnprocessedStream( Data,(UINT32)sample);
    6.19 +     clientStub->SendUnprocessedStream((UINT32)channel0 , Data,(UINT32)sample);
    6.20       //clientStub->SendUnprocessedStream(channel1 , Data,(UINT32)sample1);
    6.21  
    6.22    } 
    6.23 @@ -145,9 +145,9 @@
    6.24  
    6.25    //rlm: have to send end-files to both voices.  
    6.26    // all of these operations wil eventually be moved into functions.
    6.27 -  clientStub->SendUnprocessedStream(EndOfFile,0);
    6.28 -    //clientStub->SendUnprocessedStream(channel0, EndOfFile,0);
    6.29 -    // clientStub->SendUnprocessedStream(channel1, EndOfFile,0);
    6.30 +  //clientStub->SendUnprocessedStream(EndOfFile,0);
    6.31 +  clientStub->SendUnprocessedStream((UINT32)channel0, EndOfFile,0);
    6.32 +  // clientStub->SendUnprocessedStream(channel1, EndOfFile,0);
    6.33  
    6.34    printf("main: wait for end of file\n");
    6.35  
     7.1 --- a/modules/bluespec/Pygar/core/audioCorePipeline.bsv	Tue May 04 19:53:09 2010 -0400
     7.2 +++ b/modules/bluespec/Pygar/core/audioCorePipeline.bsv	Tue May 04 22:32:52 2010 -0400
     7.3 @@ -120,7 +120,12 @@
     7.4     rule feedInput;
     7.5       let command <- server_stub.acceptRequest_SendUnprocessedStream();
     7.6       AudioProcessorControl ctrl = unpack(truncate(command.ctrl));
     7.7 -     if(ctrl == EndOfFile)
     7.8 +
     7.9 +      Bit#(32) test = unpack(truncate(command.channel));
    7.10 +      $display("rlm: %x", test);
    7.11 +	   
    7.12 +
    7.13 +      if(ctrl == EndOfFile)
    7.14  	begin
    7.15  	  $display("lsp: PROCESSOR received EOF   ");
    7.16            core.sampleInput.put(tagged EndOfFile);