Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Fix a segmentation fault at set_affinity
authorTakahiro Hirofuchi <t.hirofuchi+sg@aist.go.jp>
Thu, 7 Nov 2013 15:08:08 +0000 (16:08 +0100)
committerTakahiro Hirofuchi <t.hirofuchi+sg@aist.go.jp>
Thu, 7 Nov 2013 15:08:08 +0000 (16:08 +0100)
src/msg/msg_task.c

index f995d10..ec9a0d3 100644 (file)
@@ -512,7 +512,12 @@ void MSG_task_set_affinity(msg_task_t task, msg_host_t host, unsigned long mask)
 
   if (mask == 0) {
     /* 0 means clear */
-    xbt_dict_remove_ext(task->simdata->affinity_mask_db, (char *) host, sizeof(host));
+    {
+      /* We need remove_ext() not throwing exception. */
+      void *ret = xbt_dict_get_or_null_ext(task->simdata->affinity_mask_db, (char *) host, sizeof(msg_host_t));
+      if (ret != NULL)
+        xbt_dict_remove_ext(task->simdata->affinity_mask_db, (char *) host, sizeof(host));
+    }
   } else
     xbt_dict_set_ext(task->simdata->affinity_mask_db, (char *) host, sizeof(host), (void *) mask, NULL);