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
常顺宇
OpenXG-RAN
Commits
83e1dc9e
Commit
83e1dc9e
authored
Jul 13, 2016
by
Frédéric Leroy
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
UE: move _nas_user_nvdata to nas_user_t
parent
9a33bca2
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
23 additions
and
26 deletions
+23
-26
openair3/NAS/UE/nas_user.c
openair3/NAS/UE/nas_user.c
+20
-26
openair3/NAS/UE/user_defs.h
openair3/NAS/UE/user_defs.h
+3
-0
No files found.
openair3/NAS/UE/nas_user.c
View file @
83e1dc9e
...
@@ -134,13 +134,6 @@ static const char *_nas_user_sim_status_str[] = {
...
@@ -134,13 +134,6 @@ static const char *_nas_user_sim_status_str[] = {
"PH-SIM PIN"
"PH-SIM PIN"
};
};
/*
* ---------------------------------------------------------------------
* UE parameters stored in the UE's non-volatile memory device
* ---------------------------------------------------------------------
*/
static
user_nvdata_t
_nas_user_nvdata
;
/****************************************************************************/
/****************************************************************************/
/****************** E X P O R T E D F U N C T I O N S ******************/
/****************** E X P O R T E D F U N C T I O N S ******************/
/****************************************************************************/
/****************************************************************************/
...
@@ -164,7 +157,6 @@ void _nas_user_context_initialize(nas_user_context_t *nas_user_context, const ch
...
@@ -164,7 +157,6 @@ void _nas_user_context_initialize(nas_user_context_t *nas_user_context, const ch
** **
** **
** Outputs: None **
** Outputs: None **
** Return: None **
** Return: None **
** Others: _nas_user_nvdata, _nas_user_context **
** **
** **
***************************************************************************/
***************************************************************************/
void
nas_user_initialize
(
nas_user_t
*
user
,
emm_indication_callback_t
emm_cb
,
void
nas_user_initialize
(
nas_user_t
*
user
,
emm_indication_callback_t
emm_cb
,
...
@@ -172,33 +164,39 @@ void nas_user_initialize(nas_user_t *user, emm_indication_callback_t emm_cb,
...
@@ -172,33 +164,39 @@ void nas_user_initialize(nas_user_t *user, emm_indication_callback_t emm_cb,
{
{
LOG_FUNC_IN
;
LOG_FUNC_IN
;
user
->
nas_user_nvdata
=
calloc
(
1
,
sizeof
(
user_nvdata_t
));
if
(
user
->
nas_user_nvdata
==
NULL
)
{
LOG_TRACE
(
ERROR
,
"USR-MAIN - Failed to alloc nas_user_nvdata"
);
// FIXME stop here
return
;
}
/* Get UE's data pathname */
/* Get UE's data pathname */
char
*
path
=
memory_get_path
(
USER_NVRAM_DIRNAME
,
USER_NVRAM_FILENAME
);
char
*
path
=
memory_get_path
(
USER_NVRAM_DIRNAME
,
USER_NVRAM_FILENAME
);
if
(
path
==
NULL
)
{
if
(
path
==
NULL
)
{
LOG_TRACE
(
ERROR
,
"USR-MAIN - Failed to get UE's data pathname"
);
LOG_TRACE
(
ERROR
,
"USR-MAIN - Failed to get UE's data pathname"
);
// FIXME return an error code or exit
return
;
}
}
/* Get UE data stored in the non-volatile memory device */
/* Get UE data stored in the non-volatile memory device */
else
{
int
rc
=
memory_read
(
path
,
user
->
nas_user_nvdata
,
sizeof
(
user_nvdata_t
));
int
rc
=
memory_read
(
path
,
&
_nas_user_nvdata
,
sizeof
(
user_nvdata_t
));
if
(
rc
!=
RETURNok
)
{
if
(
rc
!=
RETURNok
)
{
LOG_TRACE
(
ERROR
,
"USR-MAIN - Failed to read %s"
,
path
);
LOG_TRACE
(
ERROR
,
"USR-MAIN - Failed to read %s"
,
path
);
}
}
free
(
path
);
free
(
path
);
}
user
->
nas_user_context
=
calloc
(
1
,
sizeof
(
nas_user_context_t
));
user
->
nas_user_context
=
calloc
(
1
,
sizeof
(
nas_user_context_t
));
if
(
user
->
nas_user_context
==
NULL
)
{
if
(
user
->
nas_user_context
==
NULL
)
{
LOG_TRACE
(
ERROR
,
"USR-MAIN - Failed to alloc nas_user_context"
);
LOG_TRACE
(
ERROR
,
"USR-MAIN - Failed to alloc nas_user_context"
);
// FIXME stop here
// FIXME stop here
return
;
}
}
_nas_user_context_initialize
(
user
->
nas_user_context
,
version
);
_nas_user_context_initialize
(
user
->
nas_user_context
,
version
);
/* Initialize the internal NAS processing data */
/* Initialize the internal NAS processing data */
nas_proc_initialize
(
user
,
emm_cb
,
esm_cb
,
_nas_user_nvdata
.
IMEI
);
nas_proc_initialize
(
user
,
emm_cb
,
esm_cb
,
user
->
nas_user_nvdata
->
IMEI
);
LOG_FUNC_OUT
;
LOG_FUNC_OUT
;
}
}
...
@@ -395,7 +393,6 @@ const void *nas_user_get_data(void)
...
@@ -395,7 +393,6 @@ const void *nas_user_get_data(void)
** ning the IMEI. **
** ning the IMEI. **
** **
** **
** Inputs: data: Pointer to the AT command data structure **
** Inputs: data: Pointer to the AT command data structure **
** Others: _nas_user_nvdata **
** **
** **
** Outputs: None **
** Outputs: None **
** Return: RETURNok; RETURNerror; **
** Return: RETURNok; RETURNerror; **
...
@@ -418,7 +415,7 @@ static int _nas_user_proc_cgsn(nas_user_t *user, const at_command_t *data)
...
@@ -418,7 +415,7 @@ static int _nas_user_proc_cgsn(nas_user_t *user, const at_command_t *data)
switch
(
data
->
type
)
{
switch
(
data
->
type
)
{
case
AT_COMMAND_ACT
:
case
AT_COMMAND_ACT
:
/* Get the Product Serial Number Identification (IMEI) */
/* Get the Product Serial Number Identification (IMEI) */
strncpy
(
cgsn
->
sn
,
_nas_user_nvdata
.
IMEI
,
strncpy
(
cgsn
->
sn
,
user
->
nas_user_nvdata
->
IMEI
,
AT_RESPONSE_INFO_TEXT_SIZE
);
AT_RESPONSE_INFO_TEXT_SIZE
);
break
;
break
;
...
@@ -447,7 +444,6 @@ static int _nas_user_proc_cgsn(nas_user_t *user, const at_command_t *data)
...
@@ -447,7 +444,6 @@ static int _nas_user_proc_cgsn(nas_user_t *user, const at_command_t *data)
** le Equipment to which it is connected to. **
** le Equipment to which it is connected to. **
** **
** **
** Inputs: data: Pointer to the AT command data structure **
** Inputs: data: Pointer to the AT command data structure **
** Others: _nas_user_nvdata **
** **
** **
** Outputs: None **
** Outputs: None **
** Return: RETURNok; RETURNerror; **
** Return: RETURNok; RETURNerror; **
...
@@ -470,7 +466,7 @@ static int _nas_user_proc_cgmi(nas_user_t *user, const at_command_t *data)
...
@@ -470,7 +466,7 @@ static int _nas_user_proc_cgmi(nas_user_t *user, const at_command_t *data)
switch
(
data
->
type
)
{
switch
(
data
->
type
)
{
case
AT_COMMAND_ACT
:
case
AT_COMMAND_ACT
:
/* Get the Manufacturer identifier */
/* Get the Manufacturer identifier */
strncpy
(
cgmi
->
manufacturer
,
_nas_user_nvdata
.
manufacturer
,
strncpy
(
cgmi
->
manufacturer
,
user
->
nas_user_nvdata
->
manufacturer
,
AT_RESPONSE_INFO_TEXT_SIZE
);
AT_RESPONSE_INFO_TEXT_SIZE
);
break
;
break
;
...
@@ -499,7 +495,6 @@ static int _nas_user_proc_cgmi(nas_user_t *user, const at_command_t *data)
...
@@ -499,7 +495,6 @@ static int _nas_user_proc_cgmi(nas_user_t *user, const at_command_t *data)
** Equipment to which it is connected to. **
** Equipment to which it is connected to. **
** **
** **
** Inputs: data: Pointer to the AT command data structure **
** Inputs: data: Pointer to the AT command data structure **
** Others: _nas_user_nvdata **
** **
** **
** Outputs: None **
** Outputs: None **
** Return: RETURNok; RETURNerror; **
** Return: RETURNok; RETURNerror; **
...
@@ -522,7 +517,7 @@ static int _nas_user_proc_cgmm(nas_user_t *user, const at_command_t *data)
...
@@ -522,7 +517,7 @@ static int _nas_user_proc_cgmm(nas_user_t *user, const at_command_t *data)
switch
(
data
->
type
)
{
switch
(
data
->
type
)
{
case
AT_COMMAND_ACT
:
case
AT_COMMAND_ACT
:
/* Get the Model identifier */
/* Get the Model identifier */
strncpy
(
cgmm
->
model
,
_nas_user_nvdata
.
model
,
strncpy
(
cgmm
->
model
,
user
->
nas_user_nvdata
->
model
,
AT_RESPONSE_INFO_TEXT_SIZE
);
AT_RESPONSE_INFO_TEXT_SIZE
);
break
;
break
;
...
@@ -609,7 +604,6 @@ static int _nas_user_proc_cgmr(nas_user_t *user, const at_command_t *data)
...
@@ -609,7 +604,6 @@ static int _nas_user_proc_cgmr(nas_user_t *user, const at_command_t *data)
** ning the IMSI. **
** ning the IMSI. **
** **
** **
** Inputs: data: Pointer to the AT command data structure **
** Inputs: data: Pointer to the AT command data structure **
** Others: _nas_user_nvdata **
** **
** **
** Outputs: None **
** Outputs: None **
** Return: RETURNok; RETURNerror; **
** Return: RETURNok; RETURNerror; **
...
@@ -815,7 +809,7 @@ static int _nas_user_proc_cpin(nas_user_t *user, const at_command_t *data)
...
@@ -815,7 +809,7 @@ static int _nas_user_proc_cpin(nas_user_t *user, const at_command_t *data)
*/
*/
if
(
nas_user_context
->
sim_status
==
NAS_USER_SIM_PIN
)
{
if
(
nas_user_context
->
sim_status
==
NAS_USER_SIM_PIN
)
{
/* The MT is waiting for PIN password; check the PIN code */
/* The MT is waiting for PIN password; check the PIN code */
if
(
strncmp
(
_nas_user_nvdata
.
PIN
,
if
(
strncmp
(
user
->
nas_user_nvdata
->
PIN
,
data
->
command
.
cpin
.
pin
,
USER_PIN_SIZE
)
!=
0
)
{
data
->
command
.
cpin
.
pin
,
USER_PIN_SIZE
)
!=
0
)
{
/* The PIN code is NOT matching; return an error message */
/* The PIN code is NOT matching; return an error message */
LOG_TRACE
(
ERROR
,
"USR-MAIN - PIN code is not correct "
LOG_TRACE
(
ERROR
,
"USR-MAIN - PIN code is not correct "
...
@@ -2374,7 +2368,7 @@ static int _nas_user_proc_clck(nas_user_t *user, const at_command_t *data)
...
@@ -2374,7 +2368,7 @@ static int _nas_user_proc_clck(nas_user_t *user, const at_command_t *data)
/* Check password parameter */
/* Check password parameter */
if
(
data
->
mask
&
AT_CLCK_PASSWD_MASK
)
{
if
(
data
->
mask
&
AT_CLCK_PASSWD_MASK
)
{
/* Check the PIN code */
/* Check the PIN code */
if
(
strncmp
(
_nas_user_nvdata
.
PIN
,
if
(
strncmp
(
user
->
nas_user_nvdata
->
PIN
,
data
->
command
.
clck
.
passwd
,
USER_PIN_SIZE
)
!=
0
)
{
data
->
command
.
clck
.
passwd
,
USER_PIN_SIZE
)
!=
0
)
{
/* The PIN code is NOT matching; return an error message */
/* The PIN code is NOT matching; return an error message */
LOG_TRACE
(
ERROR
,
"USR-MAIN - Password is not correct "
LOG_TRACE
(
ERROR
,
"USR-MAIN - Password is not correct "
...
...
openair3/NAS/UE/user_defs.h
View file @
83e1dc9e
...
@@ -54,6 +54,7 @@ Description NAS type definition to manage a user equipment
...
@@ -54,6 +54,7 @@ Description NAS type definition to manage a user equipment
#include "EMM/IdleMode_defs.h"
#include "EMM/IdleMode_defs.h"
#include "API/USIM/usim_api.h"
#include "API/USIM/usim_api.h"
#include "SecurityModeControl.h"
#include "SecurityModeControl.h"
#include "userDef.h"
typedef
struct
{
typedef
struct
{
int
fd
;
int
fd
;
...
@@ -70,6 +71,8 @@ typedef struct {
...
@@ -70,6 +71,8 @@ typedef struct {
security_data_t
*
security_data
;
//Internal data used for security mode control procedure
security_data_t
*
security_data
;
//Internal data used for security mode control procedure
// Hardware persistent storage
// Hardware persistent storage
usim_data_t
usim_data
;
// USIM application data
usim_data_t
usim_data
;
// USIM application data
user_nvdata_t
*
nas_user_nvdata
;
//UE parameters stored in the UE's non-volatile memory device
//
nas_user_context_t
*
nas_user_context
;
nas_user_context_t
*
nas_user_context
;
}
nas_user_t
;
}
nas_user_t
;
...
...
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