srsLTE/lib/include/srsran/phy/fec/turbo/rm_turbo.h

81 lines
2.8 KiB
C
Raw Normal View History

/**
*
* \section COPYRIGHT
*
2021-03-19 03:45:56 -07:00
* Copyright 2013-2021 Software Radio Systems Limited
2014-01-28 03:41:17 -08:00
*
* By using this file, you agree to the terms and conditions set
* forth in the LICENSE file which can be found at the top level of
* the distribution.
*
2014-01-28 03:41:17 -08:00
*/
/**********************************************************************************************
* File: rm_turbo.h
*
* Description: Rate matching for turbo coded transport channels.
*
* Reference: 3GPP TS 36.212 version 10.0.0 Release 10 Sec. 5.1.4.1
*********************************************************************************************/
2021-03-19 03:45:56 -07:00
#ifndef SRSRAN_RM_TURBO_H
#define SRSRAN_RM_TURBO_H
2014-01-28 03:41:17 -08:00
2021-03-19 03:45:56 -07:00
#include "srsran/config.h"
#include "srsran/phy/fec/turbo/turbodecoder.h"
2021-03-19 03:45:56 -07:00
#ifndef SRSRAN_RX_NULL
#define SRSRAN_RX_NULL 10000
#endif
2021-03-19 03:45:56 -07:00
#ifndef SRSRAN_TX_NULL
#define SRSRAN_TX_NULL 100
#endif
2021-03-19 03:45:56 -07:00
#include "srsran/config.h"
2014-01-28 03:41:17 -08:00
2021-03-19 03:45:56 -07:00
SRSRAN_API int srsran_rm_turbo_tx(uint8_t* w_buff,
uint32_t buff_len,
uint8_t* input,
uint32_t in_len,
uint8_t* output,
uint32_t out_len,
2015-03-18 08:05:38 -07:00
uint32_t rv_idx);
2021-03-19 03:45:56 -07:00
SRSRAN_API void srsran_rm_turbo_gentables();
2015-09-16 11:10:54 -07:00
2021-03-19 03:45:56 -07:00
SRSRAN_API void srsran_rm_turbo_free_tables();
2021-03-19 03:45:56 -07:00
SRSRAN_API int srsran_rm_turbo_tx_lut(uint8_t* w_buff,
uint8_t* systematic,
uint8_t* parity,
uint8_t* output,
uint32_t cb_idx,
uint32_t out_len,
2015-09-17 02:09:00 -07:00
uint32_t w_offset,
2015-09-16 11:10:54 -07:00
uint32_t rv_idx);
2021-03-19 03:45:56 -07:00
SRSRAN_API int srsran_rm_turbo_rx(float* w_buff,
uint32_t buff_len,
float* input,
2015-03-18 08:05:38 -07:00
uint32_t in_len,
float* output,
uint32_t out_len,
uint32_t rv_idx,
2015-03-18 08:05:38 -07:00
uint32_t nof_filler_bits);
2014-01-28 03:41:17 -08:00
2021-03-19 03:45:56 -07:00
SRSRAN_API int
srsran_rm_turbo_rx_lut(int16_t* input, int16_t* output, uint32_t in_len, uint32_t cb_idx, uint32_t rv_idx);
2021-03-19 03:45:56 -07:00
SRSRAN_API int srsran_rm_turbo_rx_lut_(int16_t* input,
int16_t* output,
uint32_t in_len,
uint32_t cb_idx,
uint32_t rv_idx,
bool enable_input_tdec);
2021-03-19 03:45:56 -07:00
SRSRAN_API int
srsran_rm_turbo_rx_lut_8bit(int8_t* input, int8_t* output, uint32_t in_len, uint32_t cb_idx, uint32_t rv_idx);
2015-10-14 13:30:41 -07:00
2021-03-19 03:45:56 -07:00
#endif // SRSRAN_RM_TURBO_H