@ -17,7 +17,7 @@
*/
*/
int test_tx_status_report ( const srslte : : pdcp_lte_state_t & init_state , srslog : : basic_logger & logger )
int test_tx_status_report ( const srslte : : pdcp_lte_state_t & init_state , srslog : : basic_logger & logger )
{
{
srslte : : pdcp_config_t cfg = { 1 ,
srslte : : pdcp_config_t cfg _tx = { 1 ,
srslte : : PDCP_RB_IS_DRB ,
srslte : : PDCP_RB_IS_DRB ,
srslte : : SECURITY_DIRECTION_UPLINK ,
srslte : : SECURITY_DIRECTION_UPLINK ,
srslte : : SECURITY_DIRECTION_DOWNLINK ,
srslte : : SECURITY_DIRECTION_DOWNLINK ,
@ -26,31 +26,52 @@ int test_tx_status_report(const srslte::pdcp_lte_state_t& init_state, srslog::ba
srslte : : pdcp_discard_timer_t : : ms500 ,
srslte : : pdcp_discard_timer_t : : ms500 ,
true } ;
true } ;
pdcp_lte_test_helper pdcp_hlp ( cfg , sec_cfg , logger ) ;
srslte : : pdcp_config_t cfg_rx = { 1 ,
srslte : : pdcp_entity_lte * pdcp = & pdcp_hlp . pdcp ;
srslte : : PDCP_RB_IS_DRB ,
rlc_dummy * rlc = & pdcp_hlp . rlc ;
srslte : : SECURITY_DIRECTION_DOWNLINK ,
srsue : : stack_test_dummy * stack = & pdcp_hlp . stack ;
srslte : : SECURITY_DIRECTION_UPLINK ,
srslte : : PDCP_SN_LEN_12 ,
srslte : : pdcp_t_reordering_t : : ms500 ,
srslte : : pdcp_discard_timer_t : : ms500 ,
true } ;
pdcp_hlp . set_pdcp_initial_state ( init_state ) ;
// Setup TX
pdcp_lte_test_helper pdcp_hlp_tx ( cfg_tx , sec_cfg , logger ) ;
srslte : : pdcp_entity_lte * pdcp_tx = & pdcp_hlp_tx . pdcp ;
rlc_dummy * rlc_tx = & pdcp_hlp_tx . rlc ;
srsue : : stack_test_dummy * stack_tx = & pdcp_hlp_tx . stack ;
pdcp_hlp_tx . set_pdcp_initial_state ( init_state ) ;
// Setup RX
pdcp_lte_test_helper pdcp_hlp_rx ( cfg_tx , sec_cfg , logger ) ;
srslte : : pdcp_entity_lte * pdcp_rx = & pdcp_hlp_tx . pdcp ;
rlc_dummy * rlc_rx = & pdcp_hlp_tx . rlc ;
srsue : : stack_test_dummy * stack_rx = & pdcp_hlp_tx . stack ;
pdcp_hlp_rx . set_pdcp_initial_state ( init_state ) ;
// Tmp variable to hold the PDCP PDU
srslte : : unique_byte_buffer_t out_pdu = srslte : : make_byte_buffer ( ) ;
srslte : : unique_byte_buffer_t out_pdu = srslte : : make_byte_buffer ( ) ;
// Write 256 SDUs and notify imediatly -> FMS 0001 0000 0001
// Write 256 SDUs and notify imediatly -> FMS 0001 0000 0001
for ( uint32_t i = 0 ; i < 257 ; i + + ) {
for ( uint32_t i = 0 ; i < 257 ; i + + ) {
srslte : : unique_byte_buffer_t sdu = srslte : : make_byte_buffer ( ) ;
srslte : : unique_byte_buffer_t sdu = srslte : : make_byte_buffer ( ) ;
srslte : : unique_byte_buffer_t pdu = srslte : : make_byte_buffer ( ) ;
sdu - > append_bytes ( sdu1 , sizeof ( sdu1 ) ) ;
sdu - > append_bytes ( sdu1 , sizeof ( sdu1 ) ) ;
pdcp - > write_sdu ( std : : move ( sdu ) ) ;
pdcp_tx - > write_sdu ( std : : move ( sdu ) ) ;
pdcp - > notify_delivery ( { i } ) ;
pdcp_tx - > notify_delivery ( { i } ) ;
rlc_tx - > get_last_sdu ( pdu ) ;
pdcp_rx - > write_pdu ( std : : move ( pdu ) ) ;
}
}
// Check undelivered SDUs queue size
// Check undelivered SDUs queue size
TESTASSERT ( pdcp - > nof_discard_timers ( ) = = 0 ) ; // 0 timers should be running
TESTASSERT ( pdcp _tx - > nof_discard_timers ( ) = = 0 ) ; // 0 timers should be running on TX
// Generate the status report
// Generate the status report
pdcp - > send_status_report ( ) ;
pdcp _rx - > send_status_report ( ) ;
rlc - > get_last_sdu ( out_pdu ) ;
rlc _rx - > get_last_sdu ( out_pdu ) ;
logger . debug ( out_pdu - > msg , out_pdu - > N_bytes , " Status PDU: " ) ;
logger . debug ( out_pdu - > msg , out_pdu - > N_bytes , " Status PDU: " ) ;
// Check status PDU
// Check status PDU . We received up to
/*
/*
* | D / C | TYPE | FMS | - > | 0 | 0 | 0001 |
* | D / C | TYPE | FMS | - > | 0 | 0 | 0001 |
* | FMS | - > | 00000001 |
* | FMS | - > | 00000001 |
@ -62,33 +83,36 @@ int test_tx_status_report(const srslte::pdcp_lte_state_t& init_state, srslog::ba
// Write another 16 SDUs but don't notify SN=257, SN=258, SN=271 and SN=272
// Write another 16 SDUs but don't notify SN=257, SN=258, SN=271 and SN=272
for ( uint32_t i = 257 ; i < 273 ; i + + ) {
for ( uint32_t i = 257 ; i < 273 ; i + + ) {
srslte : : unique_byte_buffer_t sdu = srslte : : make_byte_buffer ( ) ;
srslte : : unique_byte_buffer_t sdu = srslte : : make_byte_buffer ( ) ;
srslte : : unique_byte_buffer_t pdu = srslte : : make_byte_buffer ( ) ;
sdu - > append_bytes ( sdu1 , sizeof ( sdu1 ) ) ;
sdu - > append_bytes ( sdu1 , sizeof ( sdu1 ) ) ;
pdcp - > write_sdu ( std : : move ( sdu ) ) ;
pdcp _tx - > write_sdu ( std : : move ( sdu ) ) ;
if ( i ! = 257 & & i ! = 258 & & i ! = 271 & & i ! = 272 ) {
if ( i ! = 257 & & i ! = 258 & & i ! = 271 & & i ! = 272 ) {
pdcp - > notify_delivery ( { i } ) ;
pdcp_tx - > notify_delivery ( { i } ) ;
rlc_tx - > get_last_sdu ( pdu ) ;
pdcp_rx - > write_pdu ( std : : move ( pdu ) ) ;
}
}
}
}
// Check undelivered SDUs queue size
// Check undelivered SDUs queue size
TESTASSERT ( pdcp - > nof_discard_timers ( ) = = 4 ) ;
TESTASSERT ( pdcp _tx - > nof_discard_timers ( ) = = 4 ) ;
// Generate the status report
// Generate the status report
pdcp - > send_status_report ( ) ;
pdcp _tx - > send_status_report ( ) ;
rlc - > get_last_sdu ( out_pdu ) ;
rlc _tx - > get_last_sdu ( out_pdu ) ;
logger . debug ( out_pdu - > msg , out_pdu - > N_bytes , " Status PDU: " ) ;
logger . debug ( out_pdu - > msg , out_pdu - > N_bytes , " Status PDU: " ) ;
// Check status PDU
// Check status PDU
/*
/*
* | D / C | TYPE | FMS | - > | 0 | 0 | 0001 |
* | D / C | TYPE | FMS | - > | 0 | 0 | 0001 |
* | FMS | - > | 00000001 |
* | FMS | - > | 00000001 |
* | bitmap | - > | 11000000 |
* | bitmap | - > | 01111111 |
* | bitmap ( cont . ) | - > | 00000011 |
* | bitmap ( cont . ) | - > | 00000011 |
*/
*/
TESTASSERT ( out_pdu - > N_bytes = = 4 ) ;
TESTASSERT ( out_pdu - > N_bytes = = 4 ) ;
TESTASSERT ( out_pdu - > msg [ 0 ] = = 0b00000001 ) ;
TESTASSERT ( out_pdu - > msg [ 0 ] = = 0b00000001 ) ; // FMS = 257
TESTASSERT ( out_pdu - > msg [ 1 ] = = 0b00000001 ) ;
TESTASSERT ( out_pdu - > msg [ 1 ] = = 0b00000001 ) ;
TESTASSERT ( out_pdu - > msg [ 2 ] = = 0b 10000000) ;
TESTASSERT ( out_pdu - > msg [ 2 ] = = 0b 01111111) ; // FMS + 1 is missing
TESTASSERT ( out_pdu - > msg [ 3 ] = = 0b 00000110) ;
TESTASSERT ( out_pdu - > msg [ 3 ] = = 0b 11111000) ; //
return 0 ;
return 0 ;
}
}
@ -97,7 +121,7 @@ int test_tx_status_report(const srslte::pdcp_lte_state_t& init_state, srslog::ba
*/
*/
int test_tx_wraparound_status_report ( const srslte : : pdcp_lte_state_t & init_state , srslog : : basic_logger & logger )
int test_tx_wraparound_status_report ( const srslte : : pdcp_lte_state_t & init_state , srslog : : basic_logger & logger )
{
{
srslte : : pdcp_config_t cfg = { 1 ,
srslte : : pdcp_config_t cfg _tx = { 1 ,
srslte : : PDCP_RB_IS_DRB ,
srslte : : PDCP_RB_IS_DRB ,
srslte : : SECURITY_DIRECTION_UPLINK ,
srslte : : SECURITY_DIRECTION_UPLINK ,
srslte : : SECURITY_DIRECTION_DOWNLINK ,
srslte : : SECURITY_DIRECTION_DOWNLINK ,
@ -106,28 +130,48 @@ int test_tx_wraparound_status_report(const srslte::pdcp_lte_state_t& init_state,
srslte : : pdcp_discard_timer_t : : ms500 ,
srslte : : pdcp_discard_timer_t : : ms500 ,
true } ;
true } ;
pdcp_lte_test_helper pdcp_hlp ( cfg , sec_cfg , logger ) ;
srslte : : pdcp_config_t cfg_rx = { 1 ,
srslte : : pdcp_entity_lte * pdcp = & pdcp_hlp . pdcp ;
srslte : : PDCP_RB_IS_DRB ,
rlc_dummy * rlc = & pdcp_hlp . rlc ;
srslte : : SECURITY_DIRECTION_DOWNLINK ,
srsue : : stack_test_dummy * stack = & pdcp_hlp . stack ;
srslte : : SECURITY_DIRECTION_UPLINK ,
srslte : : PDCP_SN_LEN_12 ,
srslte : : pdcp_t_reordering_t : : ms500 ,
srslte : : pdcp_discard_timer_t : : ms500 ,
true } ;
// Setup TX
pdcp_lte_test_helper pdcp_hlp_tx ( cfg_tx , sec_cfg , logger ) ;
srslte : : pdcp_entity_lte * pdcp_tx = & pdcp_hlp_tx . pdcp ;
rlc_dummy * rlc_tx = & pdcp_hlp_tx . rlc ;
srsue : : stack_test_dummy * stack_tx = & pdcp_hlp_tx . stack ;
pdcp_hlp_tx . set_pdcp_initial_state ( init_state ) ;
// Setup RX
pdcp_lte_test_helper pdcp_hlp_rx ( cfg_tx , sec_cfg , logger ) ;
srslte : : pdcp_entity_lte * pdcp_rx = & pdcp_hlp_tx . pdcp ;
rlc_dummy * rlc_rx = & pdcp_hlp_tx . rlc ;
srsue : : stack_test_dummy * stack_rx = & pdcp_hlp_tx . stack ;
pdcp_hlp_rx . set_pdcp_initial_state ( init_state ) ;
pdcp_hlp . set_pdcp_initial_state ( init_state ) ;
srslte : : unique_byte_buffer_t out_pdu = srslte : : make_byte_buffer ( ) ;
srslte : : unique_byte_buffer_t out_pdu = srslte : : make_byte_buffer ( ) ;
// Write 256 SDUs and notify imediatly -> FMS 1111 1111 0000
// Write 256 SDUs and notify imediatly -> FMS 1111 1111 0000
for ( uint32_t i = 0 ; i < 4080 ; i + + ) {
for ( uint32_t i = 0 ; i < 4080 ; i + + ) {
srslte : : unique_byte_buffer_t sdu = srslte : : make_byte_buffer ( ) ;
srslte : : unique_byte_buffer_t sdu = srslte : : make_byte_buffer ( ) ;
srslte : : unique_byte_buffer_t pdu = srslte : : make_byte_buffer ( ) ;
sdu - > append_bytes ( sdu1 , sizeof ( sdu1 ) ) ;
sdu - > append_bytes ( sdu1 , sizeof ( sdu1 ) ) ;
pdcp - > write_sdu ( std : : move ( sdu ) ) ;
pdcp_tx - > write_sdu ( std : : move ( sdu ) ) ;
pdcp - > notify_delivery ( { i } ) ;
pdcp_tx - > notify_delivery ( { i } ) ;
rlc_tx - > get_last_sdu ( pdu ) ;
pdcp_rx - > write_pdu ( std : : move ( pdu ) ) ;
}
}
// Check undelivered SDUs queue size
// Check undelivered SDUs queue size
TESTASSERT ( pdcp - > nof_discard_timers ( ) = = 0 ) ; // 0 timers should be running
TESTASSERT ( pdcp _tx - > nof_discard_timers ( ) = = 0 ) ; // 0 timers should be running
// Generate the status report
// Generate the status report
pdcp - > send_status_report ( ) ;
pdcp _rx - > send_status_report ( ) ;
rlc - > get_last_sdu ( out_pdu ) ;
rlc _rx - > get_last_sdu ( out_pdu ) ;
logger . debug ( out_pdu - > msg , out_pdu - > N_bytes , " Status PDU: " ) ;
logger . debug ( out_pdu - > msg , out_pdu - > N_bytes , " Status PDU: " ) ;
// Check status PDU
// Check status PDU
@ -142,19 +186,22 @@ int test_tx_wraparound_status_report(const srslte::pdcp_lte_state_t& init_state,
// Write another 32 SDUs but don't notify SN=4080, SN=4081, SN=14 and SN=15
// Write another 32 SDUs but don't notify SN=4080, SN=4081, SN=14 and SN=15
for ( uint32_t i = 4080 ; i < 4112 ; i + + ) {
for ( uint32_t i = 4080 ; i < 4112 ; i + + ) {
srslte : : unique_byte_buffer_t sdu = srslte : : make_byte_buffer ( ) ;
srslte : : unique_byte_buffer_t sdu = srslte : : make_byte_buffer ( ) ;
srslte : : unique_byte_buffer_t pdu = srslte : : make_byte_buffer ( ) ;
sdu - > append_bytes ( sdu1 , sizeof ( sdu1 ) ) ;
sdu - > append_bytes ( sdu1 , sizeof ( sdu1 ) ) ;
pdcp - > write_sdu ( std : : move ( sdu ) ) ;
pdcp _tx - > write_sdu ( std : : move ( sdu ) ) ;
if ( i ! = 4080 & & i ! = 4081 & & i ! = 4110 & & i ! = 4111 ) {
if ( i ! = 4080 & & i ! = 4081 & & i ! = 4110 & & i ! = 4111 ) {
pdcp - > notify_delivery ( { i % 4096 } ) ;
pdcp_tx - > notify_delivery ( { i % 4096 } ) ;
rlc_tx - > get_last_sdu ( pdu ) ;
pdcp_rx - > write_pdu ( std : : move ( pdu ) ) ;
}
}
}
}
// Check undelivered SDUs queue size
// Check undelivered SDUs queue size
TESTASSERT ( pdcp - > nof_discard_timers ( ) = = 4 ) ;
TESTASSERT ( pdcp _tx - > nof_discard_timers ( ) = = 4 ) ;
// Generate the status report
// Generate the status report
pdcp - > send_status_report ( ) ;
pdcp _rx - > send_status_report ( ) ;
rlc - > get_last_sdu ( out_pdu ) ;
rlc _rx - > get_last_sdu ( out_pdu ) ;
logger . debug ( out_pdu - > msg , out_pdu - > N_bytes , " Status PDU: " ) ;
logger . debug ( out_pdu - > msg , out_pdu - > N_bytes , " Status PDU: " ) ;
// Check status PDU
// Check status PDU
@ -167,10 +214,10 @@ int test_tx_wraparound_status_report(const srslte::pdcp_lte_state_t& init_state,
TESTASSERT ( out_pdu - > N_bytes = = 6 ) ;
TESTASSERT ( out_pdu - > N_bytes = = 6 ) ;
TESTASSERT ( out_pdu - > msg [ 0 ] = = 0b00001111 ) ;
TESTASSERT ( out_pdu - > msg [ 0 ] = = 0b00001111 ) ;
TESTASSERT ( out_pdu - > msg [ 1 ] = = 0b11110000 ) ;
TESTASSERT ( out_pdu - > msg [ 1 ] = = 0b11110000 ) ;
TESTASSERT ( out_pdu - > msg [ 2 ] = = 0b 1000000 0) ;
TESTASSERT ( out_pdu - > msg [ 2 ] = = 0b 01111111 ) ;
TESTASSERT ( out_pdu - > msg [ 3 ] = = 0b 00000000 ) ;
TESTASSERT ( out_pdu - > msg [ 3 ] = = 0b 11111111 ) ;
TESTASSERT ( out_pdu - > msg [ 4 ] = = 0b 00000000 ) ;
TESTASSERT ( out_pdu - > msg [ 4 ] = = 0b 11111111 ) ;
TESTASSERT ( out_pdu - > msg [ 5 ] = = 0b 00000 110) ;
TESTASSERT ( out_pdu - > msg [ 5 ] = = 0b 1111100 0) ;
return 0 ;
return 0 ;
}
}
/*
/*
@ -233,20 +280,6 @@ int test_rx_status_report(const srslte::pdcp_lte_state_t& init_state, srslog::ba
pdcp - > write_pdu ( std : : move ( status_pdu ) ) ;
pdcp - > write_pdu ( std : : move ( status_pdu ) ) ;
TESTASSERT ( pdcp - > nof_discard_timers ( ) = = 1 ) ;
TESTASSERT ( pdcp - > nof_discard_timers ( ) = = 1 ) ;
// Check if the SDUs were correctly discarded with the status report
pdcp - > send_status_report ( ) ;
rlc - > get_last_sdu ( out_pdu ) ;
logger . debug ( out_pdu - > msg , out_pdu - > N_bytes , " Status PDU: " ) ;
// Check status PDU, only 271 is missing => FMS = 271
/*
* | D / C | TYPE | FMS | - > | 0 | 0 | 0001 |
* | FMS | - > | 00001111 |
*/
TESTASSERT ( out_pdu - > N_bytes = = 3 ) ;
TESTASSERT ( out_pdu - > msg [ 0 ] = = 0b00000001 ) ;
TESTASSERT ( out_pdu - > msg [ 1 ] = = 0b00001111 ) ;
return 0 ;
return 0 ;
}
}
@ -259,7 +292,8 @@ int run_all_tests()
logger . set_hex_dump_max_size ( 128 ) ;
logger . set_hex_dump_max_size ( 128 ) ;
// This is the normal initial state. All state variables are set to zero
// This is the normal initial state. All state variables are set to zero
srslte : : pdcp_lte_state_t normal_init_state = { } ;
srslte : : pdcp_lte_state_t normal_init_state = {
. next_pdcp_tx_sn = 0 , . tx_hfn = 0 , . rx_hfn = 0 , . next_pdcp_rx_sn = 0 , . last_submitted_pdcp_rx_sn = 4095 } ;
TESTASSERT ( test_tx_status_report ( normal_init_state , logger ) = = 0 ) ;
TESTASSERT ( test_tx_status_report ( normal_init_state , logger ) = = 0 ) ;
TESTASSERT ( test_tx_wraparound_status_report ( normal_init_state , logger ) = = 0 ) ;
TESTASSERT ( test_tx_wraparound_status_report ( normal_init_state , logger ) = = 0 ) ;