Commit e90e30a5 authored by winckel's avatar winckel

Modified NAS_UE_AUTOSTART option, an "at+cfun=1" message reception from...

Modified NAS_UE_AUTOSTART option, an "at+cfun=1" message reception from UserProcess is simulated to start NAS Ue activities.

git-svn-id: http://svn.eurecom.fr/openair4G/trunk@4809 818b1a75-f10b-46b9-bf7c-635c3b92a50f
parent b3fda596
...@@ -201,7 +201,7 @@ static void *_nas_user_mngr(void *args) ...@@ -201,7 +201,7 @@ static void *_nas_user_mngr(void *args)
/* User receiving loop */ /* User receiving loop */
while (!exit_loop) { while (!exit_loop) {
exit_loop = nas_user_receive_and_process(fd); exit_loop = nas_user_receive_and_process(fd, NULL);
} }
/* Close the connection to the user application layer */ /* Close the connection to the user application layer */
......
...@@ -212,7 +212,7 @@ void nas_user_initialize(emm_indication_callback_t emm_cb, ...@@ -212,7 +212,7 @@ void nas_user_initialize(emm_indication_callback_t emm_cb,
** Outputs: Return: FALSE, TRUE ** ** Outputs: Return: FALSE, TRUE **
** ** ** **
***************************************************************************/ ***************************************************************************/
int nas_user_receive_and_process(int * fd) int nas_user_receive_and_process(int *fd, char *message)
{ {
LOG_FUNC_IN; LOG_FUNC_IN;
...@@ -221,6 +221,10 @@ int nas_user_receive_and_process(int * fd) ...@@ -221,6 +221,10 @@ int nas_user_receive_and_process(int * fd)
int bytes; int bytes;
int i; int i;
if (message != NULL) {
/* Set the message in receive buffer (Use to simulate reception of data from UserProcess) */
bytes = user_api_set_data(message);
} else {
/* Read the user data message */ /* Read the user data message */
bytes = user_api_read_data (*fd); bytes = user_api_read_data (*fd);
if (bytes == RETURNerror) { if (bytes == RETURNerror) {
...@@ -230,6 +234,7 @@ int nas_user_receive_and_process(int * fd) ...@@ -230,6 +234,7 @@ int nas_user_receive_and_process(int * fd)
"Failed to read data from the user application layer"); "Failed to read data from the user application layer");
LOG_FUNC_RETURN(TRUE); LOG_FUNC_RETURN(TRUE);
} }
}
if (bytes == 0) { if (bytes == 0) {
/* A signal was caught before any data were available */ /* A signal was caught before any data were available */
...@@ -261,6 +266,8 @@ int nas_user_receive_and_process(int * fd) ...@@ -261,6 +266,8 @@ int nas_user_receive_and_process(int * fd)
"The user procedure call failed"); "The user procedure call failed");
} }
/* Send response to UserProcess (If not in simulated reception) */
if (message == NULL) {
/* Encode the user data message */ /* Encode the user data message */
bytes = user_api_encode_data (nas_user_get_data (), i == nb_command - 1); bytes = user_api_encode_data (nas_user_get_data (), i == nb_command - 1);
if (bytes == RETURNerror) { if (bytes == RETURNerror) {
...@@ -279,6 +286,7 @@ int nas_user_receive_and_process(int * fd) ...@@ -279,6 +286,7 @@ int nas_user_receive_and_process(int * fd)
LOG_FUNC_RETURN(TRUE); LOG_FUNC_RETURN(TRUE);
} }
} }
}
LOG_FUNC_RETURN(FALSE); LOG_FUNC_RETURN(FALSE);
} }
......
...@@ -40,7 +40,7 @@ Description NAS procedure functions triggered by the user ...@@ -40,7 +40,7 @@ Description NAS procedure functions triggered by the user
void nas_user_initialize(emm_indication_callback_t emm_cb, void nas_user_initialize(emm_indication_callback_t emm_cb,
esm_indication_callback_t esm_cb, const char *version); esm_indication_callback_t esm_cb, const char *version);
int nas_user_receive_and_process(int * fd); int nas_user_receive_and_process(int * fd, char *message);
int nas_user_process_data(const void *data); int nas_user_process_data(const void *data);
......
...@@ -58,7 +58,7 @@ static int nas_ue_process_events(struct epoll_event *events, int nb_events) ...@@ -58,7 +58,7 @@ static int nas_ue_process_events(struct epoll_event *events, int nb_events)
{ {
/* If the event has not been yet been processed (not an itti message) */ /* If the event has not been yet been processed (not an itti message) */
if (events[event].data.fd == user_fd) { if (events[event].data.fd == user_fd) {
exit_loop = nas_user_receive_and_process(&user_fd); exit_loop = nas_user_receive_and_process(&user_fd, NULL);
} else { } else {
LOG_E(NAS, "[UE] Received an event from an unknown fd %d!\n", events[event].data.fd); LOG_E(NAS, "[UE] Received an event from an unknown fd %d!\n", events[event].data.fd);
} }
...@@ -101,11 +101,7 @@ void *nas_ue_task(void *args_p) { ...@@ -101,11 +101,7 @@ void *nas_ue_task(void *args_p) {
{ {
MessageDef *message_p; MessageDef *message_p;
#if (NAS_UE_AUTOSTART == 0)
message_p = itti_alloc_new_message(TASK_NAS_UE, DEACTIVATE_MESSAGE); message_p = itti_alloc_new_message(TASK_NAS_UE, DEACTIVATE_MESSAGE);
#else
message_p = itti_alloc_new_message(TASK_NAS_UE, ACTIVATE_MESSAGE);
#endif
itti_send_msg_to_task(TASK_L2L1, instance, message_p); itti_send_msg_to_task(TASK_L2L1, instance, message_p);
} }
...@@ -122,6 +118,12 @@ void *nas_ue_task(void *args_p) { ...@@ -122,6 +118,12 @@ void *nas_ue_task(void *args_p) {
case INITIALIZE_MESSAGE: case INITIALIZE_MESSAGE:
LOG_I(NAS, "[UE %d] Received %s\n", Mod_id, msg_name); LOG_I(NAS, "[UE %d] Received %s\n", Mod_id, msg_name);
#if (NAS_UE_AUTOSTART != 0) #if (NAS_UE_AUTOSTART != 0)
{
/* Send an activate modem command to NAS like UserProcess should do it */
char *user_data = "at+cfun=1\r";
nas_user_receive_and_process (&user_fd, user_data);
}
#endif #endif
break; break;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment