2011-03-28 15:34:48 +00:00
|
|
|
--- mdadm-3.2.1/sysfs.c.param 2011-03-28 11:28:13.599402233 -0400
|
|
|
|
+++ mdadm-3.2.1/sysfs.c 2011-03-28 11:29:29.427842126 -0400
|
|
|
|
@@ -428,6 +428,11 @@ int sysfs_uevent(struct mdinfo *sra, cha
|
|
|
|
return -1;
|
|
|
|
n = write(fd, event, strlen(event));
|
|
|
|
close(fd);
|
|
|
|
+ if (n != strlen(event)) {
|
|
|
|
+ dprintf(Name ": failed to write '%s' to '%s' (%s)\n",
|
|
|
|
+ event, fname, strerror(errno));
|
|
|
|
+ return -1;
|
|
|
|
+ }
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2011-03-28 15:22:21 +00:00
|
|
|
--- mdadm-3.2.1/mdadm.c.param 2011-03-28 10:38:12.035258787 -0400
|
|
|
|
+++ mdadm-3.2.1/mdadm.c 2011-03-28 10:39:33.346082070 -0400
|
|
|
|
@@ -103,7 +103,9 @@ int main(int argc, char *argv[])
|
2011-03-26 17:39:20 +00:00
|
|
|
char *shortopt = short_options;
|
|
|
|
int dosyslog = 0;
|
|
|
|
int rebuild_map = 0;
|
|
|
|
+#if 0
|
|
|
|
int auto_update_home = 0;
|
|
|
|
+#endif
|
|
|
|
char *subarray = NULL;
|
2011-03-28 15:22:21 +00:00
|
|
|
char *remove_path = NULL;
|
|
|
|
char *udev_filename = NULL;
|
|
|
|
@@ -1325,11 +1327,13 @@ int main(int argc, char *argv[])
|
2011-03-26 17:39:20 +00:00
|
|
|
cnt++;
|
|
|
|
acnt++;
|
|
|
|
}
|
|
|
|
+#if 0
|
|
|
|
if (rv2 == 1)
|
|
|
|
/* found something so even though assembly failed we
|
|
|
|
* want to avoid auto-updates
|
|
|
|
*/
|
|
|
|
auto_update_home = 0;
|
|
|
|
+#endif
|
|
|
|
} while (rv2!=2);
|
|
|
|
/* Incase there are stacked devices, we need to go around again */
|
|
|
|
} while (acnt);
|
2011-03-28 15:34:48 +00:00
|
|
|
--- mdadm-3.2.1/mdmon.c.param 2011-03-28 11:29:41.128681560 -0400
|
|
|
|
+++ mdadm-3.2.1/mdmon.c 2011-03-28 11:30:54.514946394 -0400
|
|
|
|
@@ -513,6 +513,9 @@ static int mdmon(char *devname, int devn
|
|
|
|
ignore = dup(0);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
+ if (ignore)
|
|
|
|
+ ignore++;
|
|
|
|
+
|
|
|
|
do_manager(container);
|
|
|
|
|
|
|
|
exit(0);
|
2011-03-28 15:22:21 +00:00
|
|
|
--- mdadm-3.2.1/Grow.c.param 2011-03-28 10:38:12.038259001 -0400
|
|
|
|
+++ mdadm-3.2.1/Grow.c 2011-03-28 10:45:28.174500010 -0400
|
|
|
|
@@ -1312,7 +1312,6 @@ int Grow_reshape(char *devname, int fd,
|
|
|
|
char *subarray = NULL;
|
2011-03-26 18:24:38 +00:00
|
|
|
|
2011-03-28 15:22:21 +00:00
|
|
|
int frozen;
|
|
|
|
- int changed = 0;
|
|
|
|
char *container = NULL;
|
|
|
|
char container_buf[20];
|
|
|
|
int cfd = -1;
|
|
|
|
@@ -1479,7 +1478,6 @@ int Grow_reshape(char *devname, int fd,
|
|
|
|
if (!quiet)
|
|
|
|
fprintf(stderr, Name ": component size of %s has been set to %lluK\n",
|
|
|
|
devname, size);
|
|
|
|
- changed = 1;
|
|
|
|
} else if (array.level != LEVEL_CONTAINER) {
|
|
|
|
size = get_component_size(fd)/2;
|
|
|
|
if (size == 0)
|
|
|
|
--- mdadm-3.2.1/Query.c.param 2011-03-28 10:38:12.040259145 -0400
|
|
|
|
+++ mdadm-3.2.1/Query.c 2011-03-28 10:41:19.272668999 -0400
|
|
|
|
@@ -35,7 +35,7 @@ int Query(char *dev)
|
|
|
|
int fd = open(dev, O_RDONLY);
|
|
|
|
int vers;
|
|
|
|
int ioctlerr;
|
|
|
|
- int superror, superrno;
|
|
|
|
+ int superror;
|
|
|
|
struct mdinfo info;
|
|
|
|
mdu_array_info_t array;
|
|
|
|
struct supertype *st = NULL;
|
|
|
|
@@ -84,7 +84,6 @@ int Query(char *dev)
|
|
|
|
st = guess_super(fd);
|
|
|
|
if (st) {
|
|
|
|
superror = st->ss->load_super(st, fd, dev);
|
|
|
|
- superrno = errno;
|
|
|
|
} else
|
|
|
|
superror = -1;
|
|
|
|
close(fd);
|
|
|
|
--- mdadm-3.2.1/super1.c.param 2011-03-28 10:38:12.043259360 -0400
|
|
|
|
+++ mdadm-3.2.1/super1.c 2011-03-28 10:53:14.423905054 -0400
|
2011-03-26 17:55:43 +00:00
|
|
|
@@ -111,7 +111,6 @@ static unsigned int calc_sb_1_csum(struc
|
|
|
|
unsigned long long newcsum;
|
|
|
|
int size = sizeof(*sb) + __le32_to_cpu(sb->max_dev)*2;
|
|
|
|
unsigned int *isuper = (unsigned int*)sb;
|
|
|
|
- int i;
|
|
|
|
|
|
|
|
/* make sure I can count... */
|
|
|
|
if (offsetof(struct mdp_superblock_1,data_offset) != 128 ||
|
|
|
|
@@ -123,7 +122,7 @@ static unsigned int calc_sb_1_csum(struc
|
|
|
|
disk_csum = sb->sb_csum;
|
|
|
|
sb->sb_csum = 0;
|
|
|
|
newcsum = 0;
|
|
|
|
- for (i=0; size>=4; size -= 4 ) {
|
|
|
|
+ for (; size>=4; size -= 4 ) {
|
|
|
|
newcsum += __le32_to_cpu(*isuper);
|
|
|
|
isuper++;
|
|
|
|
}
|
2011-03-28 15:22:21 +00:00
|
|
|
@@ -387,15 +386,11 @@ static void examine_super1(struct supert
|
2011-03-26 17:55:43 +00:00
|
|
|
printf(" Array State : ");
|
|
|
|
for (d=0; d<__le32_to_cpu(sb->raid_disks) + delta_extra; d++) {
|
|
|
|
int cnt = 0;
|
|
|
|
- int me = 0;
|
|
|
|
unsigned int i;
|
|
|
|
for (i=0; i< __le32_to_cpu(sb->max_dev); i++) {
|
|
|
|
unsigned int role = __le16_to_cpu(sb->dev_roles[i]);
|
2011-03-28 15:22:21 +00:00
|
|
|
- if (role == d) {
|
2011-03-26 17:55:43 +00:00
|
|
|
- if (i == __le32_to_cpu(sb->dev_number))
|
|
|
|
- me = 1;
|
2011-03-28 15:22:21 +00:00
|
|
|
+ if (role == d)
|
2011-03-26 17:55:43 +00:00
|
|
|
cnt++;
|
2011-03-28 15:22:21 +00:00
|
|
|
- }
|
2011-03-26 17:55:43 +00:00
|
|
|
}
|
2011-03-28 15:22:21 +00:00
|
|
|
if (cnt > 1) printf("?");
|
|
|
|
else if (cnt == 1) printf("A");
|
|
|
|
--- mdadm-3.2.1/Incremental.c.param 2011-03-28 10:38:12.045259502 -0400
|
2011-03-28 15:34:48 +00:00
|
|
|
+++ mdadm-3.2.1/Incremental.c 2011-03-28 11:31:41.924347665 -0400
|
|
|
|
@@ -707,7 +707,7 @@ static int count_active(struct supertype
|
|
|
|
int cnt = 0;
|
|
|
|
__u64 max_events = 0;
|
|
|
|
char *avail = NULL;
|
|
|
|
- int *best;
|
|
|
|
+ int *best = NULL;
|
|
|
|
char *devmap = NULL;
|
|
|
|
int numdevs = 0;
|
|
|
|
int devnum;
|
2011-03-28 15:22:21 +00:00
|
|
|
--- mdadm-3.2.1/super-intel.c.param 2011-03-28 10:38:12.048259718 -0400
|
2011-03-28 15:34:48 +00:00
|
|
|
+++ mdadm-3.2.1/super-intel.c 2011-03-28 11:33:53.898816208 -0400
|
2011-03-28 15:22:21 +00:00
|
|
|
@@ -6164,7 +6164,7 @@ static int apply_takeover_update(struct
|
2011-03-26 18:05:12 +00:00
|
|
|
{
|
2011-03-28 15:22:21 +00:00
|
|
|
struct imsm_dev *dev = NULL;
|
|
|
|
struct intel_dev *dv;
|
|
|
|
- struct imsm_dev *dev_new;
|
|
|
|
+ struct imsm_dev *dev_new = NULL;
|
|
|
|
struct imsm_map *map;
|
|
|
|
struct dl *dm, *du;
|
|
|
|
int i;
|
2011-03-28 15:34:48 +00:00
|
|
|
@@ -7008,7 +7008,7 @@ static int imsm_create_metadata_update_f
|
|
|
|
int update_memory_size = 0;
|
|
|
|
struct imsm_update_reshape *u = NULL;
|
|
|
|
struct mdinfo *spares = NULL;
|
|
|
|
- int i;
|
|
|
|
+ int i = -1;
|
|
|
|
int delta_disks = 0;
|
|
|
|
struct mdinfo *dev;
|
|
|
|
|