* grub-core/fs/jfs.c: Remove variable length arrays. Reduces jfs.mod
by 364 bytes (169 compressed).
This commit is contained in:
parent
d28e1163c3
commit
2359bf887c
2 changed files with 56 additions and 105 deletions
|
@ -1,3 +1,8 @@
|
||||||
|
2013-10-20 Vladimir Serbinenko <phcoder@gmail.com>
|
||||||
|
|
||||||
|
* grub-core/fs/jfs.c: Remove variable length arrays. Reduces jfs.mod
|
||||||
|
by 364 bytes (169 compressed).
|
||||||
|
|
||||||
2013-10-20 Vladimir Serbinenko <phcoder@gmail.com>
|
2013-10-20 Vladimir Serbinenko <phcoder@gmail.com>
|
||||||
|
|
||||||
* grub-core/fs/bfs.c: Remove variable length arrays. Reduces afs.mod and
|
* grub-core/fs/bfs.c: Remove variable length arrays. Reduces afs.mod and
|
||||||
|
|
|
@ -639,94 +639,51 @@ static grub_err_t
|
||||||
grub_jfs_find_file (struct grub_jfs_data *data, const char *path,
|
grub_jfs_find_file (struct grub_jfs_data *data, const char *path,
|
||||||
grub_uint32_t start_ino)
|
grub_uint32_t start_ino)
|
||||||
{
|
{
|
||||||
char fpath[grub_strlen (path)];
|
const char *name;
|
||||||
char *name = fpath;
|
const char *next = path;
|
||||||
char *next;
|
struct grub_jfs_diropen *diro = NULL;
|
||||||
struct grub_jfs_diropen *diro;
|
|
||||||
|
|
||||||
grub_strncpy (fpath, path, grub_strlen (path) + 1);
|
|
||||||
|
|
||||||
if (grub_jfs_read_inode (data, start_ino, &data->currinode))
|
if (grub_jfs_read_inode (data, start_ino, &data->currinode))
|
||||||
return grub_errno;
|
return grub_errno;
|
||||||
|
|
||||||
/* Skip the first slashes. */
|
while (1)
|
||||||
while (*name == '/')
|
|
||||||
{
|
{
|
||||||
|
name = next;
|
||||||
|
while (*name == '/')
|
||||||
name++;
|
name++;
|
||||||
if (!*name)
|
if (name[0] == 0)
|
||||||
return 0;
|
return GRUB_ERR_NONE;
|
||||||
|
for (next = name; *next && *next != '/'; next++);
|
||||||
|
|
||||||
|
if (name[0] == '.' && name + 1 == next)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if (name[0] == '.' && name[1] == '.' && name + 2 == next)
|
||||||
|
{
|
||||||
|
grub_uint32_t ino = grub_le_to_cpu32 (data->currinode.dir.header.idotdot);
|
||||||
|
|
||||||
|
if (grub_jfs_read_inode (data, ino, &data->currinode))
|
||||||
|
return grub_errno;
|
||||||
|
|
||||||
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Extract the actual part from the pathname. */
|
|
||||||
next = grub_strchr (name, '/');
|
|
||||||
if (next)
|
|
||||||
{
|
|
||||||
while (*next == '/')
|
|
||||||
{
|
|
||||||
next[0] = '\0';
|
|
||||||
next++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
diro = grub_jfs_opendir (data, &data->currinode);
|
diro = grub_jfs_opendir (data, &data->currinode);
|
||||||
if (!diro)
|
if (!diro)
|
||||||
return grub_errno;
|
return grub_errno;
|
||||||
|
|
||||||
for (;;)
|
for (;;)
|
||||||
{
|
{
|
||||||
if (name[0] == 0)
|
|
||||||
return GRUB_ERR_NONE;
|
|
||||||
|
|
||||||
if (name[0] == '.' && name[1] == 0)
|
|
||||||
{
|
|
||||||
if (!next)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
name = next;
|
|
||||||
next = grub_strchr (name, '/');
|
|
||||||
while (next && *next == '/')
|
|
||||||
{
|
|
||||||
next[0] = '\0';
|
|
||||||
next++;
|
|
||||||
}
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (name[0] == '.' && name[1] == '.' && name[2] == 0)
|
|
||||||
{
|
|
||||||
grub_uint32_t ino = grub_le_to_cpu32 (data->currinode.dir.header.idotdot);
|
|
||||||
|
|
||||||
grub_jfs_closedir (diro);
|
|
||||||
diro = 0;
|
|
||||||
|
|
||||||
if (grub_jfs_read_inode (data, ino, &data->currinode))
|
|
||||||
break;
|
|
||||||
|
|
||||||
if (!next)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
name = next;
|
|
||||||
next = grub_strchr (name, '/');
|
|
||||||
while (next && *next == '/')
|
|
||||||
{
|
|
||||||
next[0] = '\0';
|
|
||||||
next++;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Open this directory for reading dirents. */
|
|
||||||
diro = grub_jfs_opendir (data, &data->currinode);
|
|
||||||
if (!diro)
|
|
||||||
return grub_errno;
|
|
||||||
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (grub_jfs_getent (diro) == GRUB_ERR_OUT_OF_RANGE)
|
if (grub_jfs_getent (diro) == GRUB_ERR_OUT_OF_RANGE)
|
||||||
break;
|
{
|
||||||
|
grub_jfs_closedir (diro);
|
||||||
|
return grub_error (GRUB_ERR_FILE_NOT_FOUND, N_("file `%s' not found"), path);
|
||||||
|
}
|
||||||
|
|
||||||
/* Check if the current direntry matches the current part of the
|
/* Check if the current direntry matches the current part of the
|
||||||
pathname. */
|
pathname. */
|
||||||
if (data->caseins ? grub_strcasecmp (name, diro->name) == 0
|
if ((data->caseins ? grub_strncasecmp (name, diro->name, next - name) == 0
|
||||||
: grub_strcmp (name, diro->name) == 0)
|
: grub_strncmp (name, diro->name, next - name) == 0) && !diro->name[next - name])
|
||||||
{
|
{
|
||||||
grub_uint32_t ino = diro->ino;
|
grub_uint32_t ino = diro->ino;
|
||||||
grub_uint32_t dirino = grub_le_to_cpu32 (data->currinode.inode);
|
grub_uint32_t dirino = grub_le_to_cpu32 (data->currinode.inode);
|
||||||
|
@ -746,29 +703,10 @@ grub_jfs_find_file (struct grub_jfs_data *data, const char *path,
|
||||||
return grub_errno;
|
return grub_errno;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!next)
|
break;
|
||||||
return 0;
|
}
|
||||||
|
|
||||||
name = next;
|
|
||||||
next = grub_strchr (name, '/');
|
|
||||||
while (next && *next == '/')
|
|
||||||
{
|
|
||||||
next[0] = '\0';
|
|
||||||
next++;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Open this directory for reading dirents. */
|
|
||||||
diro = grub_jfs_opendir (data, &data->currinode);
|
|
||||||
if (!diro)
|
|
||||||
return grub_errno;
|
|
||||||
|
|
||||||
continue;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
grub_jfs_closedir (diro);
|
|
||||||
grub_error (GRUB_ERR_FILE_NOT_FOUND, N_("file `%s' not found"), path);
|
|
||||||
return grub_errno;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -776,15 +714,21 @@ static grub_err_t
|
||||||
grub_jfs_lookup_symlink (struct grub_jfs_data *data, grub_uint32_t ino)
|
grub_jfs_lookup_symlink (struct grub_jfs_data *data, grub_uint32_t ino)
|
||||||
{
|
{
|
||||||
grub_size_t size = grub_le_to_cpu64 (data->currinode.size);
|
grub_size_t size = grub_le_to_cpu64 (data->currinode.size);
|
||||||
char symlink[size + 1];
|
char *symlink;
|
||||||
|
|
||||||
if (++data->linknest > GRUB_JFS_MAX_SYMLNK_CNT)
|
if (++data->linknest > GRUB_JFS_MAX_SYMLNK_CNT)
|
||||||
return grub_error (GRUB_ERR_SYMLINK_LOOP, N_("too deep nesting of symlinks"));
|
return grub_error (GRUB_ERR_SYMLINK_LOOP, N_("too deep nesting of symlinks"));
|
||||||
|
|
||||||
|
symlink = grub_malloc (size + 1);
|
||||||
|
if (!symlink)
|
||||||
|
return grub_errno;
|
||||||
if (size <= sizeof (data->currinode.symlink.path))
|
if (size <= sizeof (data->currinode.symlink.path))
|
||||||
grub_strncpy (symlink, (char *) (data->currinode.symlink.path), size);
|
grub_strncpy (symlink, (char *) (data->currinode.symlink.path), size);
|
||||||
else if (grub_jfs_read_file (data, 0, 0, 0, size, symlink) < 0)
|
else if (grub_jfs_read_file (data, 0, 0, 0, size, symlink) < 0)
|
||||||
|
{
|
||||||
|
grub_free (symlink);
|
||||||
return grub_errno;
|
return grub_errno;
|
||||||
|
}
|
||||||
|
|
||||||
symlink[size] = '\0';
|
symlink[size] = '\0';
|
||||||
|
|
||||||
|
@ -794,6 +738,8 @@ grub_jfs_lookup_symlink (struct grub_jfs_data *data, grub_uint32_t ino)
|
||||||
|
|
||||||
grub_jfs_find_file (data, symlink, ino);
|
grub_jfs_find_file (data, symlink, ino);
|
||||||
|
|
||||||
|
grub_free (symlink);
|
||||||
|
|
||||||
return grub_errno;
|
return grub_errno;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue