if4_tools.c 7.66 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
/*******************************************************************************
    OpenAirInterface
    Copyright(c) 1999 - 2014 Eurecom

    OpenAirInterface is free software: you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation, either version 3 of the License, or
    (at your option) any later version.


    OpenAirInterface is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with OpenAirInterface.The full GNU General Public License is
   included in this distribution in the file called "COPYING". If not,
   see <http://www.gnu.org/licenses/>.

  Contact Information
  OpenAirInterface Admin: openair_admin@eurecom.fr
  OpenAirInterface Tech : openair_tech@eurecom.fr
  OpenAirInterface Dev  : openair4g-devel@lists.eurecom.fr

  Address      : Eurecom, Campus SophiaTech, 450 Route des Chappes, CS 50193 - 06904 Biot Sophia Antipolis cedex, FRANCE

 *******************************************************************************/

/*! \file PHY/LTE_TRANSPORT/if4_tools.c
* \brief 
32
* \author Fredrik Skretteberg, Tobias Schuster, Mauricio Gunther, S. Sandeep Kumar, Raymond Knopp
33 34 35
* \date 2016
* \version 0.1
* \company Eurecom
Sandeep Kumar's avatar
Sandeep Kumar committed
36
* \email: knopp@eurecom.fr 
37 38 39 40
* \note
* \warning
*/

Sandeep Kumar's avatar
Sandeep Kumar committed
41 42 43 44
#ifndef USER_MODE
#include "if4_tools.h"
#include <stdint.h>
#else
45 46 47
#include <stdint.h>
#include "PHY/defs.h"

48
#include "PHY/LTE_TRANSPORT/if4_tools.h"
49
#include "PHY/TOOLS/ALAW/alaw_lut.h"
Sandeep Kumar's avatar
Sandeep Kumar committed
50
#endif
51

