changeset 16:7e1510b47336 pygar svn.17

[svn r17] added rest of items for core
author punk
date Tue, 27 Apr 2010 22:54:50 -0400 (2010-04-28)
parents a1833d9f6e3d
children 9d1f38722f5b
files #AudioProcessor.cpp# #AudioProcessorRRR.rrr# #AudioProcessorTypes.bsv# AudioPipelineDefault.bsv AudioProcessor.bsv AudioProcessor.cpp AudioProcessor.h AudioProcessorRRR.cpp AudioProcessorRRR.h AudioProcessorRRR.rrr AudioProcessorTypes.bsv DFT.cpp SndfileWavUtil.cpp SndfileWavUtil.h audio_pipeline_default.awb audio_processor_hardware_system.awb audio_processor_software_system.awb audio_processor_types.awb common/PathTypes.bsv common/RoutingTable.bsv config/pm/Pygar/fullSystem/audio_core_exe.apm modules/bluespec/Pygar/core/audioPipeTypes.bsv modules/bluespec/Pygar/lab4/processor_library.awr
diffstat 22 files changed, 1131 insertions(+), 0 deletions(-) [+]
line wrap: on
line diff
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/#AudioProcessor.cpp#	Tue Apr 27 22:54:50 2010 -0400
     1.3 @@ -0,0 +1,104 @@
     1.4 +#include <stdio.h>
     1.5 +#include <pthread.h>
     1.6 +#include <semaphore.h>
     1.7 +
     1.8 +#include "asim/provides/connected_application.h"
     1.9 +//#include "asim/provides/SndfileWavUtil.h"
    1.10 +
    1.11 +#include "asim/rrr/client_stub_AUDIOPROCESSORRRR.h"
    1.12 +
    1.13 +using namespace std;
    1.14 +
    1.15 +pthread_mutex_t CONNECTED_APPLICATION_CLASS::lock;
    1.16 +pthread_cond_t  CONNECTED_APPLICATION_CLASS::cond;
    1.17 +sem_t CONNECTED_APPLICATION_CLASS::throttle;
    1.18 +
    1.19 +// constructor
    1.20 +CONNECTED_APPLICATION_CLASS::CONNECTED_APPLICATION_CLASS(VIRTUAL_PLATFORM vp) :
    1.21 +    clientStub(new AUDIOPROCESSORRRR_CLIENT_STUB_CLASS(this))
    1.22 +{
    1.23 +œôøº}
    1.24 +œôøºœôøºœôøº
    1.25 +// destructor
    1.26 +CONNECTED_APPLICATION_CLASS::~CONNECTED_APPLICATION_CLASS()
    1.27 +{
    1.28 +}
    1.29 +
    1.30 +// init
    1.31 +void
    1.32 +CONNECTED_APPLICATION_CLASS::Init()
    1.33 +{
    1.34 +
    1.35 +  pthread_mutex_init(&lock, NULL);
    1.36 +  pthread_cond_init(&cond, NULL);
    1.37 +  sem_init(&throttle, 0, 64);
    1.38 +
    1.39 +}
    1.40 +
    1.41 +void
    1.42 +CONNECTED_APPLICATION_CLASS::UpdateSemaphore()
    1.43 +{
    1.44 +  sem_post(&throttle);
    1.45 +}
    1.46 +
    1.47 +void
    1.48 +CONNECTED_APPLICATION_CLASS::EndSimulation()
    1.49 +{
    1.50 +  printf("EndSimulation Called\n");
    1.51 +  fflush(stdout);
    1.52 +  pthread_mutex_lock(&lock);
    1.53 +  // Do something about the race occuring here
    1.54 +  pthread_cond_signal(&cond); 
    1.55 +  pthread_mutex_unlock(&lock);
    1.56 +  printf("EndSimulation done\n");
    1.57 +  fflush(stdout);  
    1.58 +}
    1.59 +
    1.60 +// main
    1.61 +void
    1.62 +CONNECTED_APPLICATION_CLASS::Main()
    1.63 +{
    1.64 +  FILE *inputFile;
    1.65 +  UINT16 sample;
    1.66 +  
    1.67 +  // Convert input wav to pcm
    1.68 +  generate_pcm("input.wav","input.pcm");
    1.69 +
    1.70 +  //Send data to the machine here.
    1.71 +  inputFile = fopen("input.pcm","r");
    1.72 +  assert(inputFile);
    1.73 +
    1.74 +
    1.75 +  int count = 0;
    1.76 +
    1.77 +  printf("main: about to enter loop %d\n", count);  
    1.78 +
    1.79 +  while(fread(&sample, 2, 1, inputFile)) {
    1.80 +    if(count%1000 == 0)
    1.81 +      printf("main: %d\n", count);
    1.82 +    count++;
    1.83 +    sem_wait(&throttle);
    1.84 +    clientStub->SendUnprocessedStream(Data,(UINT32)sample);
    1.85 +  } 
    1.86 +
    1.87 +  printf("main: out of loop\n");
    1.88 +
    1.89 +  // Need to put lock here to prevent potential race condition
    1.90 +  pthread_mutex_lock(&lock);
    1.91 +  clientStub->SendUnprocessedStream(EndOfFile,0);
    1.92 +
    1.93 +  printf("main: wait for end of file\n");
    1.94 +
    1.95 +  pthread_cond_wait(&cond, &lock);
    1.96 +  pthread_mutex_unlock(&lock);
    1.97 +
    1.98 +  printf("main: lastt data out\n");
    1.99 +
   1.100 +  // Convert input wav to pcm
   1.101 +  generate_wav("out_hw.pcm","input.wav","out_hw.wav");
   1.102 +
   1.103 +  printf("generate wav done\n");
   1.104 +
   1.105 +  fflush(stdout);
   1.106 +  exit(0);
   1.107 +}
     2.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     2.2 +++ b/#AudioProcessorRRR.rrr#	Tue Apr 27 22:54:50 2010 -0400
     2.3 @@ -0,0 +1,14 @@
     2.4 +service AUDIOPROCESSORRRR
     2.5 +{
     2.6 +    server sw (cpp, method) <- hw (bsv, connection) 
     2.7 +    {
     2.8 +       method SendProcessedStream (in UINT32[32] ctrl, in UINT32[32] sample);
     2.9 +    };
    2.10 +
    2.11 +    server hw (bsv, connection) <- sw (cpp, method)
    2.12 +    {
    2.13 +        method SendUnprocessedStream (in UINT32[32] ctrl, in UINT32[32] sample);
    2.14 +    };
    2.15 +
    2.16 +
    2.17 + };
     3.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     3.2 +++ b/#AudioProcessorTypes.bsv#	Tue Apr 27 22:54:50 2010 -0400
     3.3 @@ -0,0 +1,52 @@
     3.4 +
     3.5 +// The MIT License
     3.6 +
     3.7 +// Copyright (c) 2009 Massachusetts Institute of Technology
     3.8 +
     3.9 +// Permission is hereby granted, free of charge, to any person obtaining a copy
    3.10 +// of this software and associated documentation files (the "Software"), to deal
    3.11 +// in the Software without restriction, including without limitation the rights
    3.12 +// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
    3.13 +// copies of the Software, and to permit persons to whom the Software is
    3.14 +// furnished to do so, subject to the following conditions:
    3.15 +
    3.16 +// The above copyright notice and this permission notice shall be included in
    3.17 +// all copies or substantial portions of the Software.
    3.18 +
    3.19 +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
    3.20 +// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
    3.21 +// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
    3.22 +// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
    3.23 +// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
    3.24 +// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
    3.25 +// THE SOFTWARE.
    3.26 +
    3.27 +// Author: Kermin Fleming kfleming@mit.edu
    3.28 +
    3.29 +import Connectable::*;
    3.30 +import GetPut::*;
    3.31 +import ClientServer::*;
    3.32 +
    3.33 +typedef Int#(16) Sample;
    3.34 +
    3.35 +typedef enum {
    3.36 +  EndOfFile = 0,
    3.37 +  Data = 1
    3.38 +} AudioProcessorControl deriving (Bits,Eq);
    3.39 +
    3.40 +
    3.41 +typedef struct { 
    3.42 +  Sample left;
    3.43 +  Sample right;
    3.44 +} StereoSample deriving (Bits,Eq);
    3.45 +
    3.46 +typedef union tagged{
    3.47 + Sample Sample;
    3.48 + void EndOfFile;
    3.49 +} AudioProcessorUnit deriving (Bits,Eq);
    3.50 +
    3.51 +interface AudioPipeline;
    3.52 +  interface Put#(AudioProcessorUnit) sampleInput;
    3.53 +  interface Get#(AudioProcessorUnit) sampleOutput;
    3.54 +endinterface
    3.55 +
     4.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     4.2 +++ b/AudioPipelineDefault.bsv	Tue Apr 27 22:54:50 2010 -0400
     4.3 @@ -0,0 +1,38 @@
     4.4 +// The MIT License
     4.5 +
     4.6 +// Copyright (c) 2009 Massachusetts Institute of Technology
     4.7 +
     4.8 +// Permission is hereby granted, free of charge, to any person obtaining a copy
     4.9 +// of this software and associated documentation files (the "Software"), to deal
    4.10 +// in the Software without restriction, including without limitation the rights
    4.11 +// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
    4.12 +// copies of the Software, and to permit persons to whom the Software is
    4.13 +// furnished to do so, subject to the following conditions:
    4.14 +
    4.15 +// The above copyright notice and this permission notice shall be included in
    4.16 +// all copies or substantial portions of the Software.
    4.17 +
    4.18 +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
    4.19 +// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
    4.20 +// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
    4.21 +// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
    4.22 +// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
    4.23 +// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
    4.24 +// THE SOFTWARE.
    4.25 +
    4.26 +// Author: Kermin Fleming kfleming@mit.edu
    4.27 +
    4.28 +import Connectable::*;
    4.29 +import GetPut::*;
    4.30 +import ClientServer::*;
    4.31 +import FIFO::*;
    4.32 +
    4.33 +`include "asim/provides/audio_processor_types.bsh"
    4.34 +
    4.35 +module mkAudioPipeline (AudioPipeline);
    4.36 +  FIFO#(AudioProcessorUnit) fifo <- mkFIFO;
    4.37 +  
    4.38 +  interface sampleInput = fifoToPut(fifo);
    4.39 +  interface sampleOutput = fifoToGet(fifo);
    4.40 +
    4.41 +endmodule
     5.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     5.2 +++ b/AudioProcessor.bsv	Tue Apr 27 22:54:50 2010 -0400
     5.3 @@ -0,0 +1,77 @@
     5.4 +// The MIT License
     5.5 +
     5.6 +// Copyright (c) 2009 Massachusetts Institute of Technology
     5.7 +
     5.8 +// Permission is hereby granted, free of charge, to any person obtaining a copy
     5.9 +// of this software and associated documentation files (the "Software"), to deal
    5.10 +// in the Software without restriction, including without limitation the rights
    5.11 +// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
    5.12 +// copies of the Software, and to permit persons to whom the Software is
    5.13 +// furnished to do so, subject to the following conditions:
    5.14 +
    5.15 +// The above copyright notice and this permission notice shall be included in
    5.16 +// all copies or substantial portions of the Software.
    5.17 +
    5.18 +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
    5.19 +// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
    5.20 +// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
    5.21 +// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
    5.22 +// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
    5.23 +// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
    5.24 +// THE SOFTWARE.
    5.25 +
    5.26 +import Connectable::*;
    5.27 +import GetPut::*;
    5.28 +import ClientServer::*;
    5.29 +
    5.30 +//AWB includes
    5.31 +`include "asim/provides/low_level_platform_interface.bsh"
    5.32 +`include "asim/provides/soft_connections.bsh"
    5.33 +`include "asim/provides/common_services.bsh"
    5.34 +
    5.35 +// Local includes
    5.36 +`include "asim/provides/audio_processor_types.bsh"
    5.37 +`include "asim/provides/audio_pipeline.bsh"
    5.38 +
    5.39 +`include "asim/rrr/remote_client_stub_AUDIOPROCESSORRRR.bsh"
    5.40 +`include "asim/rrr/remote_server_stub_AUDIOPROCESSORRRR.bsh"
    5.41 +
    5.42 +
    5.43 +module [CONNECTED_MODULE] mkConnectedApplication ();
    5.44 +
    5.45 +   // Instantiate the rrr stubs
    5.46 +   ClientStub_AUDIOPROCESSORRRR client_stub <- mkClientStub_AUDIOPROCESSORRRR();
    5.47 +   ServerStub_AUDIOPROCESSORRRR server_stub <- mkServerStub_AUDIOPROCESSORRRR();
    5.48 +
    5.49 +   // Instantiate the audio pipeline
    5.50 +   AudioPipeline pipeline <- mkAudioPipeline();
    5.51 +
    5.52 +   rule feedInput;
    5.53 +     let command <- server_stub.acceptRequest_SendUnprocessedStream();
    5.54 +     AudioProcessorControl ctrl = unpack(truncate(command.ctrl));
    5.55 +
    5.56 +     if(ctrl == EndOfFile)
    5.57 +       begin
    5.58 +         pipeline.sampleInput.put(tagged EndOfFile);
    5.59 +       end
    5.60 +     else 
    5.61 +       begin
    5.62 +         pipeline.sampleInput.put(tagged Sample unpack(truncate(command.sample)));
    5.63 +       end
    5.64 +   endrule
    5.65 +
    5.66 +   rule feedOutput;
    5.67 +     let pipelineData <- pipeline.sampleOutput.get();
    5.68 +     AudioProcessorControl endOfFileTag = EndOfFile;
    5.69 +     AudioProcessorControl sampleTag = Data;
    5.70 +
    5.71 +     case (pipelineData) matches
    5.72 +       tagged EndOfFile: client_stub.makeRequest_SendProcessedStream(zeroExtend(pack(endOfFileTag)),?);
    5.73 +       tagged Sample .sample:client_stub.makeRequest_SendProcessedStream(zeroExtend(pack(sampleTag)),
    5.74 +                                                                         zeroExtend(pack(sample)));
    5.75 +     endcase
    5.76 +   endrule
    5.77 +
    5.78 +endmodule
    5.79 +
    5.80 +
     6.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     6.2 +++ b/AudioProcessor.cpp	Tue Apr 27 22:54:50 2010 -0400
     6.3 @@ -0,0 +1,104 @@
     6.4 +#include <stdio.h>
     6.5 +#include <pthread.h>
     6.6 +#include <semaphore.h>
     6.7 +
     6.8 +#include "asim/provides/connected_application.h"
     6.9 +//#include "asim/provides/SndfileWavUtil.h"
    6.10 +
    6.11 +#include "asim/rrr/client_stub_AUDIOPROCESSORRRR.h"
    6.12 +
    6.13 +using namespace std;
    6.14 +
    6.15 +pthread_mutex_t CONNECTED_APPLICATION_CLASS::lock;
    6.16 +pthread_cond_t  CONNECTED_APPLICATION_CLASS::cond;
    6.17 +sem_t CONNECTED_APPLICATION_CLASS::throttle;
    6.18 +
    6.19 +// constructor
    6.20 +CONNECTED_APPLICATION_CLASS::CONNECTED_APPLICATION_CLASS(VIRTUAL_PLATFORM vp) :
    6.21 +    clientStub(new AUDIOPROCESSORRRR_CLIENT_STUB_CLASS(this))
    6.22 +{
    6.23 +}
    6.24 +
    6.25 +// destructor
    6.26 +CONNECTED_APPLICATION_CLASS::~CONNECTED_APPLICATION_CLASS()
    6.27 +{
    6.28 +}
    6.29 +
    6.30 +// init
    6.31 +void
    6.32 +CONNECTED_APPLICATION_CLASS::Init()
    6.33 +{
    6.34 +
    6.35 +  pthread_mutex_init(&lock, NULL);
    6.36 +  pthread_cond_init(&cond, NULL);
    6.37 +  sem_init(&throttle, 0, 64);
    6.38 +
    6.39 +}
    6.40 +
    6.41 +void
    6.42 +CONNECTED_APPLICATION_CLASS::UpdateSemaphore()
    6.43 +{
    6.44 +  sem_post(&throttle);
    6.45 +}
    6.46 +
    6.47 +void
    6.48 +CONNECTED_APPLICATION_CLASS::EndSimulation()
    6.49 +{
    6.50 +  printf("EndSimulation Called\n");
    6.51 +  fflush(stdout);
    6.52 +  pthread_mutex_lock(&lock);
    6.53 +  // Do something about the race occuring here
    6.54 +  pthread_cond_signal(&cond); 
    6.55 +  pthread_mutex_unlock(&lock);
    6.56 +  printf("EndSimulation done\n");
    6.57 +  fflush(stdout);  
    6.58 +}
    6.59 +
    6.60 +// main
    6.61 +void
    6.62 +CONNECTED_APPLICATION_CLASS::Main()
    6.63 +{
    6.64 +  FILE *inputFile;
    6.65 +  UINT16 sample;
    6.66 +  
    6.67 +  // Convert input wav to pcm
    6.68 +  generate_pcm("input.wav","input.pcm");
    6.69 +
    6.70 +  //Send data to the machine here.
    6.71 +  inputFile = fopen("input.pcm","r");
    6.72 +  assert(inputFile);
    6.73 +
    6.74 +
    6.75 +  int count = 0;
    6.76 +
    6.77 +  printf("main: about to enter loop %d\n", count);  
    6.78 +
    6.79 +  while(fread(&sample, 2, 1, inputFile)) {
    6.80 +    if(count%1000 == 0)
    6.81 +      printf("main: %d\n", count);
    6.82 +    count++;
    6.83 +    sem_wait(&throttle);
    6.84 +    clientStub->SendUnprocessedStream(Data,(UINT32)sample);
    6.85 +  } 
    6.86 +
    6.87 +  printf("main: out of loop\n");
    6.88 +
    6.89 +  // Need to put lock here to prevent potential race condition
    6.90 +  pthread_mutex_lock(&lock);
    6.91 +  clientStub->SendUnprocessedStream(EndOfFile,0);
    6.92 +
    6.93 +  printf("main: wait for end of file\n");
    6.94 +
    6.95 +  pthread_cond_wait(&cond, &lock);
    6.96 +  pthread_mutex_unlock(&lock);
    6.97 +
    6.98 +  printf("main: lastt data out\n");
    6.99 +
   6.100 +  // Convert input wav to pcm
   6.101 +  generate_wav("out_hw.pcm","input.wav","out_hw.wav");
   6.102 +
   6.103 +  printf("generate wav done\n");
   6.104 +
   6.105 +  fflush(stdout);
   6.106 +  exit(0);
   6.107 +}
     7.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     7.2 +++ b/AudioProcessor.h	Tue Apr 27 22:54:50 2010 -0400
     7.3 @@ -0,0 +1,56 @@
     7.4 +//
     7.5 +// INTEL CONFIDENTIAL
     7.6 +// Copyright (c) 2008 Intel Corp.  Recipient is granted a non-sublicensable 
     7.7 +// copyright license under Intel copyrights to copy and distribute this code 
     7.8 +// internally only. This code is provided "AS IS" with no support and with no 
     7.9 +// warranties of any kind, including warranties of MERCHANTABILITY,
    7.10 +// FITNESS FOR ANY PARTICULAR PURPOSE or INTELLECTUAL PROPERTY INFRINGEMENT. 
    7.11 +// By making any use of this code, Recipient agrees that no other licenses 
    7.12 +// to any Intel patents, trade secrets, copyrights or other intellectual 
    7.13 +// property rights are granted herein, and no other licenses shall arise by 
    7.14 +// estoppel, implication or by operation of law. Recipient accepts all risks 
    7.15 +// of use.
    7.16 +//
    7.17 +
    7.18 +// possibly use include paths to hide existing modules?
    7.19 +
    7.20 +#ifndef __AUDIO_PROCESSOR_CONNECTED_APPLICATION__
    7.21 +#define __AUDIO_PROCESSOR_CONNECTED_APPLICATION__
    7.22 +
    7.23 +#include <stdio.h>
    7.24 +#include <pthread.h>
    7.25 +#include <semaphore.h>
    7.26 +
    7.27 +#include "asim/provides/virtual_platform.h"
    7.28 +
    7.29 +#include "asim/rrr/client_stub_AUDIOPROCESSORRRR.h"
    7.30 +
    7.31 +typedef enum {
    7.32 +  EndOfFile = 0,
    7.33 +  Data = 1
    7.34 +} AudioProcessorControl; 
    7.35 +
    7.36 +
    7.37 +typedef class CONNECTED_APPLICATION_CLASS* CONNECTED_APPLICATION;
    7.38 +class CONNECTED_APPLICATION_CLASS : public PLATFORMS_MODULE_CLASS
    7.39 +{
    7.40 +  private:
    7.41 +    AUDIOPROCESSORRRR_CLIENT_STUB clientStub;
    7.42 +    static sem_t throttle;
    7.43 +    static pthread_mutex_t lock;
    7.44 +    static pthread_cond_t  cond;    
    7.45 +
    7.46 +  public:
    7.47 +    CONNECTED_APPLICATION_CLASS(VIRTUAL_PLATFORM vp);
    7.48 +    ~CONNECTED_APPLICATION_CLASS();
    7.49 +    static void EndSimulation();
    7.50 +    static void UpdateSemaphore();
    7.51 +
    7.52 +    // init
    7.53 +    void Init();
    7.54 +
    7.55 +    // main
    7.56 +    void Main();
    7.57 +};
    7.58 +
    7.59 +#endif
     8.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     8.2 +++ b/AudioProcessorRRR.cpp	Tue Apr 27 22:54:50 2010 -0400
     8.3 @@ -0,0 +1,93 @@
     8.4 +#include <cstdio>
     8.5 +#include <cstdlib>
     8.6 +#include <iostream>
     8.7 +#include <iomanip>
     8.8 +#include <stdio.h>
     8.9 +#include <sys/stat.h>
    8.10 +
    8.11 +#include "asim/rrr/service_ids.h"
    8.12 +
    8.13 +#include "asim/provides/connected_application.h"
    8.14 +
    8.15 +
    8.16 +
    8.17 +using namespace std;
    8.18 +
    8.19 +// ===== service instantiation =====
    8.20 +AUDIOPROCESSORRRR_SERVER_CLASS AUDIOPROCESSORRRR_SERVER_CLASS::instance;
    8.21 +
    8.22 +// constructor
    8.23 +AUDIOPROCESSORRRR_SERVER_CLASS::AUDIOPROCESSORRRR_SERVER_CLASS() :
    8.24 +    serverStub(new AUDIOPROCESSORRRR_SERVER_STUB_CLASS(this))
    8.25 +{
    8.26 +    // instantiate stub
    8.27 +    printf("AUDIOPROCESSORRR init called\n");
    8.28 +    outputFile = NULL;
    8.29 +}
    8.30 +
    8.31 +// destructor
    8.32 +AUDIOPROCESSORRRR_SERVER_CLASS::~AUDIOPROCESSORRRR_SERVER_CLASS()
    8.33 +{
    8.34 +    Cleanup();
    8.35 +}
    8.36 +
    8.37 +// init
    8.38 +void
    8.39 +AUDIOPROCESSORRRR_SERVER_CLASS::Init(PLATFORMS_MODULE p)
    8.40 +{
    8.41 +    parent = p;
    8.42 +}
    8.43 +
    8.44 +// uninit
    8.45 +void
    8.46 +AUDIOPROCESSORRRR_SERVER_CLASS::Uninit()
    8.47 +{
    8.48 +    Cleanup();
    8.49 +}
    8.50 +
    8.51 +// cleanup
    8.52 +void
    8.53 +AUDIOPROCESSORRRR_SERVER_CLASS::Cleanup()
    8.54 +{
    8.55 +    delete serverStub;
    8.56 +}
    8.57 +
    8.58 +
    8.59 +//
    8.60 +// RRR service methods
    8.61 +//
    8.62 +
    8.63 +void
    8.64 +AUDIOPROCESSORRRR_SERVER_CLASS::SendProcessedStream(UINT16 control, UINT16 data)
    8.65 +{
    8.66 +
    8.67 +  AudioProcessorControl audioProcessorControl = (AudioProcessorControl) control;
    8.68 +  switch(control) {
    8.69 +    case EndOfFile:
    8.70 +      if(outputFile != NULL) {
    8.71 +        fflush(outputFile);
    8.72 +        fclose(outputFile);
    8.73 +        outputFile = NULL;
    8.74 +      } else {
    8.75 +        outputFile = fopen("out_hw.pcm","w");
    8.76 +        assert(outputFile);
    8.77 +        fflush(outputFile);
    8.78 +        fclose(outputFile);
    8.79 +      }
    8.80 +
    8.81 +      CONNECTED_APPLICATION_CLASS::EndSimulation(); 
    8.82 +    break;
    8.83 +
    8.84 +    case Data:
    8.85 +      if(outputFile == NULL) {
    8.86 +        outputFile = fopen("out_hw.pcm","w");
    8.87 +        assert(outputFile);
    8.88 +      }
    8.89 +
    8.90 +      CONNECTED_APPLICATION_CLASS::UpdateSemaphore();  
    8.91 +      fwrite(&data, 2,1 , outputFile);
    8.92 +    break;
    8.93 +  }
    8.94 + 
    8.95 +}
    8.96 +
     9.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     9.2 +++ b/AudioProcessorRRR.h	Tue Apr 27 22:54:50 2010 -0400
     9.3 @@ -0,0 +1,50 @@
     9.4 +
     9.5 +#ifndef _AUDIOPROCESSORRRR_
     9.6 +#define _AUDIOPROCESSORRRR_
     9.7 +
     9.8 +#include <stdio.h>
     9.9 +#include <sys/time.h>
    9.10 +
    9.11 +#include "asim/provides/low_level_platform_interface.h"
    9.12 +
    9.13 +#include "asim/provides/rrr.h"
    9.14 +
    9.15 +
    9.16 +
    9.17 +typedef class AUDIOPROCESSORRRR_SERVER_CLASS* AUDIOPROCESSORRRR_SERVER;
    9.18 +class AUDIOPROCESSORRRR_SERVER_CLASS: public RRR_SERVER_CLASS, public PLATFORMS_MODULE_CLASS
    9.19 +{
    9.20 +  private:
    9.21 +    // self-instantiation
    9.22 +    static AUDIOPROCESSORRRR_SERVER_CLASS instance;
    9.23 +    FILE *outputFile;
    9.24 +
    9.25 +    // server stub
    9.26 +    RRR_SERVER_STUB serverStub;
    9.27 +
    9.28 +    int count;    
    9.29 +
    9.30 +  public:
    9.31 +    AUDIOPROCESSORRRR_SERVER_CLASS();
    9.32 +    ~AUDIOPROCESSORRRR_SERVER_CLASS();
    9.33 +
    9.34 +    // static methods
    9.35 +    static AUDIOPROCESSORRRR_SERVER GetInstance() { return &instance; }
    9.36 +
    9.37 +    // required RRR methods
    9.38 +    void Init(PLATFORMS_MODULE);
    9.39 +    void Uninit();
    9.40 +    void Cleanup();
    9.41 +
    9.42 +    //
    9.43 +    // RRR service methods
    9.44 +    //
    9.45 +    void SendProcessedStream(UINT16 control, UINT16 data0);
    9.46 +};
    9.47 +
    9.48 +
    9.49 +
    9.50 +// include server stub
    9.51 +#include "asim/rrr/server_stub_AUDIOPROCESSORRRR.h"
    9.52 +
    9.53 +#endif
    10.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
    10.2 +++ b/AudioProcessorRRR.rrr	Tue Apr 27 22:54:50 2010 -0400
    10.3 @@ -0,0 +1,14 @@
    10.4 +service AUDIOPROCESSORRRR
    10.5 +{
    10.6 +    server sw (cpp, method) <- hw (bsv, connection) 
    10.7 +    {
    10.8 +       method SendProcessedStream (in UINT32[32] ctrl, in UINT32[32] sample);
    10.9 +    };
   10.10 +
   10.11 +    server hw (bsv, connection) <- sw (cpp, method)
   10.12 +    {
   10.13 +        method SendUnprocessedStream (in UINT32[32] ctrl, in UINT32[32] sample);
   10.14 +    };
   10.15 +
   10.16 +
   10.17 + };
    11.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
    11.2 +++ b/AudioProcessorTypes.bsv	Tue Apr 27 22:54:50 2010 -0400
    11.3 @@ -0,0 +1,52 @@
    11.4 +
    11.5 +// The MIT License
    11.6 +
    11.7 +// Copyright (c) 2009 Massachusetts Institute of Technology
    11.8 +
    11.9 +// Permission is hereby granted, free of charge, to any person obtaining a copy
   11.10 +// of this software and associated documentation files (the "Software"), to deal
   11.11 +// in the Software without restriction, including without limitation the rights
   11.12 +// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
   11.13 +// copies of the Software, and to permit persons to whom the Software is
   11.14 +// furnished to do so, subject to the following conditions:
   11.15 +
   11.16 +// The above copyright notice and this permission notice shall be included in
   11.17 +// all copies or substantial portions of the Software.
   11.18 +
   11.19 +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
   11.20 +// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
   11.21 +// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
   11.22 +// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
   11.23 +// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
   11.24 +// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
   11.25 +// THE SOFTWARE.
   11.26 +
   11.27 +// Author: Kermin Fleming kfleming@mit.edu
   11.28 +
   11.29 +import Connectable::*;
   11.30 +import GetPut::*;
   11.31 +import ClientServer::*;
   11.32 +
   11.33 +typedef Int#(16) Sample;
   11.34 +
   11.35 +typedef enum {
   11.36 +  EndOfFile = 0,
   11.37 +  Data = 1
   11.38 +} AudioProcessorControl deriving (Bits,Eq);
   11.39 +
   11.40 +
   11.41 +typedef struct { 
   11.42 +  Sample left;
   11.43 +  Sample right;
   11.44 +} StereoSample deriving (Bits,Eq);
   11.45 +
   11.46 +typedef union tagged{
   11.47 + Sample Sample;
   11.48 + void EndOfFile;
   11.49 +} AudioProcessorUnit deriving (Bits,Eq);
   11.50 +
   11.51 +interface AudioPipeline;
   11.52 +  interface Put#(AudioProcessorUnit) sampleInput;
   11.53 +  interface Get#(AudioProcessorUnit) sampleOutput;
   11.54 +endinterface
   11.55 +
    12.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
    12.2 +++ b/DFT.cpp	Tue Apr 27 22:54:50 2010 -0400
    12.3 @@ -0,0 +1,46 @@
    12.4 +#include <stdio.h>
    12.5 +#include <stdlib.h>
    12.6 +#include <math.h>
    12.7 +
    12.8 +
    12.9 +int DFT(int dir,int m,double *x1,double *y1)
   12.10 +{
   12.11 +   long i,k;
   12.12 +   double arg;
   12.13 +   double cosarg,sinarg;
   12.14 +   double *x2=NULL,*y2=NULL;
   12.15 +
   12.16 +   x2 = (double *)(malloc(m*sizeof(double)));
   12.17 +   y2 = (double *)(malloc(m*sizeof(double)));
   12.18 +   if (x2 == NULL || y2 == NULL)
   12.19 +      return 0;
   12.20 +
   12.21 +   for (i=0;i<m;i++) {
   12.22 +      x2[i] = 0;
   12.23 +      y2[i] = 0;
   12.24 +      arg = - dir * 2.0 * 3.141592654 * (double)i / (double)m;
   12.25 +      for (k=0;k<m;k++) {
   12.26 +         cosarg = cos(k * arg);
   12.27 +         sinarg = sin(k * arg);
   12.28 +         x2[i] += (x1[k] * cosarg - y1[k] * sinarg);
   12.29 +         y2[i] += (x1[k] * sinarg + y1[k] * cosarg);
   12.30 +      }
   12.31 +   }
   12.32 +
   12.33 +   /* Copy the data back */
   12.34 +   if (dir == 1) {
   12.35 +      for (i=0;i<m;i++) {
   12.36 +         x1[i] = x2[i];
   12.37 +         y1[i] = y2[i];
   12.38 +      }
   12.39 +   } else {
   12.40 +      for (i=0;i<m;i++) {
   12.41 +         x1[i] = x2[i];
   12.42 +         y1[i] = y2[i];
   12.43 +      }
   12.44 +   }
   12.45 +
   12.46 +   free(x2);
   12.47 +   free(y2);
   12.48 +   return 1;
   12.49 +}
    13.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
    13.2 +++ b/SndfileWavUtil.cpp	Tue Apr 27 22:54:50 2010 -0400
    13.3 @@ -0,0 +1,125 @@
    13.4 +#include <stdlib.h>
    13.5 +#include <string.h>
    13.6 +#include <errno.h>
    13.7 +#include <math.h>
    13.8 +#include <sndfile.h>
    13.9 +#include "SndfileWavUtil.h"
   13.10 +
   13.11 +void
   13.12 +generate_wav(const char * pcmfilename, const char * samplewavfilename, const char * outputwavfilename)
   13.13 +{
   13.14 +  char outfilename[2048];
   13.15 +  SNDFILE * outfile ;
   13.16 +  SNDFILE * wavfile ;
   13.17 +  SNDFILE * pcmfile ;
   13.18 +  SF_INFO wavinfo ;
   13.19 +  SF_INFO pcminfo ;
   13.20 +  int buff;
   13.21 +  SF_INSTRUMENT inst ;
   13.22 +  
   13.23 +  memset (&wavinfo, 0, sizeof (wavinfo)) ;
   13.24 +
   13.25 +  
   13.26 +  wavfile = sf_open(samplewavfilename, SFM_READ, &wavinfo);
   13.27 +
   13.28 +  if (wavfile == NULL){      
   13.29 +    printf ("\nERROR : Not able to open wav file named '%s' : %s/\n", samplewavfilename, sf_strerror (NULL)) ;
   13.30 +    exit (1) ;
   13.31 +  } ;
   13.32 +
   13.33 +  printf("WAV format: %x\n", wavinfo.format);
   13.34 +
   13.35 +  if (!((wavinfo.format & SF_FORMAT_PCM_16) && (wavinfo.channels == 1) && 
   13.36 +        (wavinfo.format & SF_FORMAT_WAV))){
   13.37 +    printf("\nERROR : .wav file must be SF_FORMAT_PCM_16 in mono\n");
   13.38 +  }
   13.39 +
   13.40 +  pcminfo.format = SF_FORMAT_RAW | SF_FORMAT_PCM_16;
   13.41 +  pcminfo.samplerate = wavinfo.samplerate;
   13.42 +  pcminfo.channels = wavinfo.channels;
   13.43 +
   13.44 +  pcmfile = sf_open(pcmfilename, SFM_READ, &pcminfo);
   13.45 +
   13.46 +  if (pcmfile == NULL){      
   13.47 +    printf ("\nERROR : Not able to open pcm file named '%s' : %s/\n", pcmfilename, sf_strerror (NULL)) ;
   13.48 +    exit (1) ;
   13.49 +  } ;
   13.50 +
   13.51 +
   13.52 +
   13.53 +  outfile = sf_open(outputwavfilename, SFM_WRITE, &wavinfo);
   13.54 +
   13.55 +  memset (&inst, 0, sizeof (inst)) ;
   13.56 +
   13.57 +  for(int i = SF_STR_FIRST; i <= SF_STR_LAST; i = i + 1) { 
   13.58 +    const char * str =  sf_get_string(wavfile,i);
   13.59 +    if(str != NULL) {
   13.60 +      sf_set_string(outfile,i,str);
   13.61 +    }
   13.62 +  }
   13.63 +  
   13.64 +  if (outfile == NULL){      
   13.65 +    printf ("\nERROR : Not able to create wav file named '%s' : %s/\n", outfilename, sf_strerror (NULL)) ;
   13.66 +    exit (1) ;
   13.67 +  } ;
   13.68 +
   13.69 +  while(sf_read_int(pcmfile, &buff, 1) == 1){
   13.70 +    if(sf_write_int(outfile, &buff, 1) != 1){
   13.71 +      printf("\nERROR : unable to write to '%s' : %s/\n", outfilename, sf_strerror(NULL));
   13.72 +    }
   13.73 +  }
   13.74 +  
   13.75 +  sf_close (wavfile) ;
   13.76 +  sf_close (outfile) ;
   13.77 +  sf_close (pcmfile) ;
   13.78 +  
   13.79 +}
   13.80 +
   13.81 +
   13.82 +void
   13.83 +generate_pcm (const char * wavfilename, const char * pcmfilename)
   13.84 +{
   13.85 +	SNDFILE * wavfile ;
   13.86 +	SNDFILE * pcmfile ;
   13.87 +	SF_INFO wavinfo ;
   13.88 +	SF_INFO pcminfo ;
   13.89 +	int buff;
   13.90 +
   13.91 +	memset (&wavinfo, 0, sizeof (wavinfo)) ;
   13.92 +	memset (&pcminfo, 0, sizeof (pcminfo)) ;
   13.93 +
   13.94 +	wavfile = sf_open (wavfilename, SFM_READ, &wavinfo) ;
   13.95 +
   13.96 +	if (wavfile == NULL){      
   13.97 +	  printf ("\nERROR : Not able to open wav file named '%s' : %s/\n", wavfilename, sf_strerror (NULL)) ;
   13.98 +	  exit (1) ;
   13.99 +	} ;
  13.100 +
  13.101 +	pcminfo.format = SF_FORMAT_RAW | SF_FORMAT_PCM_16;
  13.102 +	pcminfo.samplerate = wavinfo.samplerate;
  13.103 +	pcminfo.channels = wavinfo.channels;
  13.104 +
  13.105 +	if ((!wavinfo.format & SF_FORMAT_PCM_16) || (!wavinfo.channels == 1)){
  13.106 +	  printf("\nERROR : .wav file must be SF_FORMAT_PCM_16 and mono\n");
  13.107 +	}
  13.108 +
  13.109 +	pcmfile = sf_open (pcmfilename, SFM_WRITE, &pcminfo) ;
  13.110 +
  13.111 +	if (pcmfile == NULL){      
  13.112 +	  printf ("\nERROR : Not able to create pcm file named '%s' : %s/\n", pcmfilename, sf_strerror (NULL)) ;
  13.113 +	  exit (1) ;
  13.114 +	} ;
  13.115 +	
  13.116 +	while(sf_read_int(wavfile, &buff, 1) == 1){
  13.117 +	  if(sf_write_int(pcmfile, &buff, 1) != 1){
  13.118 +	    printf("\nERROR : unable to write to '%s' : %s/\n", pcmfilename, sf_strerror(NULL));
  13.119 +	  }
  13.120 +	}
  13.121 +
  13.122 +	sf_close (wavfile) ;
  13.123 +	sf_close (pcmfile) ;
  13.124 +} 
  13.125 +
  13.126 +
  13.127 +
  13.128 +
    14.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
    14.2 +++ b/SndfileWavUtil.h	Tue Apr 27 22:54:50 2010 -0400
    14.3 @@ -0,0 +1,9 @@
    14.4 +#ifndef _SNDFILE_WAV_UTIL_
    14.5 +#define _SNDFILE_WAV_UTIL_
    14.6 +
    14.7 +int guess_direction (const char * filename1, const char * filename2) ;
    14.8 +int guess_major_format (const char * filename) ;
    14.9 +void generate_pcm(const char * wavfilename, const char * pcmfilename);
   14.10 +void generate_wav(const char * pcmfilename, const char * samplewavfilename, const char * outputwavfilename);
   14.11 +
   14.12 +#endif
    15.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
    15.2 +++ b/audio_pipeline_default.awb	Tue Apr 27 22:54:50 2010 -0400
    15.3 @@ -0,0 +1,10 @@
    15.4 +%name Default Audio Pipeline
    15.5 +%desc A basic copy-though audio pipeline
    15.6 +
    15.7 +%provides audio_pipeline
    15.8 +
    15.9 +%attributes 6_375
   15.10 +
   15.11 +%public AudioPipelineDefault.bsv
   15.12 +
   15.13 +
    16.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
    16.2 +++ b/audio_processor_hardware_system.awb	Tue Apr 27 22:54:50 2010 -0400
    16.3 @@ -0,0 +1,19 @@
    16.4 +%name Audio Processor Application
    16.5 +%desc Top level audio processor. This module wraps an Audio Pipeline, providing communications between host and audio processor
    16.6 +
    16.7 +%provides connected_application
    16.8 +
    16.9 +%requires audio_processor_types
   16.10 +%requires audio_pipeline
   16.11 +
   16.12 +%attributes 6_375
   16.13 +
   16.14 +%sources -t H    -v PUBLIC  AudioProcessor.h
   16.15 +%sources -t H    -v PUBLIC  AudioProcessorRRR.h
   16.16 +%sources -t H    -v PUBLIC  SndfileWavUtil.h
   16.17 +%sources -t BSV  -v PUBLIC  AudioProcessor.bsv
   16.18 +%sources -t CPP  -v PRIVATE AudioProcessor.cpp
   16.19 +%sources -t CPP  -v PRIVATE AudioProcessorRRR.cpp
   16.20 +%sources -t CPP  -v PRIVATE SndfileWavUtil.cpp
   16.21 +%sources -t RRR  -v PUBLIC  AudioProcessorRRR.rrr
   16.22 +%library /usr/lib/libsndfile.so
    17.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
    17.2 +++ b/audio_processor_software_system.awb	Tue Apr 27 22:54:50 2010 -0400
    17.3 @@ -0,0 +1,16 @@
    17.4 +********************************************************************
    17.5 +* Awb module specification
    17.6 +********************************************************************
    17.7 +
    17.8 +%AWB_START
    17.9 +
   17.10 +%name Audio Processor Software
   17.11 +%desc Audio Processor Software 
   17.12 +%provides software_system
   17.13 +
   17.14 +%attributes 6_375
   17.15 +
   17.16 +%public AudioProcessor.cpp
   17.17 +%public AudioProcessor.h
   17.18 +
   17.19 +%AWB_END
    18.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
    18.2 +++ b/audio_processor_types.awb	Tue Apr 27 22:54:50 2010 -0400
    18.3 @@ -0,0 +1,9 @@
    18.4 +%name Audio Processor Types
    18.5 +%desc Audio Processing Pipeline Types
    18.6 +
    18.7 +%provides audio_processor_types
    18.8 +
    18.9 +%attributes 6_375
   18.10 +
   18.11 +%public AudioProcessorTypes.bsv
   18.12 +
    19.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
    19.2 +++ b/common/PathTypes.bsv	Tue Apr 27 22:54:50 2010 -0400
    19.3 @@ -0,0 +1,31 @@
    19.4 +import Trace::*;
    19.5 +import Vector::*;
    19.6 +
    19.7 +`define MAX_VOICES       4
    19.8 +`define MAX_CORES       16
    19.9 +`define MAX_PATH_IDS    18
   19.10 +`define MAX_PATH_LENGTH 8
   19.11 +
   19.12 +// The path is hardwired and so should never be stored in a register.  Therefore int type rather than Bit type
   19.13 +
   19.14 +typedef Bit#(32) MemAddr;
   19.15 +typedef Int#(TLog#(`MAX_PATH_IDS))  PathId;
   19.16 +typedef Int#(24) Sample;
   19.17 +typedef Int#(TLog#(`MAX_VOICES)) VoiceId;
   19.18 +
   19.19 +
   19.20 +//The mixer is identified as PathId 0, path end is max 
   19.21 +PathId mixerId = 0;
   19.22 +PathId endId = `MAX_CORES+1;
   19.23 +
   19.24 +// Path is array of path ids
   19.25 +typedef Vector#(`MAX_PATH_LENGTH,  PathId) CorePath;
   19.26 +CorePath emptyCore = replicate(endId);
   19.27 +
   19.28 +typedef struct
   19.29 +{
   19.30 +  VoiceId   voice;
   19.31 +  MemAddr   startAddr;
   19.32 +  CorePath  route;
   19.33 +} FullPath deriving (Bits, Eq);
   19.34 +
    20.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
    20.2 +++ b/common/RoutingTable.bsv	Tue Apr 27 22:54:50 2010 -0400
    20.3 @@ -0,0 +1,52 @@
    20.4 +import Trace::*;
    20.5 +import Vector::*;
    20.6 +import PathTypes::*;
    20.7 +
    20.8 +function FullPath genEmptyPaths (Integer a) ;
    20.9 +   FullPath empt = FullPath {voice: fromInteger(a), startAddr: 0, route: emptyCore};
   20.10 +   return (empt);
   20.11 +endfunction
   20.12 +
   20.13 +interface RoutingTable;
   20.14 +   method FullPath getPath(Integer voiceNo);
   20.15 +endinterface
   20.16 +
   20.17 +module mkRoutingTable(RoutingTable);
   20.18 +   Vector#(`MAX_VOICES, FullPath) routeTable = genWith(genEmptyPaths);
   20.19 +
   20.20 +   function CorePath updateVoice0(Integer len, Vector#(len, PathId) cores, CorePath inPath);
   20.21 +      CorePath outPath = inPath;
   20.22 +      for(Integer i = 0; i < len; i = i+1)
   20.23 +	inPath[i] = cores[i];
   20.24 +      return outPath;
   20.25 +   endfunction
   20.26 +
   20.27 +   //demonstrate two ways of building the routeTable
   20.28 +   routeTable[0].startAddr = 0;  //where is this really going to come from?
   20.29 +   routeTable[0].route[0] = 3;
   20.30 +   routeTable[0].route[1] = mixerId;
   20.31 +   //rest are already initialized toinvalid
   20.32 +
   20.33 +   // or if you just want to update a straight list, this longer emplate works.
   20.34 +   function CorePath createVoice1Route();
   20.35 +      CorePath outPath = emptyCore;
   20.36 +      
   20.37 +      Integer len = 3;
   20.38 +      PathId route[len] = {1, 2, mixerId}; //route to update
   20.39 + 
   20.40 +      for(Integer i = 0; i < len; i = i+1)
   20.41 +	 outPath[i] = route[i];
   20.42 +      
   20.43 +      return outPath;
   20.44 +   endfunction
   20.45 +   routeTable[1].route = createVoice1Route;
   20.46 +   routeTable[1].startAddr = 0;
   20.47 +
   20.48 +   //remaining voices are all initialized to empty.
   20.49 +   
   20.50 +   method FullPath getPath(Integer a);
   20.51 +      return routeTable[a];
   20.52 +   endmethod
   20.53 +   
   20.54 +endmodule
   20.55 + 
    21.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
    21.2 +++ b/config/pm/Pygar/fullSystem/audio_core_exe.apm	Tue Apr 27 22:54:50 2010 -0400
    21.3 @@ -0,0 +1,110 @@
    21.4 +
    21.5 +[Global]
    21.6 +SaveParameters=0
    21.7 +Description=
    21.8 +File=audio_core_exe
    21.9 +Version=2.1
   21.10 +Name=Audio Processor
   21.11 +DefaultBenchmark=config/bm/bluespec/demos.cfx/benchmarks/null.cfg
   21.12 +Type=HAsim
   21.13 +Class=Asim::Model
   21.14 +DefaultRunOpts=
   21.15 +
   21.16 +[Model]
   21.17 +DefaultAttributes=hybrid simulation
   21.18 +model=HW/SW Hybrid Project Foundation
   21.19 +
   21.20 +[FPGA Environment]
   21.21 +File=config/pm/hasim/submodels/fpgaenv/fpgaenv-hybrid-exe.apm
   21.22 +Packagehint=platforms
   21.23 +
   21.24 +[Soft Connections Hybrid Application Environment/Requires]
   21.25 +platform_services=Platform Services
   21.26 +soft_connections_lib=Soft Connections Library
   21.27 +connected_application=audio pipeline with soft core
   21.28 +
   21.29 +[Hybrid Project Common Utilities]
   21.30 +File=config/pm/hasim/submodels/common/project-common-default.apm
   21.31 +Packagehint=hasim
   21.32 +
   21.33 +[Soft Connections Library]
   21.34 +File=config/pm/hasim/submodels/common/soft-connections-lib.apm
   21.35 +Packagehint=hasim
   21.36 +
   21.37 +[Platform Services]
   21.38 +File=config/pm/hasim/submodels/platform-services/standard-platform-services.apm
   21.39 +Packagehint=hasim
   21.40 +
   21.41 +[HW/SW Hybrid Project Foundation]
   21.42 +File=modules/project/project-hybrid.awb
   21.43 +Packagehint=platforms
   21.44 +
   21.45 +[Soft Connections Hybrid Application Environment]
   21.46 +File=modules/application-env/hybrid/soft-connections/application-env-hybrid-soft-conn.awb
   21.47 +Packagehint=platforms
   21.48 +
   21.49 +[HW/SW Hybrid Project Foundation/Requires]
   21.50 +project_common=Hybrid Project Common Utilities
   21.51 +fpgaenv=FPGA Environment
   21.52 +application_env=Soft Connections Hybrid Application Environment
   21.53 +
   21.54 +[HW/SW Hybrid Project Foundation/Params]
   21.55 +WAIT_FOR_HARDWARE=0
   21.56 +
   21.57 +[VMH hybrid memory]
   21.58 +File=modules/hasim/functional-partition/memory-state/memory/hybrid/vmh/vmh-memory.awb
   21.59 +Packagehint=hasim
   21.60 +
   21.61 +[Functional Partition Base Types]
   21.62 +File=modules/hasim/functional-partition/base-types/funcp-base-types.awb
   21.63 +Packagehint=hasim
   21.64 +
   21.65 +[3-Stage Audio Processor]
   21.66 +File=modules/bluespec/mit-6.375/core/processor.awb
   21.67 +Packagehint=mit-6.375
   21.68 +
   21.69 +[Blocking Data Cache]
   21.70 +File=modules/bluespec/mit-6.375/lab4/data_cache.awb
   21.71 +Packagehint=mit-6.375
   21.72 +
   21.73 +[Blocking Instruction Cache]
   21.74 +File=modules/bluespec/mit-6.375/lab4/instruction_cache.awb
   21.75 +Packagehint=mit-6.375
   21.76 +
   21.77 +[Default HAsim Common Library]
   21.78 +File=config/pm/hasim/submodels/common/hasim_common.apm
   21.79 +Packagehint=hasim
   21.80 +
   21.81 +[Simple Audio Processor Core]
   21.82 +File=modules/bluespec/mit-6.375/core/audio_pipe_types.awb
   21.83 +Packagehint=mit-6.375
   21.84 +
   21.85 +[Round-robin memory arbiter]
   21.86 +File=modules/bluespec/mit-6.375/lab4/mem_arb.awb
   21.87 +Packagehint=mit-6.375
   21.88 +
   21.89 +[Processor Library]
   21.90 +File=modules/bluespec/mit-6.375/lab4/processor_library.awb
   21.91 +Packagehint=mit-6.375
   21.92 +
   21.93 +[audio pipeline with soft core]
   21.94 +File=modules/bluespec/mit-6.375/core/audio_core_pipe.awb
   21.95 +Packagehint=mit-6.375
   21.96 +
   21.97 +[Audio Processor Core]
   21.98 +File=modules/bluespec/mit-6.375/core/audio_core.awb
   21.99 +Packagehint=mit-6.375
  21.100 +
  21.101 +[audio pipeline with soft core/Requires]
  21.102 +hasim_common=Default HAsim Common Library
  21.103 +funcp_simulated_memory=VMH hybrid memory
  21.104 +core=Audio Processor Core
  21.105 +funcp_base_types=Functional Partition Base Types
  21.106 +audio_pipe_types=Simple Audio Processor Core
  21.107 +
  21.108 +[Audio Processor Core/Requires]
  21.109 +processor_library=Processor Library
  21.110 +processor=3-Stage Audio Processor
  21.111 +data_cache=Blocking Data Cache
  21.112 +instruction_cache=Blocking Instruction Cache
  21.113 +mem_arb=Round-robin memory arbiter
    22.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
    22.2 +++ b/modules/bluespec/Pygar/core/audioPipeTypes.bsv	Tue Apr 27 22:54:50 2010 -0400
    22.3 @@ -0,0 +1,50 @@
    22.4 +
    22.5 +// The MIT License
    22.6 +
    22.7 +// Copyright (c) 2009 Massachusetts Institute of Technology
    22.8 +
    22.9 +// Permission is hereby granted, free of charge, to any person obtaining a copy
   22.10 +// of this software and associated documentation files (the "Software"), to deal
   22.11 +// in the Software without restriction, including without limitation the rights
   22.12 +// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
   22.13 +// copies of the Software, and to permit persons to whom the Software is
   22.14 +// furnished to do so, subject to the following conditions:
   22.15 +
   22.16 +// The above copyright notice and this permission notice shall be included in
   22.17 +// all copies or substantial portions of the Software.
   22.18 +
   22.19 +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
   22.20 +// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
   22.21 +// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
   22.22 +// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
   22.23 +// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
   22.24 +// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
   22.25 +// THE SOFTWARE.
   22.26 +
   22.27 +// Author: Ker
   22.28 +// min Fleming kfleming@mit.edu
   22.29 +
   22.30 +import Connectable::*;
   22.31 +import GetPut::*;
   22.32 +import ClientServer::*;
   22.33 +
   22.34 +typedef Int#(16) Sample;
   22.35 +
   22.36 +typedef enum {
   22.37 +  EndOfFile = 0,
   22.38 +  Data = 1
   22.39 +} AudioProcessorControl deriving (Bits,Eq);
   22.40 +
   22.41 +
   22.42 +typedef struct { 
   22.43 +  Sample left;
   22.44 +  Sample right;
   22.45 +} StereoSample deriving (Bits,Eq);
   22.46 +
   22.47 +typedef union tagged{
   22.48 + Sample Sample;
   22.49 + void EndOfFile;
   22.50 +} AudioProcessorUnit deriving (Bits,Eq);
   22.51 +
   22.52 +
   22.53 +