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
0f54bf27
Commit
0f54bf27
authored
Dec 25, 2019
by
Chang-Sheng,Liu
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
add L2 IF_Module and fix some memory error
parent
5693f7ba
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
271 additions
and
2 deletions
+271
-2
openair2/PHY_INTERFACE/IF_Module_L2_primitives_NB_IoT.c
openair2/PHY_INTERFACE/IF_Module_L2_primitives_NB_IoT.c
+231
-0
openair2/PHY_INTERFACE/IF_Module_L2_primitives_NB_IoT.h
openair2/PHY_INTERFACE/IF_Module_L2_primitives_NB_IoT.h
+9
-0
openair2/PHY_INTERFACE/IF_Module_NB_IoT.c
openair2/PHY_INTERFACE/IF_Module_NB_IoT.c
+29
-0
targets/RT/USER/lte-enb.c
targets/RT/USER/lte-enb.c
+2
-2
No files found.
openair2/PHY_INTERFACE/IF_Module_L2_primitives_NB_IoT.c
0 → 100644
View file @
0f54bf27
#include "IF_Module_L2_primitives_NB_IoT.h"
#include "LAYER2/MAC/proto_NB_IoT.h"
#include "LAYER2/MAC/extern_NB_IoT.h"
int
tmp
=
0
;
//int block_rach = 0;
int
first_msg4
=
0
;
void
simulate_preamble
(
UL_IND_NB_IoT_t
*
UL_INFO
,
int
CE
,
int
sc
)
{
UL_INFO
->
nrach_ind
.
number_of_initial_scs_detected
=
1
;
UL_INFO
->
nrach_ind
.
nrach_pdu_list
[
0
].
nrach_indication_rel13
.
initial_sc
=
sc
;
UL_INFO
->
nrach_ind
.
nrach_pdu_list
[
0
].
nrach_indication_rel13
.
timing_advance
=
0
;
UL_INFO
->
nrach_ind
.
nrach_pdu_list
[
0
].
nrach_indication_rel13
.
nrach_ce_level
=
CE
;
}
void
enable_preamble_simulation
(
UL_IND_NB_IoT_t
*
UL_INFO
,
int
i
)
{
if
(
i
==
1
)
{
// simulate preamble session
/*
if(UL_INFO->frame==60 && UL_INFO->subframe==2 && (tmp%3==0))
{
simulate_preamble(UL_INFO,0,2);
tmp++;
}
if(UL_INFO->frame==100 && UL_INFO->subframe==2 && (tmp%3==1))
{
simulate_preamble(UL_INFO,1,13);
tmp++;
}
*/
if
(
UL_INFO
->
frame
==
516
&&
UL_INFO
->
subframe
==
8
)
{
simulate_preamble
(
UL_INFO
,
2
,
26
);
//tmp++;
}
}
}
void
simulate_msg3
(
UL_IND_NB_IoT_t
*
UL_INFO
)
{
uint8_t
*
msg3
=
NULL
;
msg3
=
(
uint8_t
*
)
malloc
(
11
*
sizeof
(
uint8_t
));
msg3
[
0
]
=
0
;
msg3
[
1
]
=
58
;
msg3
[
2
]
=
42
;
// 2A
msg3
[
3
]
=
179
;
// B3
msg3
[
4
]
=
84
;
// 54
msg3
[
5
]
=
141
;
// 8D
msg3
[
6
]
=
43
;
// 2B
msg3
[
7
]
=
52
;
// 34
msg3
[
8
]
=
64
;
// 40
msg3
[
9
]
=
0
;
msg3
[
10
]
=
0
;
UL_INFO
->
RX_NPUSCH
.
number_of_pdus
=
1
;
UL_INFO
->
module_id
=
0
;
UL_INFO
->
CC_id
=
0
;
UL_INFO
->
frame
=
521
;
UL_INFO
->
subframe
=
1
;
UL_INFO
->
RX_NPUSCH
.
rx_pdu_list
=
(
nfapi_rx_indication_pdu_t
*
)
malloc
(
sizeof
(
nfapi_rx_indication_pdu_t
));
UL_INFO
->
RX_NPUSCH
.
rx_pdu_list
->
rx_ue_information
.
rnti
=
0x0101
;
UL_INFO
->
RX_NPUSCH
.
rx_pdu_list
->
data
=
msg3
;
UL_INFO
->
RX_NPUSCH
.
rx_pdu_list
->
rx_indication_rel8
.
length
=
11
;
}
void
enable_msg3_simulation
(
UL_IND_NB_IoT_t
*
UL_INFO
,
int
i
)
{
if
(
i
==
1
)
{
if
(
UL_INFO
->
frame
==
521
&&
UL_INFO
->
subframe
==
1
)
{
simulate_msg3
(
UL_INFO
);
}
}
}
// Sched_INFO as a input for the scheduler
void
UL_indication_NB_IoT
(
UL_IND_NB_IoT_t
*
UL_INFO
)
{
int
i
=
0
;
uint32_t
abs_subframe
;
Sched_Rsp_NB_IoT_t
*
SCHED_info
=
&
mac_inst
->
Sched_INFO
;
UE_TEMPLATE_NB_IoT
*
ue_info
=
(
UE_TEMPLATE_NB_IoT
*
)
0
;
uint16_t
tmp_rnti
;
enable_preamble_simulation
(
UL_INFO
,
0
);
enable_msg3_simulation
(
UL_INFO
,
0
);
//If there is a preamble, do the initiate RA procedure
if
(
UL_INFO
->
nrach_ind
.
number_of_initial_scs_detected
>
0
)
{
// only use one preamble now
//for(i=0;i<UL_INFO->nrach_ind.number_of_initial_scs_detected;i++)
for
(
i
=
0
;
i
<
1
;
i
++
)
{
if
(
UE_state_machine
==
initial_access
)
{
// initiate_ra here, some useful inforamtion :
LOG_D
(
MAC
,
"Init_RA_NB_IoT in, index of sc = %d
\n
"
,(
UL_INFO
->
nrach_ind
.
nrach_pdu_list
+
i
)
->
nrach_indication_rel13
.
initial_sc
);
init_RA_NB_IoT
(
mac_inst
,
(
UL_INFO
->
nrach_ind
.
nrach_pdu_list
+
i
)
->
nrach_indication_rel13
.
initial_sc
,
(
UL_INFO
->
nrach_ind
.
nrach_pdu_list
+
i
)
->
nrach_indication_rel13
.
nrach_ce_level
,
UL_INFO
->
frame
,
//timing_offset = Timing_advance * 16
(
UL_INFO
->
nrach_ind
.
nrach_pdu_list
+
i
)
->
nrach_indication_rel13
.
timing_advance
*
16
);
}
else
if
(
UE_state_machine
==
rach_for_auth_rsp
)
{
LOG_N
(
MAC
,
"It is the second time that this UE try to rach
\n
"
);
init_RA_NB_IoT
(
mac_inst
,
(
UL_INFO
->
nrach_ind
.
nrach_pdu_list
+
i
)
->
nrach_indication_rel13
.
initial_sc
,
(
UL_INFO
->
nrach_ind
.
nrach_pdu_list
+
i
)
->
nrach_indication_rel13
.
nrach_ce_level
,
UL_INFO
->
frame
,
//timing_offset = Timing_advance * 16
(
UL_INFO
->
nrach_ind
.
nrach_pdu_list
+
i
)
->
nrach_indication_rel13
.
timing_advance
*
16
);
//block_rach = 2;
}
}
}
UL_INFO
->
nrach_ind
.
number_of_initial_scs_detected
=
0
;
/* Disable crc function for now
// crc indication if there is error for this round UL transmission
if(UL_INFO->crc_ind.number_of_crcs>0)
{
for(i=0;i<UL_INFO->crc_ind.number_of_crcs;i++)
{
if((UL_INFO->crc_ind.crc_pdu_list+i)->crc_indication_rel8.crc_flag == 0)
{
//unsuccessfully received this UE PDU
//UE_info = get_ue_from_rnti(mac_inst,((UL_INFO->crc_ind.crc_pdu_list)+i)->rx_ue_information.rnti);
//UE_info->HARQ_round++;
}
}
}
*/
// Check if there is any feed back of HARQ
if
(
UL_INFO
->
nb_harq_ind
.
nb_harq_indication_body
.
number_of_harqs
>
0
)
{
//LOG_I(MAC,"Recieved Ack of DL Data, rnti : %x\n",UL_INFO->nb_harq_ind.nb_harq_indication_body.nb_harq_pdu_list[0].rx_ue_information.rnti);
ue_info
=
get_ue_from_rnti
(
mac_inst
,
UL_INFO
->
nb_harq_ind
.
nb_harq_indication_body
.
nb_harq_pdu_list
[
0
].
rx_ue_information
.
rnti
);
if
(
ue_info
->
direction
==
3
)
{
if
(
UL_INFO
->
nb_harq_ind
.
nb_harq_indication_body
.
nb_harq_pdu_list
[
0
].
nb_harq_indication_fdd_rel13
.
harq_tb1
==
1
)
{
LOG_I
(
MAC
,
"This UE get the response of HARQ DL : ACK
\n
"
);
ue_info
->
direction
=
0
;
}
else
{
LOG_I
(
MAC
,
"This UE get the response of HARQ DL : ACK, update the UL buffer for next message
\n
"
);
ue_info
->
direction
=-
1
;
//ue_info->ul_total_buffer = 11;
UE_state_machine
=
rach_for_auth_rsp
;
//LOG_I(MAC,"This UE get the response of HARQ DL : NACK, and will start the next harq round : %d\n",ue_info->HARQ_round);
//ue_info->direction=1;
//ue_info->HARQ_round++;
}
}
else
{
if
(
first_msg4
==
0
)
{
receive_msg4_ack_NB_IoT
(
mac_inst
,
UL_INFO
->
nb_harq_ind
.
nb_harq_indication_body
.
nb_harq_pdu_list
[
0
].
rx_ue_information
.
rnti
);
first_msg4
=
1
;
}
}
}
UL_INFO
->
nb_harq_ind
.
nb_harq_indication_body
.
number_of_harqs
=
0
;
//If there is a Uplink SDU which needs to send to MAC
if
(
UL_INFO
->
RX_NPUSCH
.
number_of_pdus
>
0
)
{
for
(
i
=
0
;
i
<
UL_INFO
->
RX_NPUSCH
.
number_of_pdus
;
i
++
)
{
//For MSG3, Normal Uplink Data, NAK
rx_sdu_NB_IoT
(
UL_INFO
->
module_id
,
UL_INFO
->
CC_id
,
UL_INFO
->
frame
,
UL_INFO
->
subframe
,
(
UL_INFO
->
RX_NPUSCH
.
rx_pdu_list
+
i
)
->
rx_ue_information
.
rnti
,
(
UL_INFO
->
RX_NPUSCH
.
rx_pdu_list
+
i
)
->
data
,
(
UL_INFO
->
RX_NPUSCH
.
rx_pdu_list
+
i
)
->
rx_indication_rel8
.
length
);
}
}
UL_INFO
->
RX_NPUSCH
.
number_of_pdus
=
0
;
if
(
UL_INFO
->
hypersfn
==
1
&&
UL_INFO
->
frame
==
0
)
{
LOG_D
(
MAC
,
"IF L2 hypersfn:%d frame: %d ,subframe: %d
\n
"
,
UL_INFO
->
hypersfn
,
UL_INFO
->
frame
,
UL_INFO
->
subframe
);
}
if
(
waiting_flag_from_RLC
==
1
)
{
tmp_rnti
=
0x0101
;
ue_info
=
get_ue_from_rnti
(
mac_inst
,
tmp_rnti
);
ue_info
->
direction
=
1
;
waiting_flag_from_RLC
=
2
;
}
abs_subframe
=
UL_INFO
->
hypersfn
*
10240
+
UL_INFO
->
frame
*
10
+
UL_INFO
->
subframe
+
4
;
//abs_subframe = UL_INFO->frame*10+UL_INFO->subframe +4;
//LOG_I(MAC,"Enter scheduler in subframe %d\n",abs_subframe);
//scheduler here
//Schedule subframe should be next four subframe, means that UL_INFO->frame*10+UL_INFO->subframe + 4
eNB_dlsch_ulsch_scheduler_NB_IoT
(
mac_inst
,
abs_subframe
);
mac_inst
->
if_inst_NB_IoT
->
schedule_response
(
&
mac_inst
->
Sched_INFO
);
LOG_D
(
MAC
,
"After scheduler & schedule response
\n
"
);
/*
free(SCHED_info->TX_req->tx_request_body.tx_pdu_list);
free(SCHED_info->HI_DCI0_req->hi_dci0_request_body.hi_dci0_pdu_list);
free(SCHED_info->DL_req->dl_config_request_body.dl_config_pdu_list);
free(SCHED_info->UL_req->ul_config_request_body.ul_config_pdu_list);
free(SCHED_info->TX_req);
free(SCHED_info->HI_DCI0_req);
free(SCHED_info->DL_req);
free(SCHED_info->UL_req);
*/
}
openair2/PHY_INTERFACE/IF_Module_L2_primitives_NB_IoT.h
0 → 100644
View file @
0f54bf27
#include "openair2/PHY_INTERFACE/IF_Module_NB_IoT.h"
//#include "LAYER2/MAC/extern.h"
#ifndef __IF_MODULE_L2_PRIMITIVES_NB_IOT_H__
#define __IF_MODULE_L2_PRIMITIVES_NB_IOT_H__
#endif
openair2/PHY_INTERFACE/IF_Module_NB_IoT.c
0 → 100644
View file @
0f54bf27
#include "openair2/PHY_INTERFACE/IF_Module_NB_IoT.h"
#include "openair2/PHY_INTERFACE/IF_Module_L2_primitives_NB_IoT.h"
#include "openair1/SCHED/IF_Module_L1_primitives_NB_IoT.h"
#include "LAYER2/MAC/extern_NB_IoT.h"
//#include "LAYER2/MAC/proto_NB_IoT.h"
#define MAX_IF_MODULES_NB_IoT 1
IF_Module_NB_IoT_t
*
if_inst_NB_IoT
[
MAX_IF_MODULES_NB_IoT
];
//#include "LAYER2/MAC/proto_NB_IoT.h"
IF_Module_NB_IoT_t
*
IF_Module_init_NB_IoT
(
int
Mod_id
){
AssertFatal
(
Mod_id
<
MAX_MODULES
,
"Asking for Module %d > %d
\n
"
,
Mod_id
,
MAX_IF_MODULES_NB_IoT
);
if
(
if_inst_NB_IoT
[
Mod_id
]
==
NULL
)
{
if_inst_NB_IoT
[
Mod_id
]
=
(
IF_Module_NB_IoT_t
*
)
malloc
(
sizeof
(
IF_Module_NB_IoT_t
));
memset
((
void
*
)
if_inst_NB_IoT
[
Mod_id
],
0
,
sizeof
(
IF_Module_NB_IoT_t
));
//if_inst[Mod_id]->CC_mask=0;
if_inst_NB_IoT
[
Mod_id
]
->
UL_indication
=
UL_indication_NB_IoT
;
/*AssertFatal(pthread_mutex_init(&if_inst[Mod_id]->if_mutex,NULL)==0,
"allocation of if_inst[%d]->if_mutex fails\n",Mod_id);*/
}
return
if_inst_NB_IoT
[
Mod_id
];
}
targets/RT/USER/lte-enb.c
View file @
0f54bf27
...
...
@@ -867,9 +867,9 @@ void init_eNB_proc(int inst) {
pthread_attr_t
*
attr_prach_br
=
NULL
;
#endif
LOG_I
(
PHY
,
"%s(inst:%d) RC.nb_CC[inst]:%d
\n
"
,
__FUNCTION__
,
inst
,
RC
.
nb_CC
[
inst
]);
eNBs
.
eNB_NB_IoT
=
RC
.
L1_NB_IoT
[
inst
];
//Ann
eNBs
.
eNB_NB_IoT
=
&
RC
.
L1_NB_IoT
[
inst
];
//Ann
for
(
CC_id
=
0
;
CC_id
<
RC
.
nb_CC
[
inst
];
CC_id
++
)
{
eNBs
.
eNB
=
RC
.
eNB
[
inst
][
CC_id
];
eNBs
.
eNB
=
&
RC
.
eNB
[
inst
][
CC_id
];
#ifndef OCP_FRAMEWORK
LOG_I
(
PHY
,
"Initializing eNB processes instance:%d CC_id %d
\n
"
,
inst
,
CC_id
);
...
...
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