Reduce stack move path local to heap
To use the -fstack-check gcc option each stack frame must be keep reasonably small. In this case the path local is moved from the stack to the heap to keep us under the limit. warning: frame size too large for reliable stack checking warning: try reducing the number of local variables
This commit is contained in:
parent
064837c20a
commit
c0932825ea
|
@ -149,10 +149,16 @@ static int
|
||||||
efi_get_info(int fd, struct dk_cinfo *dki_info)
|
efi_get_info(int fd, struct dk_cinfo *dki_info)
|
||||||
{
|
{
|
||||||
#if defined(__linux__)
|
#if defined(__linux__)
|
||||||
char path[PATH_MAX];
|
char *path;
|
||||||
char *dev_path;
|
char *dev_path;
|
||||||
int rval = 0;
|
int rval = 0;
|
||||||
|
|
||||||
|
memset(dki_info, 0, sizeof(*dki_info));
|
||||||
|
|
||||||
|
path = calloc(PATH_MAX, 1);
|
||||||
|
if (path == NULL)
|
||||||
|
goto error;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The simplest way to get the partition number under linux is
|
* The simplest way to get the partition number under linux is
|
||||||
* to parse it out of the /dev/<disk><parition> block device name.
|
* to parse it out of the /dev/<disk><parition> block device name.
|
||||||
|
@ -166,9 +172,11 @@ efi_get_info(int fd, struct dk_cinfo *dki_info)
|
||||||
* /proc/self/fd/<fd>. Aside from the partition number we collect
|
* /proc/self/fd/<fd>. Aside from the partition number we collect
|
||||||
* some additional device info.
|
* some additional device info.
|
||||||
*/
|
*/
|
||||||
memset(dki_info, 0, sizeof(*dki_info));
|
|
||||||
(void) sprintf(path, "/proc/self/fd/%d", fd);
|
(void) sprintf(path, "/proc/self/fd/%d", fd);
|
||||||
if ((dev_path = realpath(path, NULL)) == NULL)
|
dev_path = realpath(path, NULL);
|
||||||
|
free(path);
|
||||||
|
|
||||||
|
if (dev_path == NULL)
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
if ((strncmp(dev_path, "/dev/sd", 7) == 0)) {
|
if ((strncmp(dev_path, "/dev/sd", 7) == 0)) {
|
||||||
|
|
Loading…
Reference in New Issue