Replace magic numbers with macro constants.

Adjust comments to refer to these macros.
master
faluco 5 years ago committed by Andre Puschmann
parent ac3b7ed54c
commit cf5b321fb5

@ -189,12 +189,18 @@ typedef enum SRSLTE_API
SRSLTE_TDD = 1 SRSLTE_TDD = 1
} srslte_frame_type_t; } srslte_frame_type_t;
/// Maximum number of TDD special subframe configurations.
#define SRSLTE_MAX_TDD_SS_CONFIGS (10u)
/// Maximum number of TDD uplink-downlink subframe configurations.
#define SRSLTE_MAX_TDD_SF_CONFIGS (7u)
/// Configuration fields for operating in TDD mode. /// Configuration fields for operating in TDD mode.
typedef struct SRSLTE_API { typedef struct SRSLTE_API {
/// Uplink-downlink configuration, valid range is [0,6]. /// Uplink-downlink configuration, valid range is [0,SRSLTE_MAX_TDD_SF_CONFIGS[.
/// TS 36.211 v8.9.0 Table 4.2-2. /// TS 36.211 v8.9.0 Table 4.2-2.
uint32_t sf_config; uint32_t sf_config;
/// Special subframe symbol length configuration, valid range is [0,9]. /// Special subframe symbol length configuration, valid range is [0,SRSLTE_MAX_TDD_SS_CONFIGS[.
/// TS 36.211 v13.13.0 Table 4.2-1. /// TS 36.211 v13.13.0 Table 4.2-1.
uint32_t ss_config; uint32_t ss_config;
/// Set to true when the fields have been configured, otherwise false. /// Set to true when the fields have been configured, otherwise false.
@ -374,7 +380,7 @@ SRSLTE_API bool srslte_nofprb_isvalid(uint32_t nof_prb);
* Check TS 36.211 v8.9.0 Table 4.2-2. * Check TS 36.211 v8.9.0 Table 4.2-2.
* *
* @param tdd_config TDD configuration. * @param tdd_config TDD configuration.
* @param sf_idx Subframe number, must be in range [0,9]. * @param sf_idx Subframe number, must be in range [0,SRSLTE_NOF_SF_X_FRAME[.
* @return Returns the subframe type. * @return Returns the subframe type.
*/ */
SRSLTE_API srslte_tdd_sf_t srslte_sfidx_tdd_type(srslte_tdd_config_t tdd_config, uint32_t sf_idx); SRSLTE_API srslte_tdd_sf_t srslte_sfidx_tdd_type(srslte_tdd_config_t tdd_config, uint32_t sf_idx);

@ -95,7 +95,8 @@ void srslte_cell_fprint(FILE* stream, srslte_cell_t* cell, uint32_t sfn)
// TDD uplink-downlink configurations. // TDD uplink-downlink configurations.
// TS 36.211 v8.9.0 Table 4.2-2. // TS 36.211 v8.9.0 Table 4.2-2.
static const srslte_tdd_sf_t tdd_sf[7][10] = {{D, S, U, U, U, D, S, U, U, U}, static const srslte_tdd_sf_t tdd_sf[SRSLTE_MAX_TDD_SF_CONFIGS][SRSLTE_NOF_SF_X_FRAME] =
{{D, S, U, U, U, D, S, U, U, U},
{D, S, U, U, D, D, S, U, U, D}, {D, S, U, U, D, D, S, U, U, D},
{D, S, U, D, D, D, S, U, D, D}, {D, S, U, D, D, D, S, U, D, D},
{D, S, U, U, U, D, D, D, D, D}, {D, S, U, U, U, D, D, D, D, D},
@ -109,7 +110,7 @@ static const srslte_tdd_sf_t tdd_sf[7][10] = {{D, S, U, U, U, D, S, U, U, U},
srslte_tdd_sf_t srslte_sfidx_tdd_type(srslte_tdd_config_t tdd_config, uint32_t sf_idx) srslte_tdd_sf_t srslte_sfidx_tdd_type(srslte_tdd_config_t tdd_config, uint32_t sf_idx)
{ {
if (tdd_config.sf_config < 7 && sf_idx < 10 && tdd_config.configured) { if (tdd_config.sf_config < SRSLTE_MAX_TDD_SF_CONFIGS && sf_idx < SRSLTE_NOF_SF_X_FRAME && tdd_config.configured) {
return tdd_sf[tdd_config.sf_config][sf_idx]; return tdd_sf[tdd_config.sf_config][sf_idx];
} }
@ -134,9 +135,10 @@ uint32_t srslte_sfidx_tdd_nof_dw_slot(srslte_tdd_config_t tdd_config, uint32_t s
} }
} }
// Length of DwPTS / GP / UpPTS symbols. // Number of DwPTS / GP / UpPTS symbols per subframe.
// TS 36.211 v13.13.0 Table 4.2-2. // TS 36.211 v13.13.0 Table 4.2-2.
static const uint32_t tdd_nof_sf_symbols[10][3] = {{3, 10, 1}, static const uint32_t tdd_nof_sf_symbols[SRSLTE_MAX_TDD_SS_CONFIGS][3] =
{{3, 10, 1},
{9, 4, 1}, {9, 4, 1},
{10, 3, 1}, {10, 3, 1},
{11, 2, 1}, {11, 2, 1},
@ -149,7 +151,7 @@ static const uint32_t tdd_nof_sf_symbols[10][3] = {{3, 10, 1},
uint32_t srslte_sfidx_tdd_nof_dw(srslte_tdd_config_t tdd_config) uint32_t srslte_sfidx_tdd_nof_dw(srslte_tdd_config_t tdd_config)
{ {
if (tdd_config.ss_config < 10) { if (tdd_config.ss_config < SRSLTE_MAX_TDD_SS_CONFIGS) {
return tdd_nof_sf_symbols[tdd_config.ss_config][0]; return tdd_nof_sf_symbols[tdd_config.ss_config][0];
} }
@ -158,7 +160,7 @@ uint32_t srslte_sfidx_tdd_nof_dw(srslte_tdd_config_t tdd_config)
uint32_t srslte_sfidx_tdd_nof_gp(srslte_tdd_config_t tdd_config) uint32_t srslte_sfidx_tdd_nof_gp(srslte_tdd_config_t tdd_config)
{ {
if (tdd_config.ss_config < 10) { if (tdd_config.ss_config < SRSLTE_MAX_TDD_SS_CONFIGS) {
return tdd_nof_sf_symbols[tdd_config.ss_config][1]; return tdd_nof_sf_symbols[tdd_config.ss_config][1];
} }
@ -167,7 +169,7 @@ uint32_t srslte_sfidx_tdd_nof_gp(srslte_tdd_config_t tdd_config)
uint32_t srslte_sfidx_tdd_nof_up(srslte_tdd_config_t tdd_config) uint32_t srslte_sfidx_tdd_nof_up(srslte_tdd_config_t tdd_config)
{ {
if (tdd_config.ss_config < 10) { if (tdd_config.ss_config < SRSLTE_MAX_TDD_SS_CONFIGS) {
return tdd_nof_sf_symbols[tdd_config.ss_config][2]; return tdd_nof_sf_symbols[tdd_config.ss_config][2];
} }

Loading…
Cancel
Save