forked from Imagelibrary/rtems
2010-08-25 Sebastian Huber <sebastian.huber@embedded-brains.de>
CID 113/SECURE_CODING * libblock/src/media-path.c: Avoid strcpy(). Style. Use assert() to avoid dead code.
This commit is contained in:
@@ -1,3 +1,9 @@
|
|||||||
|
2010-08-25 Sebastian Huber <sebastian.huber@embedded-brains.de>
|
||||||
|
|
||||||
|
CID 113/SECURE_CODING
|
||||||
|
* libblock/src/media-path.c: Avoid strcpy(). Style. Use assert() to
|
||||||
|
avoid dead code.
|
||||||
|
|
||||||
2010-08-24 Sebastian Huber <sebastian.huber@embedded-brains.de>
|
2010-08-24 Sebastian Huber <sebastian.huber@embedded-brains.de>
|
||||||
|
|
||||||
PR 1673/cpukit
|
PR 1673/cpukit
|
||||||
|
|||||||
@@ -24,22 +24,22 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <inttypes.h>
|
#include <inttypes.h>
|
||||||
|
#include <assert.h>
|
||||||
|
|
||||||
#include <rtems/media.h>
|
#include <rtems/media.h>
|
||||||
|
|
||||||
char *rtems_media_create_path(const char *prefix, const char *name, rtems_device_major_number major)
|
char *rtems_media_create_path(
|
||||||
|
const char *prefix,
|
||||||
|
const char *name,
|
||||||
|
rtems_device_major_number major
|
||||||
|
)
|
||||||
{
|
{
|
||||||
size_t const len = strlen(prefix) + 1 + strlen(name) + 1 + 10 + 1;
|
size_t const size = strlen(prefix) + 1 + strlen(name) + 1 + 10 + 1;
|
||||||
char *const s = malloc(len);
|
char *const s = malloc(size);
|
||||||
|
|
||||||
if (s != NULL) {
|
if (s != NULL) {
|
||||||
int rv = snprintf(s, len, "%s/%s-%" PRIu32, prefix, name, major);
|
int rv = snprintf(s, size, "%s/%s-%" PRIu32, prefix, name, major);
|
||||||
|
assert(rv < (int) size);
|
||||||
if (rv >= (int) len) {
|
|
||||||
free(s);
|
|
||||||
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return s;
|
return s;
|
||||||
@@ -50,32 +50,30 @@ char *rtems_media_replace_prefix(const char *new_prefix, const char *path)
|
|||||||
const char *const name_try = strrchr(path, '/');
|
const char *const name_try = strrchr(path, '/');
|
||||||
const char *const name = (name_try == NULL) ? path : name_try + 1;
|
const char *const name = (name_try == NULL) ? path : name_try + 1;
|
||||||
size_t const new_prefix_len = strlen(new_prefix);
|
size_t const new_prefix_len = strlen(new_prefix);
|
||||||
size_t const name_len = strlen(name);
|
size_t const name_size = strlen(name) + 1;
|
||||||
size_t const len = new_prefix_len + 1 + name_len + 1;
|
size_t const size = new_prefix_len + 1 + name_size;
|
||||||
char *const s = malloc(len);
|
char *const s = malloc(size);
|
||||||
|
|
||||||
if (s != NULL) {
|
if (s != NULL) {
|
||||||
strcpy(s, new_prefix);
|
memcpy(s, new_prefix, new_prefix_len);
|
||||||
strcpy(s + new_prefix_len, "/");
|
s [new_prefix_len] = '/';
|
||||||
strcpy(s + new_prefix_len + 1, name);
|
memcpy(s + new_prefix_len + 1, name, name_size);
|
||||||
}
|
}
|
||||||
|
|
||||||
return s;
|
return s;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *rtems_media_append_minor(const char *path, rtems_device_minor_number minor)
|
char *rtems_media_append_minor(
|
||||||
|
const char *path,
|
||||||
|
rtems_device_minor_number minor
|
||||||
|
)
|
||||||
{
|
{
|
||||||
size_t const len = strlen(path) + 1 + 10 + 1;
|
size_t const size = strlen(path) + 1 + 10 + 1;
|
||||||
char *const s = malloc(len);
|
char *const s = malloc(size);
|
||||||
|
|
||||||
if (s != NULL) {
|
if (s != NULL) {
|
||||||
int rv = snprintf(s, len, "%s-%" PRIu32, path, minor);
|
int rv = snprintf(s, size, "%s-%" PRIu32, path, minor);
|
||||||
|
assert(rv < (int) size);
|
||||||
if (rv >= (int) len) {
|
|
||||||
free(s);
|
|
||||||
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return s;
|
return s;
|
||||||
|
|||||||
Reference in New Issue
Block a user