diff options
author | Tiziano Müller <dev-zero@gentoo.org> | 2006-12-02 11:55:45 +0000 |
---|---|---|
committer | Tiziano Müller <dev-zero@gentoo.org> | 2006-12-02 11:55:45 +0000 |
commit | 1c2bb2d7bd6f6f1f3565e97737c944414a21b43f (patch) | |
tree | 6009c7585dd3c4fc1b0ba2e90b633369def3d033 /sys-fs/evms/files | |
parent | fix bugs, implement suggestions from vapier (diff) | |
download | historical-1c2bb2d7bd6f6f1f3565e97737c944414a21b43f.tar.gz historical-1c2bb2d7bd6f6f1f3565e97737c944414a21b43f.tar.bz2 historical-1c2bb2d7bd6f6f1f3565e97737c944414a21b43f.zip |
Revision bump to include new upstream patches. Included the glib-patch provided by Jimmy Jazz (bug #152293) and the ocfs2-patch (bug #147276, thanks to Brad Plant). Solved bug #147281 and #154924. Dropped old version.
Package-Manager: portage-2.1.2_rc2
Diffstat (limited to 'sys-fs/evms/files')
-rw-r--r-- | sys-fs/evms/files/2.5.5/BaseName.patch | 29 | ||||
-rw-r--r-- | sys-fs/evms/files/2.5.5/cli_query_segfault.patch | 28 | ||||
-rw-r--r-- | sys-fs/evms/files/2.5.5/cli_reload_options.patch | 19 | ||||
-rw-r--r-- | sys-fs/evms/files/2.5.5/get_geometry.patch | 37 | ||||
-rw-r--r-- | sys-fs/evms/files/2.5.5/ntfs_unmkfs.patch | 33 | ||||
-rw-r--r-- | sys-fs/evms/files/2.5.5/raid5_algorithm.patch | 15 | ||||
-rw-r--r-- | sys-fs/evms/files/digest-evms-2.5.5-r3 | 3 | ||||
-rw-r--r-- | sys-fs/evms/files/evms-2.5.5-glib_dep.patch | 45 | ||||
-rw-r--r-- | sys-fs/evms/files/evms-2.5.5-ocfs2.patch | 22 |
9 files changed, 231 insertions, 0 deletions
diff --git a/sys-fs/evms/files/2.5.5/BaseName.patch b/sys-fs/evms/files/2.5.5/BaseName.patch new file mode 100644 index 000000000000..7a0ab0304312 --- /dev/null +++ b/sys-fs/evms/files/2.5.5/BaseName.patch @@ -0,0 +1,29 @@ +EVMS registers the base name for the top working object of a volume if the
+object has its own device. However, EVMS engine fails to unregister such
+names when discarding volumes. This prevents some operation on volumes.
+
+The problem magnifies in cluster environments because rediscovery of
+CSM containers would fail to add volumes (discarded moments ago) back to
+the object tree, and the volumes would get deleted when committing changes.
+
+Rediscovery can be triggered by an operation as simple as changing the
+attributes of a CSM container.
+
+I added code to unregister the base name, and tested on my cluster.
+ +"Changju Gao" <CGAO@novell.com> + +--- evms-2.5.5/engine/internalAPI.c 2005-10-10 09:44:41.000000000 -0500 ++++ evms-2.5.5-fix/engine/internalAPI.c 2006-11-01 17:11:42.113699000 -0600 +@@ -2722,6 +2722,11 @@ + if (rc == 0) { + engine_unregister_name(vol->name); + ++ if( vol->object->feature_header != NULL ) ++ { ++ engine_unregister_name(vol->name+EVMS_DEV_NODE_PATH_LEN); ++ } ++ + /* + * Clear out the volume pointer on this object and on all the child + * objects in the tree. diff --git a/sys-fs/evms/files/2.5.5/cli_query_segfault.patch b/sys-fs/evms/files/2.5.5/cli_query_segfault.patch new file mode 100644 index 000000000000..2df64bf3be0b --- /dev/null +++ b/sys-fs/evms/files/2.5.5/cli_query_segfault.patch @@ -0,0 +1,28 @@ +Fix for a segfault in the CLI when doing a query -- not enough memory declared +for a handle array. + +--- evms-2.5.5/ui/cli/interpreter.c 2005-06-01 10:20:32.000000000 -0500 ++++ evms-2.5.5-fix/ui/cli/interpreter.c 2006-09-14 09:47:16.480084103 -0500 +@@ -3326,7 +3326,8 @@ + dlist_t Return_Values; + object_handle_t Object_Handle; + handle_array_t * Object_List; +- handle_array_t Tmp_Array; ++ char Tmp_Buffer[sizeof(handle_array_t) + sizeof(object_handle_t)]; ++ handle_array_t * Tmp_Array = (handle_array_t *)Tmp_Buffer; + handle_object_info_t * Object_Info; + expand_handle_array_t * Expand_Points; + shrink_handle_array_t * Shrink_Points; +@@ -3477,9 +3478,9 @@ + case EVMS_OBJECT: + Object_List = Object_Info->info.object.parent_objects; + if (Object_List->count == 0 && Object_Info->info.object.volume != 0) { +- Tmp_Array.count = 1; +- Tmp_Array.handle[0] = Object_Info->info.object.volume; +- Object_List = &Tmp_Array; ++ Tmp_Array->count = 1; ++ Tmp_Array->handle[0] = Object_Info->info.object.volume; ++ Object_List = Tmp_Array; + } + break; + default: diff --git a/sys-fs/evms/files/2.5.5/cli_reload_options.patch b/sys-fs/evms/files/2.5.5/cli_reload_options.patch new file mode 100644 index 000000000000..425400514053 --- /dev/null +++ b/sys-fs/evms/files/2.5.5/cli_reload_options.patch @@ -0,0 +1,19 @@ +Check the returned effect after setting selected objects for a task and +reload the option descriptors if necessary. + +--- evms-2.5.5/ui/cli/interpreter.c 2005-06-01 10:20:32.000000000 -0500 ++++ evms-2.5.5-fix/ui/cli/interpreter.c 2006-09-01 11:54:50.903202365 -0500 +@@ -2400,6 +2400,13 @@ + Error = EINVAL; + + } ++ else ++ { ++ if (Task_Result & EVMS_Effect_Reload_Options) { ++ Clear_Option_Descriptors(); ++ Get_Option_Descriptors(); ++ } ++ } + + } + else diff --git a/sys-fs/evms/files/2.5.5/get_geometry.patch b/sys-fs/evms/files/2.5.5/get_geometry.patch new file mode 100644 index 000000000000..cc13b6451be7 --- /dev/null +++ b/sys-fs/evms/files/2.5.5/get_geometry.patch @@ -0,0 +1,37 @@ +This patch fixes a segmentation fault that can occur in the Local Disk Manager +when the queries for getting the geometry of the disk return a value of zero +for either the number of heads or the number of sectors per track. + +--- evms-2.5.5/plugins/disk/localdskmgr.c 2006-02-24 13:53:21.000000000 -0600 ++++ evms-2.5.5-fix/plugins/disk/localdskmgr.c 2006-09-01 11:41:56.681089000 -0500 +@@ -1552,16 +1552,25 @@ + + LOG_ENTRY(); + +- /* Set defaults */ +- disk->geometry.heads = 255; +- disk->geometry.sectors_per_track = 63; +- + rc = get_partition_table_geometry(disk); + + if (rc != 0) { +- get_kernel_geometry(disk); ++ rc = get_kernel_geometry(disk); ++ } ++ ++ /* Set defaults if no valid geometry was found. */ ++ if (disk->geometry.heads == 0) { ++ LOG_DEBUG("Disk %s: Heads is zero - setting to 255.\n", ++ disk->name); ++ disk->geometry.heads = 255; ++ } ++ if (disk->geometry.sectors_per_track == 0) { ++ LOG_DEBUG("Disk %s: Sectors-per-track is zero - " ++ "setting to 63.\n", disk->name); ++ disk->geometry.sectors_per_track = 63; + } + ++ /* Calculate number of cylinders based on other geometry fields. */ + disk->geometry.cylinders = disk->size / + (disk->geometry.heads * + disk->geometry.sectors_per_track * diff --git a/sys-fs/evms/files/2.5.5/ntfs_unmkfs.patch b/sys-fs/evms/files/2.5.5/ntfs_unmkfs.patch new file mode 100644 index 000000000000..6e62c28eb5d3 --- /dev/null +++ b/sys-fs/evms/files/2.5.5/ntfs_unmkfs.patch @@ -0,0 +1,33 @@ +This patch fixes a bug in the NTFS unmkfs. The offsets for the superblocks +were calculated incorrectly by using the filesystem size rather than using +the volume size. The result is that sometimes the superblocks didn't get +wiped out, leaving the NTFS file system still on the volume. + +--- evms-2.5.5/plugins/ntfs/utils.c 2006-02-24 10:36:54.000000000 -0600 ++++ evms-2.5.5-fix/plugins/ntfs/utils.c 2006-05-04 16:47:26.243120000 -0500 +@@ -313,7 +313,6 @@ + int clear_ntfs_boot_sectors(logical_volume_t * ev) + { + int rc = 0; +- private_data_t * pd = (private_data_t *) ev->private_data; + int fd; + void * block; + int32_t bytes_written; +@@ -346,7 +345,7 @@ + } + + /* Wipe out the NT4+ backup boot sector. */ +- bytes_written = EngFncs->write_volume(ev, fd, block, NTFS_BLOCK_SIZE, (pd->fs_size << EVMS_VSECTOR_SIZE_SHIFT) - NTFS_BLOCK_SIZE); ++ bytes_written = EngFncs->write_volume(ev, fd, block, NTFS_BLOCK_SIZE, (ev->vol_size << EVMS_VSECTOR_SIZE_SHIFT) - NTFS_BLOCK_SIZE); + if (bytes_written != NTFS_BLOCK_SIZE) { + LOG_WARNING("Failed to clear the primary boot sector on volume %s. " + "Only %d bytes were written.\n", +@@ -355,7 +354,7 @@ + } + + /* Wipe out the NT3.51- backup boot sector. */ +- bytes_written = EngFncs->write_volume(ev, fd, block, NTFS_BLOCK_SIZE, (pd->fs_size << (EVMS_VSECTOR_SIZE_SHIFT - 1))); ++ bytes_written = EngFncs->write_volume(ev, fd, block, NTFS_BLOCK_SIZE, (ev->vol_size << (EVMS_VSECTOR_SIZE_SHIFT - 1))); + if (bytes_written != NTFS_BLOCK_SIZE) { + LOG_WARNING("Failed to clear the primary boot sector on volume %s. " + "Only %d bytes were written.\n", diff --git a/sys-fs/evms/files/2.5.5/raid5_algorithm.patch b/sys-fs/evms/files/2.5.5/raid5_algorithm.patch new file mode 100644 index 000000000000..cae213b436f8 --- /dev/null +++ b/sys-fs/evms/files/2.5.5/raid5_algorithm.patch @@ -0,0 +1,15 @@ +This patch fixes the md plug-in so that it will set the desired parity algorithm +in the superblock for the RAID5 array. Previously it always set the algorithm +to 0, i.e., left asymmetric. + +--- evms-2.5.5/plugins/md/raid5_mgr.c 2006-02-22 10:05:17.000000000 -0600 ++++ evms-2.5.5-fix/plugins/md/raid5_mgr.c 2006-06-08 13:59:56.648351368 -0500 +@@ -1932,7 +1932,7 @@ + } + } + +- rc = md_init_sb(volume, &sb_ver, raid_level, 0, size, chunksize); ++ rc = md_init_sb(volume, &sb_ver, raid_level, parity_algorithm, size, chunksize); + if (rc) { + goto error_free; + } diff --git a/sys-fs/evms/files/digest-evms-2.5.5-r3 b/sys-fs/evms/files/digest-evms-2.5.5-r3 new file mode 100644 index 000000000000..33b12c6760ce --- /dev/null +++ b/sys-fs/evms/files/digest-evms-2.5.5-r3 @@ -0,0 +1,3 @@ +MD5 45b463f0cbade194dc0a08be432b572e evms-2.5.5.tar.gz 2286321 +RMD160 716d6b34f48f6f7a3f5f4627bc4a2c34957607f7 evms-2.5.5.tar.gz 2286321 +SHA256 9dbfaac148d822068ba883f6533935e03ae5cfc9fdf8836dea6aee99c859307c evms-2.5.5.tar.gz 2286321 diff --git a/sys-fs/evms/files/evms-2.5.5-glib_dep.patch b/sys-fs/evms/files/evms-2.5.5-glib_dep.patch new file mode 100644 index 000000000000..bbf492339934 --- /dev/null +++ b/sys-fs/evms/files/evms-2.5.5-glib_dep.patch @@ -0,0 +1,45 @@ +--- /root/aclocal.m4.old 2006-10-21 18:51:30.000000000 +0200 ++++ aclocal.m4 2006-10-21 20:48:07.000000000 +0200 +@@ -495,8 +495,8 @@ + AC_MSG_NOTICE([ not building text-mode ... requires ncurses library]) + elif test "$have_panel" = "no"; then + AC_MSG_NOTICE([ not building text-mode ... requires panel library]) +-elif test "$have_ha_glib" = "no"; then +- AC_MSG_NOTICE([ not building text-mode ... requires $ha_glib library]) ++#elif test "$have_ha_glib" = "no"; then ++# AC_MSG_NOTICE([ not building text-mode ... requires $ha_glib library]) + elif test "$have_math" = "no"; then + AC_MSG_NOTICE([ not building text-mode ... requires math library]) + else +@@ -920,7 +920,16 @@ + fi + fi + ++ha_glib=glib ++have_ha_glib=$have_glib ++HA_GLIB_CPPFLAGS=$GLIB_CPPFLAGS ++HA_GLIB_LIBS=$GLIB_LIBS ++ + if test "x$no_glib2" = x; then ++ ha_glib=glib2 ++ have_ha_glib=$have_glib2 ++ HA_GLIB_CPPFLAGS=$GLIB2_CPPFLAGS ++ HA_GLIB_LIBS=$GLIB2_LIBS + AC_MSG_RESULT([yes]) + ifelse([$2], , :, [$2]) + else +@@ -1286,10 +1295,10 @@ + [ifelse([$3], , :, [$3])]) + fi + +-ha_glib=glib +-have_ha_glib=$have_glib +-HA_GLIB_CPPFLAGS=$GLIB_CPPFLAGS +-HA_GLIB_LIBS=$GLIB_LIBS ++#ha_glib=glib ++#have_ha_glib=$have_glib ++#HA_GLIB_CPPFLAGS=$GLIB_CPPFLAGS ++#HA_GLIB_LIBS=$GLIB_LIBS + + if test "$have_ha_version" = "yes"; then + if test -d /usr/include/heartbeat -a \ diff --git a/sys-fs/evms/files/evms-2.5.5-ocfs2.patch b/sys-fs/evms/files/evms-2.5.5-ocfs2.patch new file mode 100644 index 000000000000..af8f0ee5dbe4 --- /dev/null +++ b/sys-fs/evms/files/evms-2.5.5-ocfs2.patch @@ -0,0 +1,22 @@ +--- plugins/ocfs2/ocfs2.c.orig 2006-09-12 18:45:36.000000000 +1000 ++++ plugins/ocfs2/ocfs2.c 2006-09-12 18:46:46.000000000 +1000 +@@ -636,6 +636,7 @@ static int fsim_test_version(void) + int status; + int bytes_read; + int rc; ++ float ver_num; + + LOG_ENTRY(); + +@@ -672,8 +673,9 @@ static int fsim_test_version(void) + LOG_DEBUG("Reading output from process %d on fd %d.\n", pidm, fds2[0]); + bytes_read = read(fds2[0], buffer, 1024); + if (bytes_read > 0) { +- ver = strstr(buffer, "1.1"); +- if (!ver) { ++ ver = strstr(buffer, "1."); ++ ver_num = atof(ver); ++ if(ver_num < 1.1) { + rc = EINVAL; + } else { + oc2_version = 2; |