Sandeep Kumar's avatar
Sandeep Kumar committed
52
// Get device information
53 54
void send_IF4(PHY_VARS_eNB *eNB, eNB_rxtx_proc_t *proc) {
	LTE_DL_FRAME_PARMS *fp = &eNB->frame_parms;
55 56 57 58 59
	int32_t **txdataF = eNB->common_vars.txdataF[0];
  
	uint16_t symbol_id, element_id;
  uint16_t db_fulllength = 12*fp->N_RB_DL;
  uint16_t db_halflength = db_fulllength>>1;
60
  int slotoffsetF = (proc->subframe_tx)*(fp->ofdm_symbol_size)*((fp->Ncp==1) ? 12 : 14) + 1;
61 62 63
  int blockoffsetF = slotoffsetF + fp->ofdm_symbol_size - db_halflength; 
  
  int16_t *data_block = (int16_t*)malloc(db_fulllength*sizeof(int16_t));  
64 65 66 67 68 69 70 71

  // Caller: RCC - DL *** handle RRU case - UL and PRACH *** 
  if (eNB->node_function == NGFI_RCC_IF4) {
    IF4_dl_packet_t *dl_packet = (IF4_dl_packet_t*)malloc(sizeof_IF4_dl_packet_t);
    gen_IF4_dl_packet(dl_packet, proc);
		
    dl_packet->data_block = data_block;

72
    for (symbol_id=0; symbol_id<fp->symbols_per_tti; symbol_id++) {
73

74 75
      // Do compression of the two parts and generate data blocks			
      for (element_id=0; element_id<db_halflength; element_id++) {
76 77
        data_block[element_id]  = lin2alaw[ (txdataF[0][blockoffsetF+element_id] & 0xffff) + 32768 ];          
        data_block[element_id] |= lin2alaw[ (txdataF[0][blockoffsetF+element_id]>>16) + 32768 ]<<8;  
78
        
79 80
        data_block[element_id+db_halflength]  = lin2alaw[ (txdataF[0][slotoffsetF+element_id] & 0xffff) + 32768 ];     
        data_block[element_id+db_halflength] |= lin2alaw[ (txdataF[0][slotoffsetF+element_id]>>16) + 32768 ]<<8;  
81 82
      }
				 		
83
      // Update information in generated packet
84
      dl_packet->frame_status.sym_num = symbol_id; 
85
			
Sandeep Kumar's avatar
Sandeep Kumar committed
86 87 88 89 90 91 92 93
      // Write the packet(s) to the fronthaul
      //if ((bytes_sent = dev->eth_dev.trx_write_func (&dev->eth_dev,
			//			                                         timestamp_rx,
			//			                                         rx_eNB,
			//			                                         spp_eth,
			//			                                         dev->eth_dev.openair0_cfg->rx_num_channels,
      //                                               0)) < 0) {
      //  perror("RCC : ETHERNET write");
94 95 96 97
      //}
      
      slotoffsetF  += fp->ofdm_symbol_size;
      blockoffsetF += fp->ofdm_symbol_size;    
98 99 100 101 102 103 104
    }
  }else {
    IF4_ul_packet_t *ul_packet = (IF4_ul_packet_t*)malloc(sizeof_IF4_ul_packet_t);
    gen_IF4_ul_packet(ul_packet, proc);
		
    ul_packet->data_block = data_block;

105
    for (symbol_id=0; symbol_id<fp->symbols_per_tti; symbol_id++) {			
106

107 108
      // Do compression of the two parts and generate data blocks			
      for (element_id=0; element_id<db_halflength; element_id++) {
109 110
        data_block[element_id]  = lin2alaw[ (txdataF[0][blockoffsetF+element_id] & 0xffff) + 32768 ];          
        data_block[element_id] |= lin2alaw[ (txdataF[0][blockoffsetF+element_id]>>16) + 32768 ]<<8;  
111
        
112 113
        data_block[element_id+db_halflength]  = lin2alaw[ (txdataF[0][slotoffsetF+element_id] & 0xffff) + 32768 ];     
        data_block[element_id+db_halflength] |= lin2alaw[ (txdataF[0][slotoffsetF+element_id]>>16) + 32768 ]<<8;  
114 115
      }
       			
116
      // Update information in generated packet
117
      ul_packet->frame_status.sym_num = symbol_id; 
118 119 120
			
      // Write the packet(s) to the fronthaul 

121 122
      slotoffsetF  += fp->ofdm_symbol_size;
      blockoffsetF += fp->ofdm_symbol_size;    
123 124
    }		
	}
Sandeep Kumar's avatar
Sandeep Kumar committed
125
  		    
126
}
127

128
void recv_IF4(PHY_VARS_eNB *eNB, eNB_rxtx_proc_t *proc, uint16_t *packet_type, uint32_t *symbol_number) {
Sandeep Kumar's avatar
Sandeep Kumar committed
129

Sandeep Kumar's avatar
Sandeep Kumar committed
130 131
  // Caller: RRU - DL *** handle RCC case - UL and PRACH *** 
  if (eNB->node_function == NGFI_RRU_IF4) {
Sandeep Kumar's avatar
Sandeep Kumar committed
132
  
133
//    for(i=0; i<fp->symbols_per_tti; i++) {  
Sandeep Kumar's avatar
Sandeep Kumar committed
134
      // Read packet(s) from the fronthaul    
135 136 137 138 139 140 141 142
//      if (dev->eth_dev.trx_read_func (&dev->eth_dev,
//                                      timestamp_rx,
//                                    rx_eNB,
//                                      spp_eth,
//                                      dev->eth_dev.openair0_cfg->rx_num_channels
//                                      ) < 0) {
//        perror("RRU : ETHERNET read");
//      }
Sandeep Kumar's avatar
Sandeep Kumar committed
143 144 145 146 147
      
      // Apply reverse processing - decompression
      // txAlawtolinear( Datablock )
      
      // Generate and return the OFDM symbols (txdataF)
148 149
      //txDataF 
    //}
Sandeep Kumar's avatar
Sandeep Kumar committed
150 151 152
  }else {
    
  }  
153 154
}

