RecoSim  1.0
 All Classes Files Functions Variables Enumerations
Slice.h
1 
13 #ifndef SLICE_MODULE_ALGORITHMS_FILE_H
14 #define SLICE_MODULE_ALGORITHMS_FILE_H
15 
17 
18 /*****************************************************************************/
19 /************************** BEGIN USER SPACE ********************************/
20 
21 template<int Ni, int No>
22 void Slice(User_algorithm_interface<Ni, No> &user_algo_interface) {
23  // Sw Default behavior
24  srand ((unsigned int)sc_time_stamp().to_double());
25  user_algo_interface.get_logfile() << sc_time_stamp() << "init srand" << endl;
26 
27 
28 
29  while(true) {
30 
31  /*******************************************************************************/
32  /**** MANDATORY PART (EXCEPT DISPLAY) ****/
33 
34 
35 
36 
37  /* WAIT FOR START ALGORITHM EVENT : Only for Dynamic tasks */
38  user_algo_interface.get_logfile() << sc_time_stamp() << ": " << user_algo_interface.get_name() << " Beginning of loop" << endl;
39  current_time_state = tasks_execution_time;
40  user_algo_interface.b_execution_requested();
41 
42 
43 
44  user_algo_interface.get_logfile() << sc_time_stamp() << ": " << user_algo_interface.get_name() << " Execution requested" << endl;
45 
46  /* TRACE : The algorithm is idle in order to have an accurate trace */
47  user_algo_interface.set_algorithm_idle();
48 
49  /* WAIT FOR NEXT PERIOD to begin to start algorithm execution. For non-periodic modules, function returns right away */
50  user_algo_interface.wait_until_next_period();
51 
52 
53 
54 
55 #ifdef GENERATE_LOG_FILE
56  user_algo_interface.get_logfile() << sc_time_stamp() << ": " << user_algo_interface.get_name() << " New period started" << endl;
57 #endif
58  user_algo_interface.set_algorithm_waiting();
59 
60  /**** BEGINNING OF DATA RECEPTION SEGMENT ****/
61 
62 
63 
64  user_algo_interface.b_all_data_received();
65 
66  user_algo_interface.set_algorithm_running();
67 
68  /**** END OF DATA RECEPTION SEGMENT ****/
69 
70  /**** BEGINNING OF USER ALGORITHM ****/
71 
72 
73  //for (int i=0; i<NB_SCALES_MAIN_TASK; i++)
74  //Main_lock_IN[i].notify();
75  Slice_lock_IN.post();
76 
77  //Main_lock_IN.notify();
78  // Wait for the last execution segment (after last preemption point)
79  //wait(Main_lock_OUT);
80  //Main_lock_OUT.wait();
81  //wait(Main_lock_OUT[0] & Main_lock_OUT[1] & Main_lock_OUT[2] & Main_lock_OUT[3] & Main_lock_OUT[4] & Main_lock_OUT[5] & Main_lock_OUT[6] & Main_lock_OUT[7] & Main_lock_OUT[8] & Main_lock_OUT[9]);
82  Slice_lock_OUT.wait();
83 
84  user_algo_interface.get_logfile() << sc_time_stamp() << ": " << user_algo_interface.get_name() << " MAIN TASK released" << endl;
85 
86  //wait(SC_ZERO_TIME);
87 #ifdef GENERATE_LOG_FILE
88  user_algo_interface.get_logfile() << sc_time_stamp() << ": " << user_algo_interface.get_name() << " MAIN TASK User algorithm ended" << endl;
89 #endif
90 
91 
92 
93 
94 
95 
96  /**** END OF USER ALGORITHM ****/
97 
98 
99  // Check that all data issued from previous algorithm execution has been processed and sent
100  user_algo_interface.b_all_data_sent();
101 
102  // When all data is sent, indicate that a new sequence starts now
103  // MUST BE DONE ONLY AFTER VERIFYING THAT ALL PREVIOUS DATA HAVE BEEN SENT
104  user_algo_interface.start_new_transaction_sequence();
105 
106  // Find a channel that is not transient and has updated data
107  int channel_id = 0;
108  while(user_algo_interface.is_channel_transient(channel_id) || !user_algo_interface.nb_data_received(channel_id)) channel_id++;
109 
110  // Copy data
111  int data_in_length = 0;
112  int data_out_length = 0;
113  for(int i = 0; i < No; i++) {
114  data_in_length = user_algo_interface.get_data_in_length(channel_id);
115  data_out_length = user_algo_interface.get_data_out_length(i);
116 
117  if(data_out_length <= data_in_length) {
118  memcpy(user_algo_interface.get_data_out_ptr(i), user_algo_interface.get_data_in_ptr(channel_id), data_out_length);
119  } else {
120  memcpy(user_algo_interface.get_data_out_ptr(i), user_algo_interface.get_data_in_ptr(channel_id), data_in_length);
121  for(int j = data_in_length; j < data_out_length; j+=4) user_algo_interface.get_data_out_ptr(i)[j/4] = 0;
122  }
123 
124  user_algo_interface.set_address_out(i, user_algo_interface.get_address_in(channel_id));
125  }
126 
127  // Release input sockets (we won't need their data anymore) for they are used by preceding modules again
128  user_algo_interface.release_all_input_sockets();
129 
130  // Notify RZ to continue processing
131  user_algo_interface.end_of_algorithm();
132 
133  // Send data to all sockets
134  user_algo_interface.nb_send_all_data();
135 
136 
137  // Wait for the event notifying a possible change in the user algorithm thread
138  user_algo_interface.wait_for_update_user_algorithm();
139 
140  user_algo_interface.get_logfile() << sc_time_stamp() << ": " << user_algo_interface.get_name() << " Update user algorithm event received" << endl;
141 
142  if(user_algo_interface.kill_user_algorithm()) {
143 #ifdef GENERATE_LOG_FILE
144  user_algo_interface.get_logfile() << user_algo_interface.get_name() << " User algorithm thread has to be killed!" << endl;
145 #endif
146  return;
147  }
148  }
149 
150 }
151 
152 /************************** END USER SPACE ********************************/
153 /***************************************************************************/
154 
155 #endif
virtual ofstream & get_logfile(void)=0
Get logfile.
virtual bool & kill_user_algorithm(void)=0
Get a reference to a boolean indicating whether the user algorithm should be killed or not (for insta...
virtual void start_new_transaction_sequence(int id)=0
Indicate that a new transaction sequence is beginning (i.e. sending new data) for a particular socket...
virtual int * get_data_in_ptr(int socket)=0
Get pointer to incoming data from socket 'socket'.
virtual void set_address_out(int socket, sc_dt::uint64 value)=0
Set address for outgoing transaction on socket 'socket'.
virtual bool nb_data_received(string name)=0
Check if the data from channel 'name' have been received yet. Non-blocking function.
virtual void b_all_data_received(void)=0
Check if the data from all channels have been received yet. Blocking function: if the data is not ava...
virtual int get_data_out_length(int socket) const =0
Get output socket data length.
virtual void release_all_input_sockets(void)=0
Release all input socket so that preceding modules might send some more data.
virtual void set_algorithm_waiting(void)=0
Function to call when the algorithm is waiting for data in order to have an accurate trace...
virtual int get_data_in_length(int socket) const =0
Get input socket data length.
virtual const char * get_name(void) const =0
Get task name.
virtual void b_execution_requested(void)=0
Wait until an algorithm execution has been requested/granted by the manager.
Definition: user_algorithm_interface.h:35
virtual bool is_channel_transient(string name)=0
Check if channel 'name' is transient or not.
virtual void end_of_algorithm(void)=0
Function to call at the end of algorithm.
virtual int * get_data_out_ptr(int socket)=0
Get pointer to outgoing data from socket 'socket'.
virtual void set_algorithm_running(void)=0
Function to call when the algorithm is running in order to have an accurate trace.
virtual void set_algorithm_idle(void)=0
Function to call when the algorithm is idle in order to have an accurate trace.
virtual void wait_until_next_period(void)=0
Wait until the next period is started. For non-periodic tasks, return immediately.
virtual sc_dt::uint64 get_address_in(int socket) const =0
Retrieve address from the incoming transaction on socket 'socket'.
virtual void b_all_data_sent(void)=0
Check if data has been sent on every socket. Blocking function: if data send is not finished yet...
virtual void nb_send_all_data(void)=0
Send data towards all channels. Non-blocking function.