nr_sss.c 2.85 KB
Newer Older
Guy De Souza's avatar
Guy De Souza committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
/*
 * Licensed to the OpenAirInterface (OAI) Software Alliance under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The OpenAirInterface Software Alliance licenses this file to You under
 * the OAI Public License, Version 1.1  (the "License"); you may not use this file
 * except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.openairinterface.org/?page_id=698
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *-------------------------------------------------------------------------------
 * For more information about the OpenAirInterface (OAI) Software Alliance:
 *      contact@openairinterface.org
 */

22
#include "PHY/NR_TRANSPORT/nr_transport_proto.h"
Guy De Souza's avatar
Guy De Souza committed
23

Raymond Knopp's avatar
Raymond Knopp committed
24
//#define NR_SSS_DEBUG
Guy De Souza's avatar
Guy De Souza committed
25 26

int nr_generate_sss(  int16_t *d_sss,
27
                      int32_t *txdataF,
Guy De Souza's avatar
Guy De Souza committed
28
                      int16_t amp,
29
                      uint8_t ssb_start_symbol,
30
                      nfapi_nr_config_request_scf_t* config,
Guy De Souza's avatar
Guy De Souza committed
31 32
                      NR_DL_FRAME_PARMS *frame_parms)
{
33
  int i,k,l;
Guy De Souza's avatar
Guy De Souza committed
34 35
  int m0, m1;
  int Nid, Nid1, Nid2;
36
  //int16_t a;
Guy De Souza's avatar
Guy De Souza committed
37 38 39 40
  int16_t x0[NR_SSS_LENGTH], x1[NR_SSS_LENGTH];
  const int x0_initial[7] = { 1, 0, 0, 0, 0, 0, 0 };
  const int x1_initial[7] = { 1, 0, 0, 0, 0, 0, 0 };

41
  /// Sequence generation
42
  Nid = config->cell_config.phy_cell_id.value;
Guy De Souza's avatar
Guy De Souza committed
43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59
  Nid2 = Nid % 3;
  Nid1 = (Nid - Nid2)/3;

  for ( i=0 ; i < 7 ; i++) {
    x0[i] = x0_initial[i];
    x1[i] = x1_initial[i];
  }

  for ( i=0 ; i < NR_SSS_LENGTH - 7 ; i++) {
    x0[i+7] = (x0[i + 4] + x0[i]) % 2;
    x1[i+7] = (x1[i + 1] + x1[i]) % 2;
  }

  m0 = 15*(Nid1/112) + (5*Nid2);
  m1 = Nid1 % 112;

  for (i = 0; i < NR_SSS_LENGTH ; i++) {
Guy De Souza's avatar
Guy De Souza committed
60
    d_sss[i] = (1 - 2*x0[(i + m0) % NR_SSS_LENGTH] ) * (1 - 2*x1[(i + m1) % NR_SSS_LENGTH] ) * 23170;
Guy De Souza's avatar
Guy De Souza committed
61 62
  }

Guy De Souza's avatar
Guy De Souza committed
63
#ifdef NR_SSS_DEBUG
Guy De Souza's avatar
Guy De Souza committed
64
  write_output("d_sss.m", "d_sss", (void*)d_sss, NR_SSS_LENGTH, 1, 1);
Guy De Souza's avatar
Guy De Souza committed
65 66
#endif

67
  /// Resource mapping
Guy De Souza's avatar
Guy De Souza committed
68

69
    // SSS occupies a predefined position (subcarriers 56-182, symbol 2) within the SSB block starting from
Guy De Souza's avatar
Guy De Souza committed
70
    k = frame_parms->first_carrier_offset + frame_parms->ssb_start_subcarrier + 56; //and
71
    l = ssb_start_symbol + 2;
Guy De Souza's avatar
Guy De Souza committed
72

73
    for (int m = 0; m < NR_SSS_LENGTH; m++) {
74
      ((int16_t*)txdataF)[2*(l*frame_parms->ofdm_symbol_size + k)] = (amp * d_sss[m]) >> 15;
75
      k++;
Guy De Souza's avatar
Guy De Souza committed
76

77
      if (k >= frame_parms->ofdm_symbol_size)
Guy De Souza's avatar
Guy De Souza committed
78 79
        k-=frame_parms->ofdm_symbol_size;
    }
Guy De Souza's avatar
Guy De Souza committed
80
#ifdef NR_SSS_DEBUG
81
  //  write_output("sss_0.m", "sss_0", (void*)txdataF[0][l*frame_parms->ofdm_symbol_size], frame_parms->ofdm_symbol_size, 1, 1);
Guy De Souza's avatar
Guy De Souza committed
82
#endif
Guy De Souza's avatar
Guy De Souza committed
83

84
  return 0;
Guy De Souza's avatar
Guy De Souza committed
85
}