Commit bad4b794 authored by Xenofon Foukas's avatar Xenofon Foukas

Fixed bug when delegating control when delegated lib was previously NULL

parent 673ef5fa
...@@ -579,25 +579,25 @@ int parse_mac_config(mid_t mod_id, yaml_parser_t *parser) { ...@@ -579,25 +579,25 @@ int parse_mac_config(mid_t mod_id, yaml_parser_t *parser) {
switch (event.type) { switch (event.type) {
case YAML_SEQUENCE_START_EVENT: case YAML_SEQUENCE_START_EVENT:
LOG_I(ENB_APP, "A sequence just started as expected\n"); LOG_D(ENB_APP, "A sequence just started as expected\n");
sequence_started = 1; sequence_started = 1;
break; break;
case YAML_SEQUENCE_END_EVENT: case YAML_SEQUENCE_END_EVENT:
LOG_I(ENB_APP, "A sequence ended\n"); LOG_D(ENB_APP, "A sequence ended\n");
sequence_started = 0; sequence_started = 0;
break; break;
case YAML_MAPPING_START_EVENT: case YAML_MAPPING_START_EVENT:
if (!sequence_started) { if (!sequence_started) {
goto error; goto error;
} }
LOG_I(ENB_APP, "A mapping started\n"); LOG_D(ENB_APP, "A mapping started\n");
mapping_started = 1; mapping_started = 1;
break; break;
case YAML_MAPPING_END_EVENT: case YAML_MAPPING_END_EVENT:
if (!mapping_started) { if (!mapping_started) {
goto error; goto error;
} }
LOG_I(ENB_APP, "A mapping ended\n"); LOG_D(ENB_APP, "A mapping ended\n");
mapping_started = 0; mapping_started = 0;
break; break;
case YAML_SCALAR_EVENT: case YAML_SCALAR_EVENT:
...@@ -606,15 +606,15 @@ int parse_mac_config(mid_t mod_id, yaml_parser_t *parser) { ...@@ -606,15 +606,15 @@ int parse_mac_config(mid_t mod_id, yaml_parser_t *parser) {
} }
// Check the types of subsystems offered and handle their values accordingly // Check the types of subsystems offered and handle their values accordingly
if (strcmp(event.data.scalar.value, "dl_scheduler") == 0) { if (strcmp(event.data.scalar.value, "dl_scheduler") == 0) {
LOG_I(ENB_APP, "This is for the dl_scheduler subsystem\n"); LOG_D(ENB_APP, "This is for the dl_scheduler subsystem\n");
// Call the proper handler // Call the proper handler
if (parse_dl_scheduler_config(mod_id, parser) == -1) { if (parse_dl_scheduler_config(mod_id, parser) == -1) {
LOG_I(ENB_APP, "An error occured\n"); LOG_D(ENB_APP, "An error occured\n");
goto error; goto error;
} }
} else if (strcmp(event.data.scalar.value, "ul_scheduler") == 0) { } else if (strcmp(event.data.scalar.value, "ul_scheduler") == 0) {
// Call the proper handler // Call the proper handler
LOG_I(ENB_APP, "This is for the ul_scheduler subsystem\n"); LOG_D(ENB_APP, "This is for the ul_scheduler subsystem\n");
goto error; goto error;
// TODO // TODO
} else if (strcmp(event.data.scalar.value, "ra_scheduler") == 0) { } else if (strcmp(event.data.scalar.value, "ra_scheduler") == 0) {
...@@ -674,7 +674,7 @@ int parse_dl_scheduler_config(mid_t mod_id, yaml_parser_t *parser) { ...@@ -674,7 +674,7 @@ int parse_dl_scheduler_config(mid_t mod_id, yaml_parser_t *parser) {
} }
// Check what key needs to be set // Check what key needs to be set
if (strcmp(event.data.scalar.value, "behavior") == 0) { if (strcmp(event.data.scalar.value, "behavior") == 0) {
LOG_D(ENB_APP, "Time to set the behavior attribute\n"); LOG_I(ENB_APP, "Time to set the behavior attribute\n");
yaml_event_delete(&event); yaml_event_delete(&event);
if (!yaml_parser_parse(parser, &event)) { if (!yaml_parser_parse(parser, &event)) {
goto error; goto error;
...@@ -768,7 +768,7 @@ int load_dl_scheduler_function(mid_t mod_id, const char *function_name) { ...@@ -768,7 +768,7 @@ int load_dl_scheduler_function(mid_t mod_id, const char *function_name) {
char lib_name[120]; char lib_name[120];
char target[512]; char target[512];
sprintf(lib_name, sizeof(lib_name), "/%s.so", function_name); snprintf(lib_name, sizeof(lib_name), "/%s.so", function_name);
strcpy(target, local_cache); strcpy(target, local_cache);
strcat(target, lib_name); strcat(target, lib_name);
...@@ -781,7 +781,9 @@ int load_dl_scheduler_function(mid_t mod_id, const char *function_name) { ...@@ -781,7 +781,9 @@ int load_dl_scheduler_function(mid_t mod_id, const char *function_name) {
if (loaded_scheduler) { if (loaded_scheduler) {
if (mac_agent_registered[mod_id]) { if (mac_agent_registered[mod_id]) {
agent_mac_xface[mod_id]->enb_agent_schedule_ue_spec = loaded_scheduler; agent_mac_xface[mod_id]->enb_agent_schedule_ue_spec = loaded_scheduler;
if (agent_mac_xface[mod_id]->dl_scheduler_loaded_lib != NULL) {
dlclose(agent_mac_xface[mod_id]->dl_scheduler_loaded_lib); dlclose(agent_mac_xface[mod_id]->dl_scheduler_loaded_lib);
}
agent_mac_xface[mod_id]->dl_scheduler_loaded_lib = lib; agent_mac_xface[mod_id]->dl_scheduler_loaded_lib = lib;
LOG_D(ENB_APP, "Delegated control for DL UE scheduler succesfully\n"); LOG_D(ENB_APP, "Delegated control for DL UE scheduler succesfully\n");
} }
......
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