155
void gen_IF4_dl_packet(IF4_dl_packet_t *dl_packet, eNB_rxtx_proc_t *proc) {      
Sandeep Kumar's avatar
Sandeep Kumar committed
156
  // Set Type and Sub-Type
157
  dl_packet->type = IF4_PACKET_TYPE; 
Sandeep Kumar's avatar
Sandeep Kumar committed
158
  dl_packet->sub_type = IF4_PDLFFT;
Sandeep Kumar's avatar
Sandeep Kumar committed
159 160

  // Leave reserved as it is 
161
  dl_packet->rsvd = 0;
Sandeep Kumar's avatar
Sandeep Kumar committed
162 163
  
  // Set frame status
164 165 166 167 168 169 170
  dl_packet->frame_status.ant_num = 0;
  dl_packet->frame_status.ant_start = 0;
  dl_packet->frame_status.rf_num = proc->frame_tx;
  dl_packet->frame_status.sf_num = proc->subframe_tx;
  dl_packet->frame_status.sym_num = 0;
  dl_packet->frame_status.rsvd = 0;

Sandeep Kumar's avatar
Sandeep Kumar committed
171
  // Set frame check sequence
172
  dl_packet->fcs = 0;
173 174
}

175
void gen_IF4_ul_packet(IF4_ul_packet_t *ul_packet, eNB_rxtx_proc_t *proc) {  
Sandeep Kumar's avatar
Sandeep Kumar committed
176
  // Set Type and Sub-Type
177
  ul_packet->type = IF4_PACKET_TYPE; 
Sandeep Kumar's avatar
Sandeep Kumar committed
178
  ul_packet->sub_type = IF4_PULFFT;
Sandeep Kumar's avatar
Sandeep Kumar committed
179 180

  // Leave reserved as it is 
181
  ul_packet->rsvd = 0;
Sandeep Kumar's avatar
Sandeep Kumar committed
182 183
  
  // Set frame status
184 185 186 187 188 189 190 191 192 193
  ul_packet->frame_status.ant_num = 0;
  ul_packet->frame_status.ant_start = 0;
  ul_packet->frame_status.rf_num = proc->frame_rx;
  ul_packet->frame_status.sf_num = proc->subframe_rx;
  ul_packet->frame_status.sym_num = 0;
  ul_packet->frame_status.rsvd = 0;
    
  // Set antenna specific gain *** set other antenna gain ***
  ul_packet->gain0.exponent = 0;
  ul_packet->gain0.rsvd = 0;
Sandeep Kumar's avatar
Sandeep Kumar committed
194 195
    
  // Set frame check sequence
196
  ul_packet->fcs = 0;
197 198
}

199
void gen_IF4_prach_packet(IF4_prach_packet_t *prach_packet, eNB_rxtx_proc_t *proc) {
Sandeep Kumar's avatar
Sandeep Kumar committed
200
  // Set Type and Sub-Type
201
  prach_packet->type = IF4_PACKET_TYPE; 
Sandeep Kumar's avatar
Sandeep Kumar committed
202
  prach_packet->sub_type = IF4_PRACH;
Sandeep Kumar's avatar
Sandeep Kumar committed
203 204

  // Leave reserved as it is 
205
  prach_packet->rsvd = 0;
Sandeep Kumar's avatar
Sandeep Kumar committed
206 207
  
  // Set LTE Prach configuration
208 209 210 211 212 213
  prach_packet->prach_conf.rsvd = 0;
  prach_packet->prach_conf.ant = 0;
  prach_packet->prach_conf.rf_num = proc->frame_rx;
  prach_packet->prach_conf.sf_num = proc->subframe_rx;
  prach_packet->prach_conf.exponent = 0;  
        
Sandeep Kumar's avatar
Sandeep Kumar committed
214
  // Set frame check sequence
215
  prach_packet->fcs = 0;
216
}