Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
O
OpenXG-RAN
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
canghaiwuhen
OpenXG-RAN
Commits
0f6079b3
Commit
0f6079b3
authored
Mar 30, 2017
by
Florian Kaltenberger
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
added 2bit ACK/NACK for TM3/TM4 in HARQ_procedures
parent
3bc3bebc
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
45 additions
and
29 deletions
+45
-29
openair1/SCHED/phy_procedures_lte_eNb.c
openair1/SCHED/phy_procedures_lte_eNb.c
+45
-29
No files found.
openair1/SCHED/phy_procedures_lte_eNb.c
View file @
0f6079b3
...
@@ -1564,12 +1564,13 @@ void process_HARQ_feedback(uint8_t UE_id,
...
@@ -1564,12 +1564,13 @@ void process_HARQ_feedback(uint8_t UE_id,
{
{
LTE_DL_FRAME_PARMS
*
fp
=&
eNB
->
frame_parms
;
LTE_DL_FRAME_PARMS
*
fp
=&
eNB
->
frame_parms
;
uint8_t
dl_harq_pid
[
8
],
dlsch_ACK
[
8
],
dl_subframe
;
uint8_t
dl_harq_pid
[
8
],
dlsch_ACK
[
2
][
8
],
dl_subframe
;
LTE_eNB_DLSCH_t
*
dlsch
=
eNB
->
dlsch
[(
uint32_t
)
UE_id
][
0
];
LTE_eNB_DLSCH_t
*
dlsch
=
eNB
->
dlsch
[(
uint32_t
)
UE_id
][
0
];
LTE_eNB_DLSCH_t
*
dlsch1
=
eNB
->
dlsch
[(
uint32_t
)
UE_id
][
1
];
LTE_eNB_UE_stats
*
ue_stats
=
&
eNB
->
UE_stats
[(
uint32_t
)
UE_id
];
LTE_eNB_UE_stats
*
ue_stats
=
&
eNB
->
UE_stats
[(
uint32_t
)
UE_id
];
LTE_DL_eNB_HARQ_t
*
dlsch_harq_proc
;
LTE_DL_eNB_HARQ_t
*
dlsch_harq_proc
;
uint8_t
subframe_m4
,
M
,
m
;
uint8_t
subframe_m4
,
M
,
m
;
int
mp
;
int
mp
,
tb
;
int
all_ACKed
=
1
,
nb_alloc
=
0
,
nb_ACK
=
0
;
int
all_ACKed
=
1
,
nb_alloc
=
0
,
nb_ACK
=
0
;
int
frame
=
proc
->
frame_rx
;
int
frame
=
proc
->
frame_rx
;
int
subframe
=
proc
->
subframe_rx
;
int
subframe
=
proc
->
subframe_rx
;
...
@@ -1582,13 +1583,15 @@ void process_HARQ_feedback(uint8_t UE_id,
...
@@ -1582,13 +1583,15 @@ void process_HARQ_feedback(uint8_t UE_id,
M
=
1
;
M
=
1
;
if
(
pusch_flag
==
1
)
{
if
(
pusch_flag
==
1
)
{
dlsch_ACK
[
0
]
=
eNB
->
ulsch
[(
uint8_t
)
UE_id
]
->
harq_processes
[
harq_pid
]
->
o_ACK
[
0
];
dlsch_ACK
[
0
][
0
]
=
eNB
->
ulsch
[(
uint8_t
)
UE_id
]
->
harq_processes
[
harq_pid
]
->
o_ACK
[
0
];
dlsch_ACK
[
1
][
0
]
=
eNB
->
ulsch
[(
uint8_t
)
UE_id
]
->
harq_processes
[
harq_pid
]
->
o_ACK
[
1
];
if
(
dlsch
->
subframe_tx
[
subframe_m4
]
==
1
)
if
(
dlsch
->
subframe_tx
[
subframe_m4
]
==
1
)
LOG_D
(
PHY
,
"[eNB %d] Frame %d: Received ACK/NAK %d on PUSCH for subframe %d
\n
"
,
eNB
->
Mod_id
,
LOG_D
(
PHY
,
"[eNB %d] Frame %d: Received ACK/NAK %d on PUSCH for subframe %d
\n
"
,
eNB
->
Mod_id
,
frame
,
dlsch_ACK
[
0
],
subframe_m4
);
frame
,
dlsch_ACK
[
0
],
subframe_m4
);
}
}
else
{
else
{
dlsch_ACK
[
0
]
=
pucch_payload
[
0
];
dlsch_ACK
[
0
][
0
]
=
pucch_payload
[
0
];
dlsch_ACK
[
1
][
0
]
=
pucch_payload
[
1
];
LOG_D
(
PHY
,
"[eNB %d] Frame %d: Received ACK/NAK %d on PUCCH for subframe %d
\n
"
,
eNB
->
Mod_id
,
LOG_D
(
PHY
,
"[eNB %d] Frame %d: Received ACK/NAK %d on PUCCH for subframe %d
\n
"
,
eNB
->
Mod_id
,
frame
,
dlsch_ACK
[
0
],
subframe_m4
);
frame
,
dlsch_ACK
[
0
],
subframe_m4
);
/*
/*
...
@@ -1605,7 +1608,7 @@ void process_HARQ_feedback(uint8_t UE_id,
...
@@ -1605,7 +1608,7 @@ void process_HARQ_feedback(uint8_t UE_id,
"%05u:%02u %s received %s rnti %x harq id %u tx SF %u"
,
"%05u:%02u %s received %s rnti %x harq id %u tx SF %u"
,
frame
,
subframe
,
frame
,
subframe
,
(
pusch_flag
==
1
)
?
"PUSCH"
:
"PUCCH"
,
(
pusch_flag
==
1
)
?
"PUSCH"
:
"PUCCH"
,
(
dlsch_ACK
[
0
])
?
"ACK"
:
"NACK"
,
(
dlsch_ACK
[
0
]
[
0
]
)
?
"ACK"
:
"NACK"
,
dlsch
->
rnti
,
dlsch
->
rnti
,
dl_harq_pid
[
0
],
dl_harq_pid
[
0
],
subframe_m4
subframe_m4
...
@@ -1624,8 +1627,8 @@ void process_HARQ_feedback(uint8_t UE_id,
...
@@ -1624,8 +1627,8 @@ void process_HARQ_feedback(uint8_t UE_id,
// otherwise, it depends on how many of the PDSCH in the set are scheduled, we can leave it like this,
// otherwise, it depends on how many of the PDSCH in the set are scheduled, we can leave it like this,
// but we have to adapt the code below. For example, if only one out of 2 are scheduled, only 1 bit o_ACK is used
// but we have to adapt the code below. For example, if only one out of 2 are scheduled, only 1 bit o_ACK is used
dlsch_ACK
[
0
]
=
eNB
->
ulsch
[(
uint8_t
)
UE_id
]
->
harq_processes
[
harq_pid
]
->
o_ACK
[
0
];
dlsch_ACK
[
0
]
[
0
]
=
eNB
->
ulsch
[(
uint8_t
)
UE_id
]
->
harq_processes
[
harq_pid
]
->
o_ACK
[
0
];
dlsch_ACK
[
1
]
=
(
eNB
->
pucch_config_dedicated
[
UE_id
].
tdd_AckNackFeedbackMode
==
bundling
)
dlsch_ACK
[
0
][
1
]
=
(
eNB
->
pucch_config_dedicated
[
UE_id
].
tdd_AckNackFeedbackMode
==
bundling
)
?
eNB
->
ulsch
[(
uint8_t
)
UE_id
]
->
harq_processes
[
harq_pid
]
->
o_ACK
[
0
]
:
eNB
->
ulsch
[(
uint8_t
)
UE_id
]
->
harq_processes
[
harq_pid
]
->
o_ACK
[
1
];
?
eNB
->
ulsch
[(
uint8_t
)
UE_id
]
->
harq_processes
[
harq_pid
]
->
o_ACK
[
0
]
:
eNB
->
ulsch
[(
uint8_t
)
UE_id
]
->
harq_processes
[
harq_pid
]
->
o_ACK
[
1
];
}
}
...
@@ -1647,23 +1650,23 @@ void process_HARQ_feedback(uint8_t UE_id,
...
@@ -1647,23 +1650,23 @@ void process_HARQ_feedback(uint8_t UE_id,
nb_ACK
=
3
;
nb_ACK
=
3
;
}
}
}
else
if
(
pucch_sel
==
2
)
{
// bundling or M=1
}
else
if
(
pucch_sel
==
2
)
{
// bundling or M=1
dlsch_ACK
[
0
]
=
pucch_payload
[
0
];
dlsch_ACK
[
0
]
[
0
]
=
pucch_payload
[
0
];
dlsch_ACK
[
1
]
=
pucch_payload
[
0
];
dlsch_ACK
[
0
][
1
]
=
pucch_payload
[
0
];
}
else
{
// multiplexing with no SR, this is table 10.1
}
else
{
// multiplexing with no SR, this is table 10.1
if
(
M
==
1
)
if
(
M
==
1
)
dlsch_ACK
[
0
]
=
pucch_payload
[
0
];
dlsch_ACK
[
0
]
[
0
]
=
pucch_payload
[
0
];
else
if
(
M
==
2
)
{
else
if
(
M
==
2
)
{
if
(((
pucch_sel
==
1
)
&&
(
pucch_payload
[
0
]
==
1
)
&&
(
pucch_payload
[
1
]
==
1
))
||
if
(((
pucch_sel
==
1
)
&&
(
pucch_payload
[
0
]
==
1
)
&&
(
pucch_payload
[
1
]
==
1
))
||
((
pucch_sel
==
0
)
&&
(
pucch_payload
[
0
]
==
0
)
&&
(
pucch_payload
[
1
]
==
1
)))
((
pucch_sel
==
0
)
&&
(
pucch_payload
[
0
]
==
0
)
&&
(
pucch_payload
[
1
]
==
1
)))
dlsch_ACK
[
0
]
=
1
;
dlsch_ACK
[
0
]
[
0
]
=
1
;
else
else
dlsch_ACK
[
0
]
=
0
;
dlsch_ACK
[
0
]
[
0
]
=
0
;
if
(((
pucch_sel
==
1
)
&&
(
pucch_payload
[
0
]
==
1
)
&&
(
pucch_payload
[
1
]
==
1
))
||
if
(((
pucch_sel
==
1
)
&&
(
pucch_payload
[
0
]
==
1
)
&&
(
pucch_payload
[
1
]
==
1
))
||
((
pucch_sel
==
1
)
&&
(
pucch_payload
[
0
]
==
0
)
&&
(
pucch_payload
[
1
]
==
0
)))
((
pucch_sel
==
1
)
&&
(
pucch_payload
[
0
]
==
0
)
&&
(
pucch_payload
[
1
]
==
0
)))
dlsch_ACK
[
1
]
=
1
;
dlsch_ACK
[
0
][
1
]
=
1
;
else
else
dlsch_ACK
[
1
]
=
0
;
dlsch_ACK
[
0
][
1
]
=
0
;
}
}
}
}
}
}
...
@@ -1705,32 +1708,42 @@ void process_HARQ_feedback(uint8_t UE_id,
...
@@ -1705,32 +1708,42 @@ void process_HARQ_feedback(uint8_t UE_id,
harq_pid_updated
[
UE_id
][
dl_harq_pid
[
m
]]
=
1
;
harq_pid_updated
[
UE_id
][
dl_harq_pid
[
m
]]
=
1
;
if
((
pucch_sel
!=
2
)
&&
(
pusch_flag
==
0
))
{
// multiplexing
if
((
pucch_sel
!=
2
)
&&
(
pusch_flag
==
0
))
{
// multiplexing
if
((
SR_payload
==
1
)
&&
(
all_ACKed
==
1
))
if
((
SR_payload
==
1
)
&&
(
all_ACKed
==
1
))
{
dlsch_ACK
[
m
]
=
1
;
dlsch_ACK
[
0
][
m
]
=
1
;
else
dlsch_ACK
[
1
][
m
]
=
1
;
dlsch_ACK
[
m
]
=
0
;
}
else
{
dlsch_ACK
[
0
][
m
]
=
0
;
dlsch_ACK
[
1
][
m
]
=
0
;
}
}
}
if
(
dl_harq_pid
[
m
]
<
dlsch
->
Mdlharq
)
{
if
(
dl_harq_pid
[
m
]
<
dlsch
->
Mdlharq
)
{
dlsch_harq_proc
=
dlsch
->
harq_processes
[
dl_harq_pid
[
m
]];
// we always loop over 2 possible max TBs. If its not used it should habe been disabled
for
(
tb
=
0
;
tb
<
2
;
tb
++
)
{
if
(
tb
==
0
)
dlsch_harq_proc
=
dlsch
->
harq_processes
[
dl_harq_pid
[
m
]];
else
dlsch_harq_proc
=
dlsch1
->
harq_processes
[
dl_harq_pid
[
m
]];
#ifdef DEBUG_PHY_PROC
#ifdef DEBUG_PHY_PROC
LOG_D
(
PHY
,
"[eNB %d][PDSCH %x/%d] subframe %d, status %d, round %d (mcs %d, rv %d, TBS %d)
\n
"
,
eNB
->
Mod_id
,
LOG_D
(
PHY
,
"[eNB %d][PDSCH %x/%d] subframe %d,
TB %d,
status %d, round %d (mcs %d, rv %d, TBS %d)
\n
"
,
eNB
->
Mod_id
,
dlsch
->
rnti
,
dl_harq_pid
[
m
],
dl_subframe
,
dlsch
->
rnti
,
dl_harq_pid
[
m
],
dl_subframe
,
tb
,
dlsch_harq_proc
->
status
,
dlsch_harq_proc
->
round
,
dlsch_harq_proc
->
status
,
dlsch_harq_proc
->
round
,
dlsch
->
harq_processes
[
dl_harq_pid
[
m
]]
->
mcs
,
dlsch
->
harq_processes
[
dl_harq_pid
[
m
]]
->
mcs
,
dlsch
->
harq_processes
[
dl_harq_pid
[
m
]]
->
rvidx
,
dlsch
->
harq_processes
[
dl_harq_pid
[
m
]]
->
rvidx
,
dlsch
->
harq_processes
[
dl_harq_pid
[
m
]]
->
TBS
);
dlsch
->
harq_processes
[
dl_harq_pid
[
m
]]
->
TBS
);
if
(
dlsch_harq_proc
->
status
==
DISABLED
)
LOG_E
(
PHY
,
"dlsch_harq_proc is disabled?
\n
"
);
#endif
#endif
if
((
dl_harq_pid
[
m
]
<
dlsch
->
Mdlharq
)
&&
if
(
dlsch_harq_proc
->
status
==
DISABLED
)
{
(
dlsch_harq_proc
->
status
==
ACTIVE
))
{
LOG_E
(
PHY
,
"dlsch_harq_proc is disabled?
\n
"
);
}
else
{
if
(
dlsch_harq_proc
->
status
==
ACTIVE
)
{
// dl_harq_pid of DLSCH is still active
// dl_harq_pid of DLSCH is still active
if
(
dlsch_ACK
[
mp
]
==
0
)
{
if
(
dlsch_ACK
[
tb
][
mp
]
==
0
)
{
// Received NAK
// Received NAK
#ifdef DEBUG_PHY_PROC
#ifdef DEBUG_PHY_PROC
LOG_D
(
PHY
,
"[eNB %d][PDSCH %x/%d] M = %d, m= %d, mp=%d NAK Received in round %d, requesting retransmission
\n
"
,
eNB
->
Mod_id
,
LOG_D
(
PHY
,
"[eNB %d][PDSCH %x/%d] M = %d, m= %d, mp=%d NAK Received in round %d, requesting retransmission
\n
"
,
eNB
->
Mod_id
,
...
@@ -1776,6 +1789,7 @@ void process_HARQ_feedback(uint8_t UE_id,
...
@@ -1776,6 +1789,7 @@ void process_HARQ_feedback(uint8_t UE_id,
T
(
T_ENB_PHY_DLSCH_UE_ACK
,
T_INT
(
eNB
->
Mod_id
),
T_INT
(
frame
),
T_INT
(
subframe
),
T_INT
(
UE_id
),
T_INT
(
dlsch
->
rnti
),
T
(
T_ENB_PHY_DLSCH_UE_ACK
,
T_INT
(
eNB
->
Mod_id
),
T_INT
(
frame
),
T_INT
(
subframe
),
T_INT
(
UE_id
),
T_INT
(
dlsch
->
rnti
),
T_INT
(
dl_harq_pid
[
m
]));
T_INT
(
dl_harq_pid
[
m
]));
// TODO: add TB to stats
ue_stats
->
dlsch_ACK
[
dl_harq_pid
[
m
]][
dlsch_harq_proc
->
round
]
++
;
ue_stats
->
dlsch_ACK
[
dl_harq_pid
[
m
]][
dlsch_harq_proc
->
round
]
++
;
// Received ACK so set round to 0 and set dlsch_harq_pid IDLE
// Received ACK so set round to 0 and set dlsch_harq_pid IDLE
...
@@ -1800,8 +1814,8 @@ void process_HARQ_feedback(uint8_t UE_id,
...
@@ -1800,8 +1814,8 @@ void process_HARQ_feedback(uint8_t UE_id,
}
}
#ifdef DEBUG_PHY_PROC
#ifdef DEBUG_PHY_PROC
LOG_D
(
PHY
,
"[process_HARQ_feedback] Frame %d Setting round to %d for pid %d (subframe %d)
\n
"
,
frame
,
LOG_D
(
PHY
,
"[process_HARQ_feedback] Frame %d Setting round to %d for pid %d
tb %d
(subframe %d)
\n
"
,
frame
,
dlsch_harq_proc
->
round
,
dl_harq_pid
[
m
],
subframe
);
dlsch_harq_proc
->
round
,
dl_harq_pid
[
m
],
tb
,
subframe
);
#endif
#endif
harq_pid_round
[
UE_id
][
dl_harq_pid
[
m
]]
=
dlsch_harq_proc
->
round
;
harq_pid_round
[
UE_id
][
dl_harq_pid
[
m
]]
=
dlsch_harq_proc
->
round
;
// Clear NAK stats and adjust mcs offset
// Clear NAK stats and adjust mcs offset
...
@@ -1823,6 +1837,8 @@ void process_HARQ_feedback(uint8_t UE_id,
...
@@ -1823,6 +1837,8 @@ void process_HARQ_feedback(uint8_t UE_id,
ue_stats
->
dlsch_sliding_cnt
=
0
;
ue_stats
->
dlsch_sliding_cnt
=
0
;
}
}
}
}
}
}
}
}
}
}
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment