source: soft/giet_vm/applications/router/main.c @ 710

Last change on this file since 710 was 687, checked in by alain, 9 years ago

Introduce the ps command in shell.
Adapt the router application.

File size: 5.7 KB
RevLine 
[451]1/////////////////////////////////////////////////////////////////////////////////////////////
2// File   : main.c   (for router application)
3// Date   : november 2014
4// author : Alain Greiner
5/////////////////////////////////////////////////////////////////////////////////////////////
[687]6// This multi-threaded application illustrates "task-farm" parallelism.
7// It is described as a TCG (Task and Communication Graph).
[451]8// It contains 2 + N tasks : one "producer", one "consumer" and N "router")
9// It contains 2 MWMR channels : "fifo_in" and "fifo_out".
10// - The "producer" task writes NMAX token into "fifo_in".
11// - The N "router" tasks read token from "fifo_in" and write them into "fifo_out".
12// - The "consumer" task read token from "fifo_out" and displays instrumentation results.
13// Token are indexed (by the producer) from 0 to NMAX-1.
[687]14// The router task contains a random delay emulating a variable processing time.
[451]15//
16// This application is intended to run on a multi-processors, multi-clusters architecture,
17//  with one thread per processor.
18//
19// It uses the he following hardware parameters, defined in the hard_config.h file:
20// - X_SIZE       : number of clusters in a row
21// - Y_SIZE       : number of clusters in a column
22// - NB_PROCS_MAX : number of processors per cluster
23//
24// There is two global arrays (indexed by the token index) for insrumentation:
25// - The "router_tab" array is filled concurrently by all "router" tasks.
26//   Each entry contains the processor index that routed the token.
27// - The "consumer_tab" array is filled by the "consumer" task.
28//   Each entry contain the arrival order to the consumer task.
29/////////////////////////////////////////////////////////////////////////////////////////////
[687]30// Implementation note:
31// The synchronisation variables fifo_in, fifo_out, and tty_lock are initialised by the
32// "producer" task. Other tasks are waiting on the init_ok variable until completion.
33/////////////////////////////////////////////////////////////////////////////////////////////
[451]34
[687]35
[191]36#include "stdio.h"
37#include "mwmr_channel.h"
38#include "mapping_info.h"
[295]39#include "hard_config.h"
[191]40
[687]41#define VERBOSE  1
42#define NMAX     50           // total number of token
43#define DEPTH    20       // MWMR channels depth
[345]44
[687]45// MWMR channels and associated buffers
[191]46
[451]47__attribute__((section (".data_in")))  mwmr_channel_t fifo_in;
[457]48__attribute__((section (".data_in")))  unsigned int   buf_in[DEPTH];
49
[451]50__attribute__((section (".data_out"))) mwmr_channel_t fifo_out;
[457]51__attribute__((section (".data_out"))) unsigned int   buf_out[DEPTH];
[451]52 
[687]53// Instrumentation Counters
[451]54
55__attribute__((section (".data_out")))  unsigned int consumer_tab[NMAX];
56__attribute__((section (".data_out")))  unsigned int router_tab[NMAX];
57
[687]58// synchronisation variables
[451]59
[687]60unsigned int  init_ok = 0;
[451]61
[191]62/////////////////////////////////////////////
63__attribute__ ((constructor)) void producer()
64{
65
66    unsigned int        n;
67    unsigned int        buf;
68
[432]69    // get processor identifiers
70    unsigned int    x;
71    unsigned int    y;
[687]72    unsigned int    p;
73    giet_proc_xyp( &x , &y , &p );
[191]74
[687]75    // allocates a private TTY
76    giet_tty_alloc( 0 );
[191]77
[687]78    // initialises TTY lock
79    // lock_init( &tty_lock );
80
[451]81    // initializes fifo_in
[687]82    mwmr_init( &fifo_in  , buf_in  , 1 , DEPTH );
[295]83
[687]84    // initializes fifo_out
85    mwmr_init( &fifo_out , buf_out , 1 , DEPTH );
86
87    init_ok = 1;
88
89    giet_tty_printf("\n[Producer] completes initialisation on P[%d,%d,%d] at cycle %d\n", 
90                    x , y , p , giet_proctime() );
91
92    // main loop
[191]93    for(n = 0 ; n < NMAX ; n++) 
94    { 
95        buf = n;
[451]96        mwmr_write( &fifo_in , &buf , 1 );
[687]97
98        if ( VERBOSE ) 
99        giet_tty_printf(" - token %d sent at cycle %d\n", n , giet_proctime() );
[191]100    }
101
[295]102    giet_exit( "Producer task completed");
[191]103
104} // end producer()
105
106/////////////////////////////////////////////
107__attribute__ ((constructor)) void consumer()
108{
109    unsigned int        n;
110    unsigned int        buf;
111
[432]112    // get processor identifiers
113    unsigned int    x;
114    unsigned int    y;
[687]115    unsigned int    p;
116    giet_proc_xyp( &x, &y, &p );
[191]117
[687]118    // allocates a private TTY
119    giet_tty_alloc( 0 );
[191]120
[687]121    while ( init_ok == 0 ) asm volatile( "nop" );
[295]122
[687]123    giet_tty_printf("\n[Consumer] starts execution on P[%d,%d,%d] at cycle %d\n", 
124                    x, y, p, giet_proctime() );
125
126    // main loop
[451]127    for( n = 0 ; n < NMAX ; n++ ) 
[191]128    { 
[451]129        mwmr_read( &fifo_out , &buf , 1 );
130        consumer_tab[n] = buf;
[687]131
132        if ( VERBOSE ) 
133        giet_tty_printf(" - token %d received at cycle %d\n", buf , giet_proctime() );
[191]134    }
135
[451]136    // instrumentation display
[687]137    giet_tty_printf("\n[Consumer] displays instrumentation results\n");
[451]138    for( n = 0 ; n < NMAX ; n++ )
139    {
[687]140        giet_tty_printf(" - arrival = %d / value = %d / router = %x\n",
141                        n , consumer_tab[n] , router_tab[n] );
[451]142    }
143
[687]144    giet_exit( "Consumer completed" );
[191]145
146} // end consumer()
147
148///////////////////////////////////////////
149__attribute__ ((constructor)) void router()
150{
[264]151    unsigned int        buf;
[295]152    unsigned int        n;
[191]153    unsigned int        tempo;
154
[432]155    // get processor identifiers
156    unsigned int    x;
157    unsigned int    y;
[687]158    unsigned int    p;
159    giet_proc_xyp( &x, &y, &p );
[191]160
[687]161    // allocates a private TTY
162    giet_tty_alloc( 0 );
[191]163
[687]164    giet_tty_printf("\n[Router] starts execution on P[%d,%d,%d] at cycle %d\n", 
165                    x, y, p, giet_proctime() );
[191]166
[687]167    while ( init_ok == 0 ) asm volatile( "nop" );
168
[191]169    // main loop
170    while(1)
171    {
[451]172        mwmr_read( &fifo_in , &buf , 1 );
173
174        tempo = giet_rand();
175        for ( n = 0 ; n < tempo ; n++ ) asm volatile ( "nop" );
176
[687]177        router_tab[buf] = (x<<(Y_WIDTH + P_WIDTH)) + (y<<P_WIDTH) + p;
[451]178
179        mwmr_write( &fifo_out , &buf , 1 );
[687]180
181        if ( VERBOSE ) 
182        giet_tty_printf(" - token %d routed at cycle %d\n", buf , giet_proctime() );
[191]183    }
[451]184} // end router
Note: See TracBrowser for help on using the repository browser.