Use posix_memalign() for memory used to write bitmaps

This makes super[01].c properly align buffers used for the bitmap
using posix_memalign() to make sure the writes don't fail in case the
bitmap is opened using O_DIRECT.

This is based on https://bugzilla.redhat.com/show_bug.cgi?id=789898
and an initial patch by Alexander Murashkin.

Signed-off-by: Jes Sorensen <Jes.Sorensen@redhat.com>
Signed-off-by: NeilBrown <neilb@suse.de>
This commit is contained in:
Jes Sorensen 2012-02-14 11:52:13 +01:00 committed by NeilBrown
parent 9f1b0f0f1e
commit d669228f29
2 changed files with 10 additions and 5 deletions

View File

@ -1065,13 +1065,11 @@ static int write_bitmap0(struct supertype *st, int fd)
int rv = 0;
int towrite, n;
char abuf[4096+4096];
char *buf = (char*)(((long)(abuf+4096))&~4095L);
void *buf;
if (!get_dev_size(fd, NULL, &dsize))
return 1;
if (dsize < MD_RESERVED_SECTORS*512)
return -1;
@ -1082,6 +1080,9 @@ static int write_bitmap0(struct supertype *st, int fd)
if (lseek64(fd, offset + 4096, 0)< 0LL)
return 3;
if (posix_memalign(&buf, 4096, 4096))
return -ENOMEM;
memset(buf, 0xff, 4096);
memcpy(buf, ((char*)sb)+MD_SB_BYTES, sizeof(bitmap_super_t));
towrite = 60*1024;
@ -1100,6 +1101,7 @@ static int write_bitmap0(struct supertype *st, int fd)
if (towrite)
rv = -2;
free(buf);
return rv;
}

View File

@ -1641,12 +1641,14 @@ static int write_bitmap1(struct supertype *st, int fd)
struct mdp_superblock_1 *sb = st->sb;
bitmap_super_t *bms = (bitmap_super_t*)(((char*)sb)+1024);
int rv = 0;
void *buf;
int towrite, n;
char buf[4096];
locate_bitmap1(st, fd);
if (posix_memalign(&buf, 4096, 4096))
return -ENOMEM;
memset(buf, 0xff, 4096);
memcpy(buf, ((char*)sb)+1024, sizeof(bitmap_super_t));
@ -1669,6 +1671,7 @@ static int write_bitmap1(struct supertype *st, int fd)
if (towrite)
rv = -2;
free(buf);
return rv;
}