Commit b6c164d5 authored by ghaddab's avatar ghaddab

git-svn-id: http://svn.eurecom.fr/openair4G/trunk@5118 818b1a75-f10b-46b9-bf7c-635c3b92a50f
parent e7e68757
...@@ -33,7 +33,7 @@ static bool any_bad_argument(const octave_value_list &args) ...@@ -33,7 +33,7 @@ static bool any_bad_argument(const octave_value_list &args)
if ((!v.is_real_scalar()) || (v.scalar_value() < -2) || (floor(v.scalar_value()) != v.scalar_value()) || (v.scalar_value() >= MAX_CARDS)) if ((!v.is_real_scalar()) || (v.scalar_value() < -2) || (floor(v.scalar_value()) != v.scalar_value()) || (v.scalar_value() >= MAX_CARDS))
{ {
error(FCNNAME); error(FCNNAME);
error("card must be 0-3 for a specific card, or -1 to get frame from all cards.\nSet framing.sync_mode =SYNCMODE_MASTER for one card and =SYNCMODE_SLAVE to obtain synchronized frames.\n"); error("card must be 0-19 for a specific card, or -1 to get frame from all cards.\nSet framing.sync_mode =SYNCMODE_MASTER for one card and =SYNCMODE_SLAVE to obtain synchronized frames.\n");
return true; return true;
} }
return false; return false;
...@@ -82,10 +82,10 @@ DEFUN_DLD (oarf_get_frame, args, nargout,"Get frame") ...@@ -82,10 +82,10 @@ DEFUN_DLD (oarf_get_frame, args, nargout,"Get frame")
int card = args(0).int_value(); int card = args(0).int_value();
octave_value returnvalue; octave_value returnvalue;
int i,aa; int i,aa,j;
short *rx_sig[MAX_CARDS * MAX_ANTENNAS]; short *rx_sig[MAX_CARDS * MAX_ANTENNAS];
int ret; int ret;
int frame_length_samples=0; int frame_length_samples[MAX_CARDS];
ret = openair0_open(); ret = openair0_open();
if ( ret != 0 ) if ( ret != 0 )
...@@ -106,8 +106,10 @@ DEFUN_DLD (oarf_get_frame, args, nargout,"Get frame") ...@@ -106,8 +106,10 @@ DEFUN_DLD (oarf_get_frame, args, nargout,"Get frame")
card = -1; card = -1;
} }
if (card <-1 || card >= openair0_num_detected_cards) if (card <-1 || card >= openair0_num_detected_cards) {
error("card number must be between 0 and %d. Or -1 for all cards.", openair0_num_detected_cards-1); error("card number must be between 0 and %d. Or -1 for all cards.", openair0_num_detected_cards-1);
return octave_value(-4);
}
if (card == -1) { if (card == -1) {
numant = openair0_num_detected_cards * openair0_num_antennas[0]; numant = openair0_num_detected_cards * openair0_num_antennas[0];
...@@ -132,19 +134,21 @@ DEFUN_DLD (oarf_get_frame, args, nargout,"Get frame") ...@@ -132,19 +134,21 @@ DEFUN_DLD (oarf_get_frame, args, nargout,"Get frame")
printf("\n"); printf("\n");
} }
if (openair0_exmimo_pci[0].exmimo_config_ptr->framing.resampling_factor[0] == 2) for (i=0; i<openair0_num_detected_cards; i++)
frame_length_samples = FRAME_LENGTH_COMPLEX_SAMPLES; {
else if (openair0_exmimo_pci[0].exmimo_config_ptr->framing.resampling_factor[0] == 1) if (openair0_exmimo_pci[i].exmimo_config_ptr->framing.resampling_factor[0] == 2)
frame_length_samples = FRAME_LENGTH_COMPLEX_SAMPLES*2; frame_length_samples[i] = FRAME_LENGTH_COMPLEX_SAMPLES;
else if (openair0_exmimo_pci[0].exmimo_config_ptr->framing.resampling_factor[0] == 0) else if (openair0_exmimo_pci[i].exmimo_config_ptr->framing.resampling_factor[0] == 1)
frame_length_samples = FRAME_LENGTH_COMPLEX_SAMPLES*4; frame_length_samples[i] = FRAME_LENGTH_COMPLEX_SAMPLES*2;
else if (openair0_exmimo_pci[i].exmimo_config_ptr->framing.resampling_factor[0] == 0)
frame_length_samples[i] = FRAME_LENGTH_COMPLEX_SAMPLES*4;
else else
frame_length_samples = FRAME_LENGTH_COMPLEX_SAMPLES; frame_length_samples[i] = FRAME_LENGTH_COMPLEX_SAMPLES;
}
printf("Info : Only resampling_factor of channel 0 is taken into account for copying received frame for all the other chains\n"); printf("Info : Only resampling_factor of channel 0 is taken into account for copying received frame for all the other chains\n");
ComplexMatrix dx (frame_length_samples, numant);
ComplexMatrix dx (FRAME_LENGTH_COMPLEX_SAMPLES*4, numant*openair0_num_detected_cards);
/* /*
// set the tx buffer to 0x00010001 to put switch in rx mode // set the tx buffer to 0x00010001 to put switch in rx mode
for (aa=0; aa<numant; aa++) for (aa=0; aa<numant; aa++)
...@@ -155,24 +159,28 @@ DEFUN_DLD (oarf_get_frame, args, nargout,"Get frame") ...@@ -155,24 +159,28 @@ DEFUN_DLD (oarf_get_frame, args, nargout,"Get frame")
printf("Warning: tdd_config is not set to TXRXSWITCH_TESTRX! You better know what you are doing! :)\n"); printf("Warning: tdd_config is not set to TXRXSWITCH_TESTRX! You better know what you are doing! :)\n");
// assign userspace pointers // assign userspace pointers
for (j=0; j<openair0_num_detected_cards;j++)
{
for (i=0; i<numant; i++) for (i=0; i<numant; i++)
{ {
if ( numant == openair0_num_antennas[card] ) //if ( numant == openair0_num_antennas[j] )
rx_sig[i] = (short*) openair0_exmimo_pci[ card ].adc_head[ i ]; rx_sig[i+(j*MAX_ANTENNAS)] = (short*) openair0_exmimo_pci[ j ].adc_head[ i ];
else //else
rx_sig[i] = (short*) openair0_exmimo_pci[ i / (int)openair0_num_antennas[0] ].adc_head[i % openair0_num_antennas[0]]; // rx_sig[i+(j*MAX_ANTENNAS)] = (short*) openair0_exmimo_pci[ i / (int)openair0_num_antennas[0] ].adc_head[i % openair0_num_antennas[0]];
//printf("adc_head[%i] = %p ", i, rx_sig[i]); // printf("Card %i adc_head[%i] = %p \n",j, i, rx_sig[i+(j*MAX_ANTENNAS)]);
}
} }
printf("frame length samples : %d\n",frame_length_samples);
// msg("Getting buffer...\n"); // msg("Getting buffer...\n");
if ( no_getframe_ioctl == 0) if ( no_getframe_ioctl == 0)
openair0_get_frame(card); openair0_get_frame(card);
for (i=0; i<frame_length_samples; i++) for (j=0; j<openair0_num_detected_cards;j++)
for (i=0; i<frame_length_samples[j]; i++)
for (aa=0; aa<numant; aa++) for (aa=0; aa<numant; aa++)
dx(i, aa) = Complex( rx_sig[aa][i*2], rx_sig[aa][i*2+1] ); dx(i, aa+j*MAX_ANTENNAS) = Complex( rx_sig[aa+j*MAX_ANTENNAS][i*2], rx_sig[aa+j*MAX_ANTENNAS][i*2+1] );
openair0_close(); openair0_close();
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment