@@ -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;
}