* [PATCH libdmraid-events 0/3] Assorted fixes
@ 2009-12-11 3:22 NeilBrown
2009-12-11 3:22 ` [PATCH libdmraid-events 1/3] Add some missing closedir calls NeilBrown
` (3 more replies)
0 siblings, 4 replies; 7+ messages in thread
From: NeilBrown @ 2009-12-11 3:22 UTC (permalink / raw)
To: dm-devel
Hi,
a recent code inspection found a few minor bugs in libdmraid-events.
Here are 3 patches which address these issues.
This is based on 1.0.0.rc4 retrieved from
http://sources.redhat.com/lvm2/wiki/DMRAID_Eventing?action=AttachFile&do=get&target=libdmraid-events_DSO-1.0.0.rc4.tgz
Thanks,
NeilBrown
^ permalink raw reply [flat|nested] 7+ messages in thread
* [PATCH libdmraid-events 1/3] Add some missing closedir calls.
2009-12-11 3:22 [PATCH libdmraid-events 0/3] Assorted fixes NeilBrown
@ 2009-12-11 3:22 ` NeilBrown
2009-12-11 3:22 ` [PATCH libdmraid-events 2/3] Fix some issues with use of snprintf NeilBrown
` (2 subsequent siblings)
3 siblings, 0 replies; 7+ messages in thread
From: NeilBrown @ 2009-12-11 3:22 UTC (permalink / raw)
To: dm-devel
[-- Attachment #1: closedir-fixes --]
[-- Type: text/plain, Size: 990 bytes --]
Two times opendir is called without a matching
closedir - so add those calls.
Signed-off-by: NeilBrown <neilb@suse.de>
---
libdmraid-events.c | 2 ++
1 file changed, 2 insertions(+)
--- libdmraid-events.orig/libdmraid-events.c
+++ libdmraid-events/libdmraid-events.c
@@ -172,6 +172,7 @@ static int _repopulate(const char* devic
memcpy(test_path+strlen(sys_path), strchr(disk+1, '/')+1, strlen(strchr(disk+1, '/')+1));
if((dir = opendir(test_path)))
{
+ closedir(dir);
/* test path is for this raid volume */
memcpy(test_path+strlen(test_path), "/dev", 4);
if(!(fd = fopen(test_path, "r"))) {
@@ -959,6 +960,7 @@ int register_device(const char *device,
if(!(dir = opendir(test_path)))
continue;
else {
+ closedir(dir);
/* test path is for this raid volume */
memcpy(rv_next->raid_mem[m].dev_name, scsi_dev, strlen(scsi_dev));
memset(rv_next->raid_mem[m].dev_name+strlen(scsi_dev), 0, 1);
^ permalink raw reply [flat|nested] 7+ messages in thread
* [PATCH libdmraid-events 2/3] Fix some issues with use of snprintf
2009-12-11 3:22 [PATCH libdmraid-events 0/3] Assorted fixes NeilBrown
2009-12-11 3:22 ` [PATCH libdmraid-events 1/3] Add some missing closedir calls NeilBrown
@ 2009-12-11 3:22 ` NeilBrown
2009-12-11 3:22 ` [PATCH libdmraid-events 3/3] Fix minor memory leak in lib_main NeilBrown
2009-12-14 14:28 ` [PATCH libdmraid-events 0/3] Assorted fixes Heinz Mauelshagen
3 siblings, 0 replies; 7+ messages in thread
From: NeilBrown @ 2009-12-11 3:22 UTC (permalink / raw)
To: dm-devel
[-- Attachment #1: snprint.fixes --]
[-- Type: text/plain, Size: 2140 bytes --]
Several times, the buf len argument passed to snprintf is a
'sizeof' something which is only vaguely related to the size of the buffer,
and in some cases is definitely larger than the buffer.
Also snprintf does not guarantee to produce a nul terminated string if
an overflow occurs.
So pass more appropriate buffer lengths and ensure result is nul
terminated.
Also make 'dm_num' large enough to hold more than a single digit.
Signed-off-by: NeilBrown <neilb@suse.de>
---
libdmraid-events.c | 12 ++++++++----
1 file changed, 8 insertions(+), 4 deletions(-)
--- libdmraid-events.orig/libdmraid-events.c
+++ libdmraid-events/libdmraid-events.c
@@ -303,6 +303,7 @@ static char *_match_port(const char *vol
for(i = 0; i < curr->num_sata_drives; i++)
if(curr->raid_mem[i].port_num>=0){
snprintf(port, 4, "%d", curr->raid_mem[i].port_num);
+ port[4] = 0;
memcpy(buf+strlen(buf), curr->raid_mem[i].dev_name, strlen(curr->raid_mem[i].dev_name));
memcpy(buf+strlen(buf), "=", 1);
memcpy(buf+strlen(buf), port, strlen(port));
@@ -378,7 +379,7 @@ static char *_get_dev_names(const char *
int num = 0;
FILE *fd;
char sys_path[BUF_SIZE];
- char dm_num[2];
+ char dm_num[5];
char dm_mm[MAJOR_MINOR];
char f_mm[MAJOR_MINOR];
struct dm_task *dmt;
@@ -406,8 +407,10 @@ static char *_get_dev_names(const char *
memset(sys_path, 0, BUF_SIZE);
memcpy(sys_path, SYS_DM_PATH, strlen(SYS_DM_PATH));
memset(dm_mm, 0, MAJOR_MINOR);
- snprintf(dm_mm, sizeof(info.major)+sizeof(info.minor), "%d:%d", info.major, info.minor);
- snprintf(dm_num, sizeof(num = 0), "%d", num);
+ snprintf(dm_mm, MAJOR_MINOR-1, "%d:%d", info.major, info.minor);
+ num = 0;
+ snprintf(dm_num, sizeof(dm_num), "%d", num);
+
while(!access(strncat(sys_path, dm_num, strlen(dm_num)), F_OK)) {
@@ -423,7 +426,8 @@ static char *_get_dev_names(const char *
/* Reset string for next iteration */
memset(sys_path+strlen(SYS_DM_PATH), 0, 1);
num++;
- snprintf(dm_num, sizeof(num), "%d", num);
+ snprintf(dm_num, sizeof(dm_num), "%d", num);
+ dm_num[sizeof(dm_num)-1] = 0;
fclose(fd);
continue;
}
^ permalink raw reply [flat|nested] 7+ messages in thread
* [PATCH libdmraid-events 3/3] Fix minor memory leak in lib_main
2009-12-11 3:22 [PATCH libdmraid-events 0/3] Assorted fixes NeilBrown
2009-12-11 3:22 ` [PATCH libdmraid-events 1/3] Add some missing closedir calls NeilBrown
2009-12-11 3:22 ` [PATCH libdmraid-events 2/3] Fix some issues with use of snprintf NeilBrown
@ 2009-12-11 3:22 ` NeilBrown
2009-12-14 14:28 ` [PATCH libdmraid-events 0/3] Assorted fixes Heinz Mauelshagen
3 siblings, 0 replies; 7+ messages in thread
From: NeilBrown @ 2009-12-11 3:22 UTC (permalink / raw)
To: dm-devel
[-- Attachment #1: memory-leak --]
[-- Type: text/plain, Size: 735 bytes --]
As lib_argv[3] is set to NULL, there is no point mallocing
some space an putting it there.
Signed-off-by: NeilBrown <neilb@suse.de>
---
libdmraid-events.c | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
--- libdmraid-events.orig/libdmraid-events.c
+++ libdmraid-events/libdmraid-events.c
@@ -209,7 +209,7 @@ static int lib_main(char op, const char*
int lib_argc=3;
char *lib_argv[4];
- for(i=0; i<4; i++)
+ for(i=0; i<3; i++)
lib_argv[i]=malloc(strlen(device) + 1);
strcpy(lib_argv[0], "dso");
@@ -229,7 +229,7 @@ static int lib_main(char op, const char*
libdmraid_exit(lc);
}
- for(i=0; i<4; i++)
+ for(i=0; i<3; i++)
free(lib_argv[i]);
return ret;
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH libdmraid-events 0/3] Assorted fixes
2009-12-11 3:22 [PATCH libdmraid-events 0/3] Assorted fixes NeilBrown
` (2 preceding siblings ...)
2009-12-11 3:22 ` [PATCH libdmraid-events 3/3] Fix minor memory leak in lib_main NeilBrown
@ 2009-12-14 14:28 ` Heinz Mauelshagen
2009-12-15 0:43 ` Neil Brown
2009-12-15 1:07 ` Neil Brown
3 siblings, 2 replies; 7+ messages in thread
From: Heinz Mauelshagen @ 2009-12-14 14:28 UTC (permalink / raw)
To: device-mapper development
Neil,
you seem to be based on an old version of libdmraid-events.c.
Please rebase to sources.redhat.com:/cvs/dm/ (dmraid subdirectory is
recent), which most likely has all of that addressed already and rebase
if you still find the issues.
Thanks,
Heinz
On Fri, 2009-12-11 at 14:22 +1100, NeilBrown wrote:
> Hi,
> a recent code inspection found a few minor bugs in libdmraid-events.
> Here are 3 patches which address these issues.
> This is based on 1.0.0.rc4 retrieved from
>
> http://sources.redhat.com/lvm2/wiki/DMRAID_Eventing?action=AttachFile&do=get&target=libdmraid-events_DSO-1.0.0.rc4.tgz
>
> Thanks,
> NeilBrown
>
>
> --
> dm-devel mailing list
> dm-devel@redhat.com
> https://www.redhat.com/mailman/listinfo/dm-devel
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH libdmraid-events 0/3] Assorted fixes
2009-12-14 14:28 ` [PATCH libdmraid-events 0/3] Assorted fixes Heinz Mauelshagen
@ 2009-12-15 0:43 ` Neil Brown
2009-12-15 1:07 ` Neil Brown
1 sibling, 0 replies; 7+ messages in thread
From: Neil Brown @ 2009-12-15 0:43 UTC (permalink / raw)
To: device-mapper development; +Cc: heinzm
On Mon, 14 Dec 2009 15:28:50 +0100
Heinz Mauelshagen <heinzm@redhat.com> wrote:
> Neil,
>
> you seem to be based on an old version of libdmraid-events.c.
>
> Please rebase to sources.redhat.com:/cvs/dm/ (dmraid subdirectory is
> recent), which most likely has all of that addressed already and rebase
> if you still find the issues.
>
Thanks for the pointer.
However I cannot find libdmraid-events.c in the repository.
Only libdmraid-events-isw.c which seems to be a very different thing
Is there still a libdmraid-events.c ? or has it been incorporated in
something else?
Thanks,
NeilBrown
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH libdmraid-events 0/3] Assorted fixes
2009-12-14 14:28 ` [PATCH libdmraid-events 0/3] Assorted fixes Heinz Mauelshagen
2009-12-15 0:43 ` Neil Brown
@ 2009-12-15 1:07 ` Neil Brown
1 sibling, 0 replies; 7+ messages in thread
From: Neil Brown @ 2009-12-15 1:07 UTC (permalink / raw)
To: device-mapper development; +Cc: heinzm
On Mon, 14 Dec 2009 15:28:50 +0100
Heinz Mauelshagen <heinzm@redhat.com> wrote:
> Neil,
>
> you seem to be based on an old version of libdmraid-events.c.
>
> Please rebase to sources.redhat.com:/cvs/dm/ (dmraid subdirectory is
> recent), which most likely has all of that addressed already and rebase
> if you still find the issues.
>
>
Also, I tried building from that source tree and there seem to be a number
of problems.
- include/dmraid/dmreg.h is needed but not provided
- lib/dmraid.a needs lib/device/partition.o, but there is no rule for
building that file.
- when tools/dmraid is build, the "-I" flags don't get passed to 'cc' so the
compile fails ... I haven't managed to figure out why that is yet.
Thanks,
NeilBrown
^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2009-12-15 1:07 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-12-11 3:22 [PATCH libdmraid-events 0/3] Assorted fixes NeilBrown
2009-12-11 3:22 ` [PATCH libdmraid-events 1/3] Add some missing closedir calls NeilBrown
2009-12-11 3:22 ` [PATCH libdmraid-events 2/3] Fix some issues with use of snprintf NeilBrown
2009-12-11 3:22 ` [PATCH libdmraid-events 3/3] Fix minor memory leak in lib_main NeilBrown
2009-12-14 14:28 ` [PATCH libdmraid-events 0/3] Assorted fixes Heinz Mauelshagen
2009-12-15 0:43 ` Neil Brown
2009-12-15 1:07 ` Neil Brown
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.