Commit 495278e6 authored by Robert Schmidt's avatar Robert Schmidt

Make multiple passes over RLC to get all data

parent 8429ba3b
...@@ -821,55 +821,71 @@ void nr_schedule_ue_spec(module_id_t module_id, ...@@ -821,55 +821,71 @@ void nr_schedule_ue_spec(module_id_t module_id,
NULL); // contention res id NULL); // contention res id
buf += written; buf += written;
int size = TBS - written; int size = TBS - written;
DevAssert(size >= 0);
DevAssert(size > 3);
/* next, get RLC data */ /* next, get RLC data */
// we do not know how much data we will get from RLC, i.e., whether it
// will be longer than 256B or not. Therefore, reserve space for long header, then
// fetch data, then fill real length
NR_MAC_SUBHEADER_LONG *header = (NR_MAC_SUBHEADER_LONG *) buf;
buf += 3;
size -= 3;
const int lcid = DL_SCH_LCID_DTCH; const int lcid = DL_SCH_LCID_DTCH;
int dlsch_total_bytes = 0; int dlsch_total_bytes = 0;
if (sched_ctrl->num_total_bytes > 0) { if (sched_ctrl->num_total_bytes > 0) {
/* this is the data from the RLC we would like to request (e.g., only tbs_size_t len = 0;
* some bytes for first LC and some more from a second one */ while (size > 3) {
const rlc_buffer_occupancy_t ndata = min(sched_ctrl->rlc_status[lcid].bytes_in_buffer, size); // we do not know how much data we will get from RLC, i.e., whether it
const tbs_size_t len = mac_rlc_data_req(module_id, // will be longer than 256B or not. Therefore, reserve space for long header, then
rnti, // fetch data, then fill real length
module_id, NR_MAC_SUBHEADER_LONG *header = (NR_MAC_SUBHEADER_LONG *) buf;
frame, buf += 3;
ENB_FLAG_YES, size -= 3;
MBMS_FLAG_NO,
lcid, /* limit requested number of bytes to what preprocessor specified, or
ndata, * such that TBS is full */
(char *)buf, const rlc_buffer_occupancy_t ndata = min(sched_ctrl->rlc_status[lcid].bytes_in_buffer, size);
0, len = mac_rlc_data_req(module_id,
0); rnti,
module_id,
LOG_D(MAC, frame,
"%4d.%2d RNTI %04x: %d bytes from DTCH %d (ndata %d, remaining size %d)\n", ENB_FLAG_YES,
frame, MBMS_FLAG_NO,
slot, lcid,
rnti, ndata,
len, (char *)buf,
lcid, 0,
ndata, 0);
size);
LOG_D(MAC,
header->R = 0; "%4d.%2d RNTI %04x: %d bytes from DTCH %d (ndata %d, remaining size %d)\n",
header->F = 1; frame,
header->LCID = lcid; slot,
header->L1 = (len >> 8) & 0xff; rnti,
header->L2 = len & 0xff; len,
size -= len; lcid,
buf += len; ndata,
dlsch_total_bytes += len; size);
if (len == 0)
break;
header->R = 0;
header->F = 1;
header->LCID = lcid;
header->L1 = (len >> 8) & 0xff;
header->L2 = len & 0xff;
size -= len;
buf += len;
dlsch_total_bytes += len;
}
if (len == 0) {
/* RLC did not have data anymore, mark buffer as unused */
buf -= 3;
size += 3;
}
} }
else if (get_softmodem_params()->phy_test || get_softmodem_params()->do_ra) { else if (get_softmodem_params()->phy_test || get_softmodem_params()->do_ra) {
/* we will need the large header, phy-test typically allocates all
* resources and fills to the last byte below */
NR_MAC_SUBHEADER_LONG *header = (NR_MAC_SUBHEADER_LONG *) buf;
buf += 3;
size -= 3;
DevAssert(size > 0);
LOG_D(MAC, "Configuring DL_TX in %d.%d: TBS %d with %d B of random data\n", frame, slot, TBS, size); LOG_D(MAC, "Configuring DL_TX in %d.%d: TBS %d with %d B of random data\n", frame, slot, TBS, size);
// fill dlsch_buffer with random data // fill dlsch_buffer with random data
for (int i = 0; i < size; i++) for (int i = 0; i < size; i++)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment