mirror of https://github.com/PentHertz/srsLTE.git
Merge branch 'master' into next
This commit is contained in:
commit
860d8af911
|
@ -42,6 +42,11 @@
|
|||
#include <fstream>
|
||||
#include <map>
|
||||
|
||||
#define LTE_FDD_ENB_IND_HE_N_BITS 5
|
||||
#define LTE_FDD_ENB_IND_HE_MASK 0x1FUL
|
||||
#define LTE_FDD_ENB_IND_HE_MAX_VALUE 31
|
||||
#define LTE_FDD_ENB_SEQ_HE_MAX_VALUE 0x07FFFFFFFFFFUL
|
||||
|
||||
namespace srsepc{
|
||||
|
||||
typedef struct{
|
||||
|
@ -106,6 +111,7 @@ private:
|
|||
void get_uint_vec_from_hex_str(const std::string &key_str, uint8_t *key, uint len);
|
||||
|
||||
void increment_ue_sqn(uint64_t imsi);
|
||||
void increment_seq_after_resync(uint64_t imsi);
|
||||
void increment_sqn(uint8_t *sqn, uint8_t *next_sqn);
|
||||
void set_sqn(uint64_t imsi, uint8_t *sqn);
|
||||
|
||||
|
|
|
@ -532,7 +532,7 @@ hss::resync_sqn(uint64_t imsi, uint8_t *auts)
|
|||
ret = resync_sqn_milenage(imsi, auts);
|
||||
break;
|
||||
}
|
||||
increment_ue_sqn(imsi);
|
||||
increment_seq_after_resync(imsi);
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
@ -625,21 +625,86 @@ hss::increment_ue_sqn(uint64_t imsi)
|
|||
void
|
||||
hss::increment_sqn(uint8_t *sqn, uint8_t *next_sqn)
|
||||
{
|
||||
// Awkward 48 bit sqn and doing arithmetic
|
||||
uint64_t tmp_sqn = 0;
|
||||
uint8_t *p = (uint8_t *)&tmp_sqn;
|
||||
// The following SQN incrementation function is implemented according to 3GPP TS 33.102 version 11.5.1 Annex C
|
||||
|
||||
for(int i = 0; i < 6; i++) {
|
||||
p[5-i] = sqn[i];
|
||||
uint64_t seq;
|
||||
uint64_t ind;
|
||||
uint64_t sqn64;
|
||||
|
||||
sqn64 =0;
|
||||
|
||||
for(int i=0; i<6; i++)
|
||||
{
|
||||
sqn64 |= (uint64_t)sqn[i] << (5-i)*8;
|
||||
}
|
||||
|
||||
tmp_sqn++;
|
||||
for(int i = 0; i < 6; i++){
|
||||
next_sqn[i] = p[5-i];
|
||||
seq = sqn64 >> LTE_FDD_ENB_IND_HE_N_BITS;
|
||||
ind = sqn64 & LTE_FDD_ENB_IND_HE_MASK;
|
||||
|
||||
uint64_t nextseq;
|
||||
uint64_t nextind;
|
||||
uint64_t nextsqn;
|
||||
|
||||
nextseq = (seq + 1) % LTE_FDD_ENB_SEQ_HE_MAX_VALUE;
|
||||
nextind = (ind + 1) % LTE_FDD_ENB_IND_HE_MAX_VALUE;
|
||||
nextsqn = (nextseq << LTE_FDD_ENB_IND_HE_N_BITS) | nextind;
|
||||
|
||||
for(int i=0; i<6; i++)
|
||||
{
|
||||
next_sqn[i] = (nextsqn >> (5-i)*8) & 0xFF;
|
||||
}
|
||||
|
||||
return;
|
||||
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
hss::increment_seq_after_resync(uint64_t imsi)
|
||||
{
|
||||
|
||||
// This function only increment the SEQ part of the SQN for resynchronization purpose
|
||||
|
||||
hss_ue_ctx_t *ue_ctx = NULL;
|
||||
bool ret = get_ue_ctx(imsi, &ue_ctx);
|
||||
if(ret == false)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
uint8_t *sqn = ue_ctx->sqn;
|
||||
|
||||
uint64_t seq;
|
||||
uint64_t ind;
|
||||
uint64_t sqn64;
|
||||
|
||||
sqn64 =0;
|
||||
|
||||
for(int i=0; i<6; i++)
|
||||
{
|
||||
sqn64 |= (uint64_t)sqn[i] << (5-i)*8;
|
||||
}
|
||||
|
||||
seq = sqn64 >> LTE_FDD_ENB_IND_HE_N_BITS;
|
||||
ind = sqn64 & LTE_FDD_ENB_IND_HE_MASK;
|
||||
|
||||
uint64_t nextseq;
|
||||
uint64_t nextsqn;
|
||||
|
||||
nextseq = (seq + 1) % LTE_FDD_ENB_SEQ_HE_MAX_VALUE;
|
||||
nextsqn = (nextseq << LTE_FDD_ENB_IND_HE_N_BITS) | ind;
|
||||
|
||||
for(int i=0; i<6; i++)
|
||||
{
|
||||
sqn[i] = (nextsqn >> (5-i)*8) & 0xFF;
|
||||
}
|
||||
|
||||
return;
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
void
|
||||
hss::set_sqn(uint64_t imsi, uint8_t *sqn)
|
||||
{
|
||||
|
|
Loading…
Reference in New Issue