[ofa-general] [PATCHv2] opensm/osm_ucast_lash.(h c): Replace memory allocation by array

Hal Rosenstock hnrose at comcast.net
Thu Jun 18 04:31:25 PDT 2009


lash's num_mst_in_lane array is indexed by lane nuber, not by switch index.
Since it's a small number, get rid of extra memory allocation.

Signed-off-by: Robert Pearson <rpearson at systemfabricworks.com>
Signed-off-by: Hal Rosenstock <hal.rosenstock at gmail.com>
---
Changes since v1:
Fixed memset in init_lash_structures pointed out by Diego Guella
<diego.guella at sircomtech.com>

diff --git a/opensm/include/opensm/osm_ucast_lash.h b/opensm/include/opensm/osm_ucast_lash.h
index f48ea33..98034cc 100644
--- a/opensm/include/opensm/osm_ucast_lash.h
+++ b/opensm/include/opensm/osm_ucast_lash.h
@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2008      System Fabric Works, Inc.
+ * Copyright (c) 2008,2009 System Fabric Works, Inc. All rights reserved.
  * Copyright (c) 2004-2007 Voltaire, Inc. All rights reserved.
  * Copyright (c) 2002-2006 Mellanox Technologies LTD. All rights reserved.
  * Copyright (c) 1996-2003 Intel Corporation. All rights reserved.
@@ -90,7 +90,7 @@ typedef struct _lash {
 	int balance_limit;
 	switch_t **switches;
 	cdg_vertex_t ****cdg_vertex_matrix;
-	int *num_mst_in_lane;
+	int num_mst_in_lane[IB_MAX_NUM_VLS];
 	int ***virtual_location;
 } lash_t;
 
diff --git a/opensm/opensm/osm_ucast_lash.c b/opensm/opensm/osm_ucast_lash.c
index a987eb3..5913434 100644
--- a/opensm/opensm/osm_ucast_lash.c
+++ b/opensm/opensm/osm_ucast_lash.c
@@ -4,6 +4,7 @@
  * Copyright (c) 1996-2003 Intel Corporation. All rights reserved.
  * Copyright (c) 2007      Simula Research Laboratory. All rights reserved.
  * Copyright (c) 2007      Silicon Graphics Inc. All rights reserved.
+ * Copyright (c) 2008,2009 System Fabric Works, Inc. All rights reserved.
  *
  * This software is available to you under a choice of one of two
  * licenses.  You may choose to be licensed under the terms of the GNU
@@ -707,9 +708,6 @@ static void free_lash_structures(lash_t * p_lash)
 	if (p_lash->virtual_location)
 		free(p_lash->virtual_location);
 
-	if (p_lash->num_mst_in_lane)
-		free(p_lash->num_mst_in_lane);
-
 	OSM_LOG_EXIT(p_log);
 }
 
@@ -778,11 +776,8 @@ static int init_lash_structures(lash_t * p_lash)
 	}
 
 	/* initialise num_mst_in_lane[num_switches], default 0 */
-	p_lash->num_mst_in_lane = (int *)malloc(num_switches * sizeof(int));
-	if (p_lash->num_mst_in_lane == NULL)
-		goto Exit_Mem_Error;
 	memset(p_lash->num_mst_in_lane, 0,
-	       num_switches * sizeof(p_lash->num_mst_in_lane[0]));
+	       IB_MAX_NUM_VLS * sizeof(p_lash->num_mst_in_lane[0]));
 
 	goto Exit;
 



More information about the general mailing list