diff options
author | marcus <marcus@FreeBSD.org> | 2009-05-24 06:58:01 +0800 |
---|---|---|
committer | marcus <marcus@FreeBSD.org> | 2009-05-24 06:58:01 +0800 |
commit | 904ca21330722e63539c5a8a957b4009cd971af9 (patch) | |
tree | 6ccbdf66b799023abb7d11a6403bdedbd30c206e | |
parent | 525698097d1ad94688c207f4cc8a7c1e8724c086 (diff) | |
download | freebsd-ports-gnome-904ca21330722e63539c5a8a957b4009cd971af9.tar.gz freebsd-ports-gnome-904ca21330722e63539c5a8a957b4009cd971af9.tar.zst freebsd-ports-gnome-904ca21330722e63539c5a8a957b4009cd971af9.zip |
Optimize the check for an existing GEOM object and correct a nearby memory
leak.
-rw-r--r-- | sysutils/hal/Makefile | 2 | ||||
-rw-r--r-- | sysutils/hal/files/patch-hald_hf-storage.c | 41 |
2 files changed, 27 insertions, 16 deletions
diff --git a/sysutils/hal/Makefile b/sysutils/hal/Makefile index 68058566b0db..80c30d2d19eb 100644 --- a/sysutils/hal/Makefile +++ b/sysutils/hal/Makefile @@ -8,7 +8,7 @@ PORTNAME= hal DISTVERSION= 0.5.11 -PORTREVISION= 24 +PORTREVISION= 25 CATEGORIES= sysutils MASTER_SITES= http://hal.freedesktop.org/releases/ diff --git a/sysutils/hal/files/patch-hald_hf-storage.c b/sysutils/hal/files/patch-hald_hf-storage.c index cfe7e202350f..605342c36b3b 100644 --- a/sysutils/hal/files/patch-hald_hf-storage.c +++ b/sysutils/hal/files/patch-hald_hf-storage.c @@ -1,5 +1,5 @@ ---- hald/freebsd/hf-storage.c.orig 2008-05-07 19:23:57.000000000 -0400 -+++ hald/freebsd/hf-storage.c 2009-05-23 17:07:00.000000000 -0400 +--- hald/freebsd/hf-storage.c.orig 2008-08-10 09:50:10.000000000 -0400 ++++ hald/freebsd/hf-storage.c 2009-05-23 18:52:52.000000000 -0400 @@ -30,6 +30,7 @@ #include <limits.h> #include <inttypes.h> @@ -59,7 +59,30 @@ if (hf_runner_run_sync(device, 0, "hald-probe-storage", "HF_HAS_CHILDREN", HF_BOOL_TO_STRING(hf_storage_device_has_partitions(device)), -@@ -433,11 +439,42 @@ hf_storage_parse_conftxt (const char *co +@@ -403,13 +409,20 @@ hf_storage_parse_conftxt (const char *co + continue; + } + ++ depth = atoi(fields[0]); ++ hash = g_str_hash(fields[2]); ++ if (g_hash_table_lookup(table, GUINT_TO_POINTER(hash)) != NULL) ++ { ++ g_strfreev(fields); ++ curr_depth = depth; ++ continue; ++ } ++ + geom_obj = g_new0(Geom_Object, 1); + +- depth = atoi(fields[0]); + geom_obj->class = g_strdup(fields[1]); + geom_obj->dev = g_strdup(fields[2]); + geom_obj->type = -1; /* We use -1 here to denote a missing type. */ +- hash = g_str_hash(geom_obj->dev); + geom_obj->hash = hash; + + if (g_strv_length(fields) >= 5) +@@ -433,6 +446,30 @@ hf_storage_parse_conftxt (const char *co if (! strcmp (geom_obj->class, "GPT") || ! strcmp (geom_obj->class, "APPLE")) geom_obj->str_type = g_strdup(fields[10]); @@ -90,18 +113,6 @@ else geom_obj->type = atoi(fields[10]); } - } - -+ if (g_hash_table_lookup(table, GUINT_TO_POINTER(hash)) != NULL) -+ { -+ hf_storage_geom_free(geom_obj); -+ curr_depth = depth; -+ continue; -+ } -+ - g_hash_table_insert (table, GUINT_TO_POINTER(hash), geom_obj); - - if (depth > curr_depth) @@ -541,15 +578,20 @@ hf_storage_device_rescan_real (HalDevice } |