forked from pool/grub2
Accepting request 240012 from home:k0da:ppc
OBS-URL: https://build.opensuse.org/request/show/240012 OBS-URL: https://build.opensuse.org/package/show/Base:System/grub2?expand=0&rev=97
This commit is contained in:
parent
bbda4d805e
commit
800f4125e5
@ -8,10 +8,10 @@ Signed-off-by: Jan Kara <jack@suse.cz>
|
|||||||
grub-core/fs/xfs.c | 245 +++++++++++++++++++++++++++++++++++++----------------
|
grub-core/fs/xfs.c | 245 +++++++++++++++++++++++++++++++++++++----------------
|
||||||
1 file changed, 173 insertions(+), 72 deletions(-)
|
1 file changed, 173 insertions(+), 72 deletions(-)
|
||||||
|
|
||||||
diff --git a/grub-core/fs/xfs.c b/grub-core/fs/xfs.c
|
Index: grub-2.02~beta2/grub-core/fs/xfs.c
|
||||||
index 7e247a32df5c..3b1d8994067f 100644
|
===================================================================
|
||||||
--- a/grub-core/fs/xfs.c
|
--- grub-2.02~beta2.orig/grub-core/fs/xfs.c
|
||||||
+++ b/grub-core/fs/xfs.c
|
+++ grub-2.02~beta2/grub-core/fs/xfs.c
|
||||||
@@ -34,6 +34,15 @@ GRUB_MOD_LICENSE ("GPLv3+");
|
@@ -34,6 +34,15 @@ GRUB_MOD_LICENSE ("GPLv3+");
|
||||||
#define XFS_INODE_FORMAT_EXT 2
|
#define XFS_INODE_FORMAT_EXT 2
|
||||||
#define XFS_INODE_FORMAT_BTREE 3
|
#define XFS_INODE_FORMAT_BTREE 3
|
||||||
@ -140,7 +140,7 @@ index 7e247a32df5c..3b1d8994067f 100644
|
|||||||
/* Filetype information as used in inodes. */
|
/* Filetype information as used in inodes. */
|
||||||
#define FILETYPE_INO_MASK 0170000
|
#define FILETYPE_INO_MASK 0170000
|
||||||
#define FILETYPE_INO_REG 0100000
|
#define FILETYPE_INO_REG 0100000
|
||||||
@@ -219,18 +249,6 @@ GRUB_XFS_EXTENT_SIZE (grub_xfs_extent *exts, int ex)
|
@@ -219,18 +249,6 @@ GRUB_XFS_EXTENT_SIZE (grub_xfs_extent *e
|
||||||
return (grub_be_to_cpu32 (exts[ex][3]) & ((1 << 21) - 1));
|
return (grub_be_to_cpu32 (exts[ex][3]) & ((1 << 21) - 1));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -159,7 +159,7 @@ index 7e247a32df5c..3b1d8994067f 100644
|
|||||||
|
|
||||||
static inline grub_uint64_t
|
static inline grub_uint64_t
|
||||||
grub_xfs_inode_block (struct grub_xfs_data *data,
|
grub_xfs_inode_block (struct grub_xfs_data *data,
|
||||||
@@ -261,6 +279,92 @@ grub_xfs_inode_size(struct grub_xfs_data *data)
|
@@ -261,6 +279,92 @@ grub_xfs_inode_size(struct grub_xfs_data
|
||||||
return 1 << data->sblock.log2_inode;
|
return 1 << data->sblock.log2_inode;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -246,13 +246,13 @@ index 7e247a32df5c..3b1d8994067f 100644
|
|||||||
+
|
+
|
||||||
+ if (data->hascrc)
|
+ if (data->hascrc)
|
||||||
+ p += 48; /* crc, uuid, ... */
|
+ p += 48; /* crc, uuid, ... */
|
||||||
+ return (grub_uint64_t *)p;
|
+ return (grub_uint64_t *)(void*)p;
|
||||||
+}
|
+}
|
||||||
+
|
+
|
||||||
static grub_err_t
|
static grub_err_t
|
||||||
grub_xfs_read_inode (struct grub_xfs_data *data, grub_uint64_t ino,
|
grub_xfs_read_inode (struct grub_xfs_data *data, grub_uint64_t ino,
|
||||||
struct grub_xfs_inode *inode)
|
struct grub_xfs_inode *inode)
|
||||||
@@ -268,6 +372,9 @@ grub_xfs_read_inode (struct grub_xfs_data *data, grub_uint64_t ino,
|
@@ -268,6 +372,9 @@ grub_xfs_read_inode (struct grub_xfs_dat
|
||||||
grub_uint64_t block = grub_xfs_inode_block (data, ino);
|
grub_uint64_t block = grub_xfs_inode_block (data, ino);
|
||||||
int offset = grub_xfs_inode_offset (data, ino);
|
int offset = grub_xfs_inode_offset (data, ino);
|
||||||
|
|
||||||
@ -262,7 +262,7 @@ index 7e247a32df5c..3b1d8994067f 100644
|
|||||||
/* Read the inode. */
|
/* Read the inode. */
|
||||||
if (grub_disk_read (data->disk, block, offset, grub_xfs_inode_size(data),
|
if (grub_disk_read (data->disk, block, offset, grub_xfs_inode_size(data),
|
||||||
inode))
|
inode))
|
||||||
@@ -290,6 +397,7 @@ grub_xfs_read_block (grub_fshelp_node_t node, grub_disk_addr_t fileblock)
|
@@ -290,6 +397,7 @@ grub_xfs_read_block (grub_fshelp_node_t
|
||||||
|
|
||||||
if (node->inode.format == XFS_INODE_FORMAT_BTREE)
|
if (node->inode.format == XFS_INODE_FORMAT_BTREE)
|
||||||
{
|
{
|
||||||
@ -270,7 +270,7 @@ index 7e247a32df5c..3b1d8994067f 100644
|
|||||||
const grub_uint64_t *keys;
|
const grub_uint64_t *keys;
|
||||||
int recoffset;
|
int recoffset;
|
||||||
|
|
||||||
@@ -297,15 +405,15 @@ grub_xfs_read_block (grub_fshelp_node_t node, grub_disk_addr_t fileblock)
|
@@ -297,15 +405,15 @@ grub_xfs_read_block (grub_fshelp_node_t
|
||||||
if (leaf == 0)
|
if (leaf == 0)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
@ -291,7 +291,7 @@ index 7e247a32df5c..3b1d8994067f 100644
|
|||||||
do
|
do
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
@@ -327,7 +435,10 @@ grub_xfs_read_block (grub_fshelp_node_t node, grub_disk_addr_t fileblock)
|
@@ -327,7 +435,10 @@ grub_xfs_read_block (grub_fshelp_node_t
|
||||||
0, node->data->bsize, leaf))
|
0, node->data->bsize, leaf))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
@ -303,7 +303,7 @@ index 7e247a32df5c..3b1d8994067f 100644
|
|||||||
{
|
{
|
||||||
grub_free (leaf);
|
grub_free (leaf);
|
||||||
grub_error (GRUB_ERR_BAD_FS, "not a correct XFS BMAP node");
|
grub_error (GRUB_ERR_BAD_FS, "not a correct XFS BMAP node");
|
||||||
@@ -335,8 +446,8 @@ grub_xfs_read_block (grub_fshelp_node_t node, grub_disk_addr_t fileblock)
|
@@ -335,8 +446,8 @@ grub_xfs_read_block (grub_fshelp_node_t
|
||||||
}
|
}
|
||||||
|
|
||||||
nrec = grub_be_to_cpu16 (leaf->numrecs);
|
nrec = grub_be_to_cpu16 (leaf->numrecs);
|
||||||
@ -314,7 +314,7 @@ index 7e247a32df5c..3b1d8994067f 100644
|
|||||||
- (char *) leaf))
|
- (char *) leaf))
|
||||||
/ (2 * sizeof (grub_uint64_t)));
|
/ (2 * sizeof (grub_uint64_t)));
|
||||||
}
|
}
|
||||||
@@ -346,7 +457,7 @@ grub_xfs_read_block (grub_fshelp_node_t node, grub_disk_addr_t fileblock)
|
@@ -346,7 +457,7 @@ grub_xfs_read_block (grub_fshelp_node_t
|
||||||
else if (node->inode.format == XFS_INODE_FORMAT_EXT)
|
else if (node->inode.format == XFS_INODE_FORMAT_EXT)
|
||||||
{
|
{
|
||||||
nrec = grub_be_to_cpu32 (node->inode.nextents);
|
nrec = grub_be_to_cpu32 (node->inode.nextents);
|
||||||
@ -323,7 +323,7 @@ index 7e247a32df5c..3b1d8994067f 100644
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -404,7 +515,7 @@ grub_xfs_read_symlink (grub_fshelp_node_t node)
|
@@ -404,7 +515,7 @@ grub_xfs_read_symlink (grub_fshelp_node_
|
||||||
switch (node->inode.format)
|
switch (node->inode.format)
|
||||||
{
|
{
|
||||||
case XFS_INODE_FORMAT_INO:
|
case XFS_INODE_FORMAT_INO:
|
||||||
@ -332,7 +332,7 @@ index 7e247a32df5c..3b1d8994067f 100644
|
|||||||
|
|
||||||
case XFS_INODE_FORMAT_EXT:
|
case XFS_INODE_FORMAT_EXT:
|
||||||
{
|
{
|
||||||
@@ -501,23 +612,18 @@ grub_xfs_iterate_dir (grub_fshelp_node_t dir,
|
@@ -501,23 +612,18 @@ grub_xfs_iterate_dir (grub_fshelp_node_t
|
||||||
{
|
{
|
||||||
case XFS_INODE_FORMAT_INO:
|
case XFS_INODE_FORMAT_INO:
|
||||||
{
|
{
|
||||||
@ -361,7 +361,7 @@ index 7e247a32df5c..3b1d8994067f 100644
|
|||||||
|
|
||||||
/* Synthesize the direntries for `.' and `..'. */
|
/* Synthesize the direntries for `.' and `..'. */
|
||||||
if (iterate_dir_call_hook (diro->ino, ".", &ctx))
|
if (iterate_dir_call_hook (diro->ino, ".", &ctx))
|
||||||
@@ -526,12 +632,10 @@ grub_xfs_iterate_dir (grub_fshelp_node_t dir,
|
@@ -526,12 +632,10 @@ grub_xfs_iterate_dir (grub_fshelp_node_t
|
||||||
if (iterate_dir_call_hook (parent, "..", &ctx))
|
if (iterate_dir_call_hook (parent, "..", &ctx))
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
@ -376,7 +376,7 @@ index 7e247a32df5c..3b1d8994067f 100644
|
|||||||
grub_uint8_t c;
|
grub_uint8_t c;
|
||||||
|
|
||||||
/* inopos might be unaligned. */
|
/* inopos might be unaligned. */
|
||||||
@@ -556,10 +660,7 @@ grub_xfs_iterate_dir (grub_fshelp_node_t dir,
|
@@ -556,10 +660,7 @@ grub_xfs_iterate_dir (grub_fshelp_node_t
|
||||||
return 1;
|
return 1;
|
||||||
de->name[de->len] = c;
|
de->name[de->len] = c;
|
||||||
|
|
||||||
@ -388,7 +388,7 @@ index 7e247a32df5c..3b1d8994067f 100644
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -586,15 +687,11 @@ grub_xfs_iterate_dir (grub_fshelp_node_t dir,
|
@@ -586,15 +687,11 @@ grub_xfs_iterate_dir (grub_fshelp_node_t
|
||||||
>> dirblk_log2);
|
>> dirblk_log2);
|
||||||
blk++)
|
blk++)
|
||||||
{
|
{
|
||||||
@ -408,7 +408,7 @@ index 7e247a32df5c..3b1d8994067f 100644
|
|||||||
|
|
||||||
numread = grub_xfs_read_file (dir, 0, 0,
|
numread = grub_xfs_read_file (dir, 0, 0,
|
||||||
blk << dirblk_log2,
|
blk << dirblk_log2,
|
||||||
@@ -606,13 +703,11 @@ grub_xfs_iterate_dir (grub_fshelp_node_t dir,
|
@@ -606,13 +703,11 @@ grub_xfs_iterate_dir (grub_fshelp_node_t
|
||||||
- grub_be_to_cpu32 (tail->leaf_stale));
|
- grub_be_to_cpu32 (tail->leaf_stale));
|
||||||
|
|
||||||
/* Iterate over all entries within this block. */
|
/* Iterate over all entries within this block. */
|
||||||
@ -423,7 +423,7 @@ index 7e247a32df5c..3b1d8994067f 100644
|
|||||||
freetag = (grub_uint8_t *) direntry;
|
freetag = (grub_uint8_t *) direntry;
|
||||||
|
|
||||||
if (grub_get_unaligned16 (freetag) == 0XFFFF)
|
if (grub_get_unaligned16 (freetag) == 0XFFFF)
|
||||||
@@ -620,14 +715,16 @@ grub_xfs_iterate_dir (grub_fshelp_node_t dir,
|
@@ -620,14 +715,16 @@ grub_xfs_iterate_dir (grub_fshelp_node_t
|
||||||
grub_uint8_t *skip = (freetag + sizeof (grub_uint16_t));
|
grub_uint8_t *skip = (freetag + sizeof (grub_uint16_t));
|
||||||
|
|
||||||
/* This entry is not used, go to the next one. */
|
/* This entry is not used, go to the next one. */
|
||||||
@ -444,7 +444,7 @@ index 7e247a32df5c..3b1d8994067f 100644
|
|||||||
filename[direntry->len] = '\0';
|
filename[direntry->len] = '\0';
|
||||||
|
|
||||||
if (iterate_dir_call_hook (grub_be_to_cpu64(direntry->inode),
|
if (iterate_dir_call_hook (grub_be_to_cpu64(direntry->inode),
|
||||||
@@ -644,8 +741,7 @@ grub_xfs_iterate_dir (grub_fshelp_node_t dir,
|
@@ -644,8 +741,7 @@ grub_xfs_iterate_dir (grub_fshelp_node_t
|
||||||
break;
|
break;
|
||||||
|
|
||||||
/* Select the next directory entry. */
|
/* Select the next directory entry. */
|
||||||
@ -476,6 +476,3 @@ index 7e247a32df5c..3b1d8994067f 100644
|
|||||||
|
|
||||||
grub_xfs_read_inode (data, data->diropen.ino, &data->diropen.inode);
|
grub_xfs_read_inode (data, data->diropen.ino, &data->diropen.inode);
|
||||||
|
|
||||||
--
|
|
||||||
1.8.1.4
|
|
||||||
|
|
||||||
|
@ -1,3 +1,9 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Wed Jul 9 16:26:35 UTC 2014 - dvlaeev@suse.com
|
||||||
|
|
||||||
|
- Fix ppc64le build by fixing
|
||||||
|
grub2-xfs-V5-filesystem-format-support.patch
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Wed Jun 25 09:20:16 UTC 2014 - jack@suse.cz
|
Wed Jun 25 09:20:16 UTC 2014 - jack@suse.cz
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user