Fixed floating point exception bug in sch.c

master
ismagom 10 years ago
parent ae4b71df85
commit 4cdbd9bd83

@ -128,12 +128,16 @@ static int encode_tb(sch_t *q, harq_t *harq, uint8_t *data, uint8_t *e_bits, uin
if (q != NULL && if (q != NULL &&
data != NULL && data != NULL &&
harq != NULL) harq != NULL)
{ {
uint32_t Gp = nof_e_bits / Qm; uint32_t Gp = nof_e_bits / Qm;
uint32_t gamma = Gp%harq->cb_segm.C;
uint32_t gamma = Gp;
if (harq->cb_segm.C > 0) {
gamma = Gp%harq->cb_segm.C;
}
if (harq->rv == 0) { if (harq->rv == 0) {
/* Compute transport block CRC */ /* Compute transport block CRC */
par = crc_checksum(&q->crc_tb, data, harq->mcs.tbs); par = crc_checksum(&q->crc_tb, data, harq->mcs.tbs);
@ -246,14 +250,23 @@ static int decode_tb(sch_t *q, harq_t *harq, float *e_bits, uint8_t *data, uint3
if (q != NULL && if (q != NULL &&
data != NULL && data != NULL &&
harq != NULL) harq != NULL)
{ {
if (harq->mcs.tbs == 0 || harq->cb_segm.C == 0) {
return LIBLTE_SUCCESS;
}
rp = 0; rp = 0;
rp = 0; rp = 0;
wp = 0; wp = 0;
uint32_t Gp = nof_e_bits / Qm; uint32_t Gp = nof_e_bits / Qm;
uint32_t gamma = Gp%harq->cb_segm.C; uint32_t gamma=Gp;
if (harq->cb_segm.C>0) {
gamma = Gp%harq->cb_segm.C;
}
bool early_stop = true; bool early_stop = true;
for (i = 0; i < harq->cb_segm.C && early_stop; i++) { for (i = 0; i < harq->cb_segm.C && early_stop; i++) {

Loading…
Cancel
Save