Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
O
OpenXG-AMF
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
1
Issues
1
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
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
OpenXG
OpenXG-AMF
Commits
414f19d6
Commit
414f19d6
authored
Jan 15, 2023
by
Tien Thinh NGUYEN
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Update DNN
parent
3397bfc4
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
73 additions
and
74 deletions
+73
-74
src/nas/ies/AuthenticationResponseParameter.cpp
src/nas/ies/AuthenticationResponseParameter.cpp
+1
-1
src/nas/ies/DNN.cpp
src/nas/ies/DNN.cpp
+57
-49
src/nas/ies/DNN.hpp
src/nas/ies/DNN.hpp
+13
-22
src/nas/msgs/ULNASTransport.cpp
src/nas/msgs/ULNASTransport.cpp
+2
-2
No files found.
src/nas/ies/AuthenticationResponseParameter.cpp
View file @
414f19d6
...
...
@@ -98,7 +98,7 @@ int AuthenticationResponseParameter::Decode(
decoded_size
+=
decoded_header_size
;
// RES or RES*
uint
16
_t
ie_len
=
GetLengthIndicator
();
uint
8
_t
ie_len
=
GetLengthIndicator
();
decode_bstring
(
&
res_or_res_star_
,
ie_len
,
(
buf
+
decoded_size
),
len
-
decoded_size
);
decoded_size
+=
ie_len
;
...
...
src/nas/ies/DNN.cpp
View file @
414f19d6
...
...
@@ -19,82 +19,90 @@
* contact@openairinterface.org
*/
/*! \file
\brief
\author Keliang DU, BUPT
\date 2020
\email: contact@openairinterface.org
*/
#include "DNN.hpp"
#include "logger.hpp"
using
namespace
nas
;
//------------------------------------------------------------------------------
DNN
::
DNN
(
uint8_t
iei
)
:
_DNN
()
{
_iei
=
iei
;
length
=
0
;
DNN
::
DNN
(
)
:
Type4NasIe
(
kIeiDnn
),
_DNN
()
{
SetLengthIndicator
(
1
)
;
SetIeName
(
kDnnIeName
)
;
}
//------------------------------------------------------------------------------
DNN
::
DNN
(
const
uint8_t
iei
,
bstring
d
nn
)
{
_
iei
=
iei
;
_DNN
=
bstrcpy
(
dnn
);
length
=
blength
(
dnn
)
+
2
;
DNN
::
DNN
(
bstring
dnn
)
:
Type4NasIe
(
kIeiD
nn
)
{
_
DNN
=
bstrcpy
(
dnn
)
;
SetLengthIndicator
(
blength
(
dnn
)
);
SetIeName
(
kDnnIeName
)
;
}
//------------------------------------------------------------------------------
DNN
::
DNN
()
:
_iei
(),
_DNN
(),
length
()
{}
DNN
::
~
DNN
()
{}
//------------------------------------------------------------------------------
DNN
::~
DNN
()
{}
void
DNN
::
SetValue
(
const
bstring
&
dnn
)
{
_DNN
=
bstrcpy
(
dnn
);
}
//------------------------------------------------------------------------------
void
DNN
::
getValue
(
bstring
&
dnn
)
{
dnn
=
b
lk2bstr
((
uint8_t
*
)
bdata
(
_DNN
)
+
1
,
blength
(
_DNN
)
-
1
);
void
DNN
::
GetValue
(
bstring
&
dnn
)
const
{
dnn
=
b
strcpy
(
_DNN
);
}
//------------------------------------------------------------------------------
int
DNN
::
Encode
(
uint8_t
*
buf
,
int
len
)
{
Logger
::
nas_mm
().
debug
(
"Encoding DNN IEI (0x%x)"
,
_iei
);
if
(
len
<
length
)
{
Logger
::
nas_mm
().
error
(
"len is less than %d"
,
length
);
return
0
;
Logger
::
nas_mm
().
debug
(
"Encoding %s"
,
GetIeName
().
c_str
());
int
ie_len
=
GetIeLength
();
if
(
len
<
ie_len
)
{
Logger
::
nas_mm
().
error
(
"Len is less than %d"
,
ie_len
);
return
KEncodeDecodeError
;
}
int
encoded_size
=
0
;
if
(
_iei
)
{
*
(
buf
+
encoded_size
)
=
_iei
;
encoded_size
++
;
*
(
buf
+
encoded_size
)
=
(
length
-
2
);
encoded_size
++
;
int
size
=
encode_bstring
(
_DNN
,
(
buf
+
encoded_size
),
len
-
encoded_size
);
encoded_size
+=
size
;
}
else
{
*
(
buf
+
encoded_size
)
=
(
length
-
1
);
encoded_size
++
;
int
size
=
encode_bstring
(
_DNN
,
(
buf
+
encoded_size
),
len
-
encoded_size
);
encoded_size
+=
size
;
}
Logger
::
nas_mm
().
debug
(
"encoded DNN len: %d"
,
encoded_size
);
// IEI and Length
int
encoded_header_size
=
Type4NasIe
::
Encode
(
buf
+
encoded_size
,
len
);
if
(
encoded_header_size
==
KEncodeDecodeError
)
return
KEncodeDecodeError
;
encoded_size
+=
encoded_header_size
;
// Value
int
size
=
encode_bstring
(
_DNN
,
(
buf
+
encoded_size
),
len
-
encoded_size
);
encoded_size
+=
size
;
Logger
::
nas_mm
().
debug
(
"Encoded %s, len (%d)"
,
GetIeName
().
c_str
(),
encoded_size
);
return
encoded_size
;
}
//------------------------------------------------------------------------------
int
DNN
::
Decode
(
uint8_t
*
buf
,
int
len
,
bool
is_option
)
{
Logger
::
nas_mm
().
debug
(
"Decoding DNN IEI (0x%x)"
,
*
buf
);
int
decoded_size
=
0
;
if
(
is_option
)
{
decoded_size
++
;
int
DNN
::
Decode
(
uint8_t
*
buf
,
int
len
,
bool
is_iei
)
{
if
(
len
<
kDnnMinimumLength
)
{
Logger
::
nas_mm
().
error
(
"Buffer length is less than the minimum length of this IE (%d octet)"
,
kDnnMinimumLength
);
return
KEncodeDecodeError
;
}
length
=
*
(
buf
+
decoded_size
);
decoded_size
++
;
decode_bstring
(
&
_DNN
,
length
,
(
buf
+
decoded_size
),
len
-
decoded_size
);
decoded_size
+=
length
;
for
(
int
i
=
0
;
i
<
blength
(
_DNN
);
i
++
)
{
Logger
::
nas_mm
().
debug
(
"Decoded DNN value: 0x%x"
,
(
uint8_t
)
bdata
(
_DNN
)[
i
]);
uint8_t
decoded_size
=
0
;
uint8_t
octet
=
0
;
Logger
::
nas_mm
().
debug
(
"Decoding %s"
,
GetIeName
().
c_str
());
// IEI and Length
int
decoded_header_size
=
Type4NasIe
::
Decode
(
buf
+
decoded_size
,
len
,
is_iei
);
if
(
decoded_header_size
==
KEncodeDecodeError
)
return
KEncodeDecodeError
;
decoded_size
+=
decoded_header_size
;
// DNN
uint8_t
ie_len
=
GetLengthIndicator
();
decode_bstring
(
&
_DNN
,
ie_len
,
(
buf
+
decoded_size
),
len
-
decoded_size
);
decoded_size
+=
ie_len
;
for
(
int
i
=
0
;
i
<
ie_len
;
i
++
)
{
Logger
::
nas_mm
().
debug
(
"Decoded value 0x%x"
,
(
uint8_t
)
_DNN
->
data
[
i
]);
}
Logger
::
nas_mm
().
debug
(
"Decoded DNN len: %d"
,
decoded_size
);
Logger
::
nas_mm
().
debug
(
"Decoded %s, len (%d)"
,
GetIeName
().
c_str
(),
decoded_size
);
return
decoded_size
;
}
src/nas/ies/DNN.hpp
View file @
414f19d6
...
...
@@ -19,39 +19,30 @@
* contact@openairinterface.org
*/
/*! \file
\brief
\author Keliang DU, BUPT
\date 2020
\email: contact@openairinterface.org
*/
#ifndef __DNN_H_
#define __DNN_H_
#include <stdint.h>
#include <iostream>
extern
"C"
{
#include "TLVDecoder.h"
#include "TLVEncoder.h"
#include "bstrlib.h"
}
#include "Type4NasIe.hpp"
constexpr
uint8_t
kDnnMinimumLength
=
3
;
constexpr
uint8_t
kDnnMaximumLength
=
102
;
constexpr
auto
kDnnIeName
=
"DNN"
;
namespace
nas
{
class
DNN
{
class
DNN
:
public
Type4NasIe
{
public:
DNN
();
DNN
(
uint8_t
iei
);
DNN
(
const
uint8_t
iei
,
bstring
dnn
);
DNN
(
bstring
dnn
);
~
DNN
();
// void setValue(uint8_t iei, uint8_t value);
int
Encode
(
uint8_t
*
buf
,
int
len
);
int
Decode
(
uint8_t
*
buf
,
int
len
,
bool
is_option
);
void
getValue
(
bstring
&
dnn
);
void
SetValue
(
const
bstring
&
dnn
);
void
GetValue
(
bstring
&
dnn
)
const
;
private:
uint8_t
_iei
;
uint8_t
length
;
bstring
_DNN
;
};
...
...
src/nas/msgs/ULNASTransport.cpp
View file @
414f19d6
...
...
@@ -138,13 +138,13 @@ bool ULNASTransport::GetSNssai(SNSSAI_s& snssai) {
//------------------------------------------------------------------------------
void
ULNASTransport
::
setDNN
(
bstring
dnn
)
{
ie_dnn
=
std
::
make_optional
<
DNN
>
(
0x25
,
dnn
);
ie_dnn
=
std
::
make_optional
<
DNN
>
(
dnn
);
}
//------------------------------------------------------------------------------
bool
ULNASTransport
::
getDnn
(
bstring
&
dnn
)
{
if
(
ie_dnn
.
has_value
())
{
ie_dnn
.
value
().
g
etValue
(
dnn
);
ie_dnn
.
value
().
G
etValue
(
dnn
);
return
true
;
}
else
{
return
false
;
...
...
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