* [PATCH 1/2] staging: erofs: add requirements field in superblock
@ 2019-06-10 9:36 Gao Xiang
2019-06-11 1:37 ` Chao Yu
0 siblings, 1 reply; 4+ messages in thread
From: Gao Xiang @ 2019-06-10 9:36 UTC (permalink / raw)
To: Chao Yu, Greg Kroah-Hartman, devel
Cc: LKML, linux-erofs, Chao Yu, Miao Xie, weidu.du, Fang Wei,
Gao Xiang, stable
There are some backward incompatible optimizations pending
for months, mainly due to on-disk format expensions.
However, we should ensure that it cannot be mounted with
old kernels. Otherwise, it will causes unexpected behaviors.
Fixes: ba2b77a82022 ("staging: erofs: add super block operations")
Cc: <stable@vger.kernel.org> # 4.19+
Signed-off-by: Gao Xiang <gaoxiang25@huawei.com>
---
drivers/staging/erofs/erofs_fs.h | 11 +++++++++--
drivers/staging/erofs/super.c | 8 ++++++++
2 files changed, 17 insertions(+), 2 deletions(-)
diff --git a/drivers/staging/erofs/erofs_fs.h b/drivers/staging/erofs/erofs_fs.h
index fa52898df006..531821757845 100644
--- a/drivers/staging/erofs/erofs_fs.h
+++ b/drivers/staging/erofs/erofs_fs.h
@@ -17,10 +17,16 @@
#define EROFS_SUPER_MAGIC_V1 0xE0F5E1E2
#define EROFS_SUPER_OFFSET 1024
+/*
+ * Any bits that aren't in EROFS_ALL_REQUIREMENTS should be
+ * incompatible with this kernel version.
+ */
+#define EROFS_ALL_REQUIREMENTS 0
+
struct erofs_super_block {
/* 0 */__le32 magic; /* in the little endian */
/* 4 */__le32 checksum; /* crc32c(super_block) */
-/* 8 */__le32 features;
+/* 8 */__le32 features; /* extra features for the image */
/* 12 */__u8 blkszbits; /* support block_size == PAGE_SIZE only */
/* 13 */__u8 reserved;
@@ -34,8 +40,9 @@ struct erofs_super_block {
/* 44 */__le32 xattr_blkaddr;
/* 48 */__u8 uuid[16]; /* 128-bit uuid for volume */
/* 64 */__u8 volume_name[16]; /* volume name */
+/* 80 */__le32 requirements; /* all mandatory minimum requirements */
-/* 80 */__u8 reserved2[48]; /* 128 bytes */
+/* 84 */__u8 reserved2[44]; /* 128 bytes */
} __packed;
/*
diff --git a/drivers/staging/erofs/super.c b/drivers/staging/erofs/super.c
index f580d4ef77a1..815e5825db59 100644
--- a/drivers/staging/erofs/super.c
+++ b/drivers/staging/erofs/super.c
@@ -104,6 +104,14 @@ static int superblock_read(struct super_block *sb)
goto out;
}
+ /* check if the kernel meets all mandatory requirements */
+ if (le32_to_cpu(layout->requirements) & (~EROFS_ALL_REQUIREMENTS)) {
+ errln("too old to meet minimum requirements: %x supported: %x",
+ le32_to_cpu(layout->requirements),
+ EROFS_ALL_REQUIREMENTS);
+ goto out;
+ }
+
sbi->blocks = le32_to_cpu(layout->blocks);
sbi->meta_blkaddr = le32_to_cpu(layout->meta_blkaddr);
#ifdef CONFIG_EROFS_FS_XATTR
--
2.17.1
^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: [PATCH 1/2] staging: erofs: add requirements field in superblock
2019-06-10 9:36 [PATCH 1/2] staging: erofs: add requirements field in superblock Gao Xiang
@ 2019-06-11 1:37 ` Chao Yu
2019-06-11 1:43 ` Gao Xiang
0 siblings, 1 reply; 4+ messages in thread
From: Chao Yu @ 2019-06-11 1:37 UTC (permalink / raw)
To: Gao Xiang, Greg Kroah-Hartman, devel
Cc: LKML, linux-erofs, Chao Yu, Miao Xie, weidu.du, Fang Wei, stable
On 2019/6/10 17:36, Gao Xiang wrote:
> There are some backward incompatible optimizations pending
> for months, mainly due to on-disk format expensions.
>
> However, we should ensure that it cannot be mounted with
> old kernels. Otherwise, it will causes unexpected behaviors.
>
> Fixes: ba2b77a82022 ("staging: erofs: add super block operations")
> Cc: <stable@vger.kernel.org> # 4.19+
> Signed-off-by: Gao Xiang <gaoxiang25@huawei.com>
> ---
> drivers/staging/erofs/erofs_fs.h | 11 +++++++++--
> drivers/staging/erofs/super.c | 8 ++++++++
> 2 files changed, 17 insertions(+), 2 deletions(-)
>
> diff --git a/drivers/staging/erofs/erofs_fs.h b/drivers/staging/erofs/erofs_fs.h
> index fa52898df006..531821757845 100644
> --- a/drivers/staging/erofs/erofs_fs.h
> +++ b/drivers/staging/erofs/erofs_fs.h
> @@ -17,10 +17,16 @@
> #define EROFS_SUPER_MAGIC_V1 0xE0F5E1E2
> #define EROFS_SUPER_OFFSET 1024
>
> +/*
> + * Any bits that aren't in EROFS_ALL_REQUIREMENTS should be
> + * incompatible with this kernel version.
> + */
> +#define EROFS_ALL_REQUIREMENTS 0
> +
> struct erofs_super_block {
> /* 0 */__le32 magic; /* in the little endian */
> /* 4 */__le32 checksum; /* crc32c(super_block) */
> -/* 8 */__le32 features;
> +/* 8 */__le32 features; /* extra features for the image */
> /* 12 */__u8 blkszbits; /* support block_size == PAGE_SIZE only */
> /* 13 */__u8 reserved;
>
> @@ -34,8 +40,9 @@ struct erofs_super_block {
> /* 44 */__le32 xattr_blkaddr;
> /* 48 */__u8 uuid[16]; /* 128-bit uuid for volume */
> /* 64 */__u8 volume_name[16]; /* volume name */
> +/* 80 */__le32 requirements; /* all mandatory minimum requirements */
>
> -/* 80 */__u8 reserved2[48]; /* 128 bytes */
> +/* 84 */__u8 reserved2[44]; /* 128 bytes */
Xiang,
It needs to update the comment behind reserved2, it's locating at 132 bytes.
> } __packed;
>
> /*
> diff --git a/drivers/staging/erofs/super.c b/drivers/staging/erofs/super.c
> index f580d4ef77a1..815e5825db59 100644
> --- a/drivers/staging/erofs/super.c
> +++ b/drivers/staging/erofs/super.c
> @@ -104,6 +104,14 @@ static int superblock_read(struct super_block *sb)
> goto out;
> }
>
> + /* check if the kernel meets all mandatory requirements */
> + if (le32_to_cpu(layout->requirements) & (~EROFS_ALL_REQUIREMENTS)) {
> + errln("too old to meet minimum requirements: %x supported: %x",
It will be better to give a suggestion to user to upgrade kernel version to
match the image with new layout, otherwise it's just a little confused about
above printed message.
Thanks,
> + le32_to_cpu(layout->requirements),
> + EROFS_ALL_REQUIREMENTS);
> + goto out;
> + }
> +
> sbi->blocks = le32_to_cpu(layout->blocks);
> sbi->meta_blkaddr = le32_to_cpu(layout->meta_blkaddr);
> #ifdef CONFIG_EROFS_FS_XATTR
>
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH 1/2] staging: erofs: add requirements field in superblock
2019-06-11 1:37 ` Chao Yu
@ 2019-06-11 1:43 ` Gao Xiang
2019-06-11 1:47 ` Chao Yu
0 siblings, 1 reply; 4+ messages in thread
From: Gao Xiang @ 2019-06-11 1:43 UTC (permalink / raw)
To: Chao Yu
Cc: Greg Kroah-Hartman, devel, LKML, linux-erofs, Chao Yu, Miao Xie,
weidu.du, Fang Wei, stable
Hi Chao,
On 2019/6/11 9:37, Chao Yu wrote:
> On 2019/6/10 17:36, Gao Xiang wrote:
>> There are some backward incompatible optimizations pending
>> for months, mainly due to on-disk format expensions.
>>
>> However, we should ensure that it cannot be mounted with
>> old kernels. Otherwise, it will causes unexpected behaviors.
>>
>> Fixes: ba2b77a82022 ("staging: erofs: add super block operations")
>> Cc: <stable@vger.kernel.org> # 4.19+
>> Signed-off-by: Gao Xiang <gaoxiang25@huawei.com>
>> ---
>> drivers/staging/erofs/erofs_fs.h | 11 +++++++++--
>> drivers/staging/erofs/super.c | 8 ++++++++
>> 2 files changed, 17 insertions(+), 2 deletions(-)
>>
>> diff --git a/drivers/staging/erofs/erofs_fs.h b/drivers/staging/erofs/erofs_fs.h
>> index fa52898df006..531821757845 100644
>> --- a/drivers/staging/erofs/erofs_fs.h
>> +++ b/drivers/staging/erofs/erofs_fs.h
>> @@ -17,10 +17,16 @@
>> #define EROFS_SUPER_MAGIC_V1 0xE0F5E1E2
>> #define EROFS_SUPER_OFFSET 1024
>>
>> +/*
>> + * Any bits that aren't in EROFS_ALL_REQUIREMENTS should be
>> + * incompatible with this kernel version.
>> + */
>> +#define EROFS_ALL_REQUIREMENTS 0
>> +
>> struct erofs_super_block {
>> /* 0 */__le32 magic; /* in the little endian */
>> /* 4 */__le32 checksum; /* crc32c(super_block) */
>> -/* 8 */__le32 features;
>> +/* 8 */__le32 features; /* extra features for the image */
>> /* 12 */__u8 blkszbits; /* support block_size == PAGE_SIZE only */
>> /* 13 */__u8 reserved;
>>
>> @@ -34,8 +40,9 @@ struct erofs_super_block {
>> /* 44 */__le32 xattr_blkaddr;
>> /* 48 */__u8 uuid[16]; /* 128-bit uuid for volume */
>> /* 64 */__u8 volume_name[16]; /* volume name */
>> +/* 80 */__le32 requirements; /* all mandatory minimum requirements */
>>
>> -/* 80 */__u8 reserved2[48]; /* 128 bytes */
>> +/* 84 */__u8 reserved2[44]; /* 128 bytes */
>
> Xiang,
>
> It needs to update the comment behind reserved2, it's locating at 132 bytes.
I don't get the point... the whole struct is totally 128bytes I think?
>
>> } __packed;
>>
>> /*
>> diff --git a/drivers/staging/erofs/super.c b/drivers/staging/erofs/super.c
>> index f580d4ef77a1..815e5825db59 100644
>> --- a/drivers/staging/erofs/super.c
>> +++ b/drivers/staging/erofs/super.c
>> @@ -104,6 +104,14 @@ static int superblock_read(struct super_block *sb)
>> goto out;
>> }
>>
>> + /* check if the kernel meets all mandatory requirements */
>> + if (le32_to_cpu(layout->requirements) & (~EROFS_ALL_REQUIREMENTS)) {
>> + errln("too old to meet minimum requirements: %x supported: %x",
>
> It will be better to give a suggestion to user to upgrade kernel version to
> match the image with new layout, otherwise it's just a little confused about
> above printed message.
OK, I will refine the printed message :)
Thanks,
Gao Xiang
>
> Thanks,
>
>> + le32_to_cpu(layout->requirements),
>> + EROFS_ALL_REQUIREMENTS);
>> + goto out;
>> + }
>> +
>> sbi->blocks = le32_to_cpu(layout->blocks);
>> sbi->meta_blkaddr = le32_to_cpu(layout->meta_blkaddr);
>> #ifdef CONFIG_EROFS_FS_XATTR
>>
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: [PATCH 1/2] staging: erofs: add requirements field in superblock
2019-06-11 1:43 ` Gao Xiang
@ 2019-06-11 1:47 ` Chao Yu
0 siblings, 0 replies; 4+ messages in thread
From: Chao Yu @ 2019-06-11 1:47 UTC (permalink / raw)
To: Gao Xiang
Cc: Greg Kroah-Hartman, devel, LKML, linux-erofs, Chao Yu, Miao Xie,
weidu.du, Fang Wei, stable
On 2019/6/11 9:43, Gao Xiang wrote:
> Hi Chao,
>
> On 2019/6/11 9:37, Chao Yu wrote:
>> On 2019/6/10 17:36, Gao Xiang wrote:
>>> There are some backward incompatible optimizations pending
>>> for months, mainly due to on-disk format expensions.
>>>
>>> However, we should ensure that it cannot be mounted with
>>> old kernels. Otherwise, it will causes unexpected behaviors.
>>>
>>> Fixes: ba2b77a82022 ("staging: erofs: add super block operations")
>>> Cc: <stable@vger.kernel.org> # 4.19+
>>> Signed-off-by: Gao Xiang <gaoxiang25@huawei.com>
>>> ---
>>> drivers/staging/erofs/erofs_fs.h | 11 +++++++++--
>>> drivers/staging/erofs/super.c | 8 ++++++++
>>> 2 files changed, 17 insertions(+), 2 deletions(-)
>>>
>>> diff --git a/drivers/staging/erofs/erofs_fs.h b/drivers/staging/erofs/erofs_fs.h
>>> index fa52898df006..531821757845 100644
>>> --- a/drivers/staging/erofs/erofs_fs.h
>>> +++ b/drivers/staging/erofs/erofs_fs.h
>>> @@ -17,10 +17,16 @@
>>> #define EROFS_SUPER_MAGIC_V1 0xE0F5E1E2
>>> #define EROFS_SUPER_OFFSET 1024
>>>
>>> +/*
>>> + * Any bits that aren't in EROFS_ALL_REQUIREMENTS should be
>>> + * incompatible with this kernel version.
>>> + */
>>> +#define EROFS_ALL_REQUIREMENTS 0
>>> +
>>> struct erofs_super_block {
>>> /* 0 */__le32 magic; /* in the little endian */
>>> /* 4 */__le32 checksum; /* crc32c(super_block) */
>>> -/* 8 */__le32 features;
>>> +/* 8 */__le32 features; /* extra features for the image */
>>> /* 12 */__u8 blkszbits; /* support block_size == PAGE_SIZE only */
>>> /* 13 */__u8 reserved;
>>>
>>> @@ -34,8 +40,9 @@ struct erofs_super_block {
>>> /* 44 */__le32 xattr_blkaddr;
>>> /* 48 */__u8 uuid[16]; /* 128-bit uuid for volume */
>>> /* 64 */__u8 volume_name[16]; /* volume name */
>>> +/* 80 */__le32 requirements; /* all mandatory minimum requirements */
>>>
>>> -/* 80 */__u8 reserved2[48]; /* 128 bytes */
>>> +/* 84 */__u8 reserved2[44]; /* 128 bytes */
>>
>> Xiang,
>>
>> It needs to update the comment behind reserved2, it's locating at 132 bytes.
>
> I don't get the point... the whole struct is totally 128bytes I think?
Xiang, I misunderstood meaning of comments, please ignore it, sorry. :)
Thanks,
>
>>
>>> } __packed;
>>>
>>> /*
>>> diff --git a/drivers/staging/erofs/super.c b/drivers/staging/erofs/super.c
>>> index f580d4ef77a1..815e5825db59 100644
>>> --- a/drivers/staging/erofs/super.c
>>> +++ b/drivers/staging/erofs/super.c
>>> @@ -104,6 +104,14 @@ static int superblock_read(struct super_block *sb)
>>> goto out;
>>> }
>>>
>>> + /* check if the kernel meets all mandatory requirements */
>>> + if (le32_to_cpu(layout->requirements) & (~EROFS_ALL_REQUIREMENTS)) {
>>> + errln("too old to meet minimum requirements: %x supported: %x",
>>
>> It will be better to give a suggestion to user to upgrade kernel version to
>> match the image with new layout, otherwise it's just a little confused about
>> above printed message.
>
> OK, I will refine the printed message :)
>
> Thanks,
> Gao Xiang
>
>>
>> Thanks,
>>
>>> + le32_to_cpu(layout->requirements),
>>> + EROFS_ALL_REQUIREMENTS);
>>> + goto out;
>>> + }
>>> +
>>> sbi->blocks = le32_to_cpu(layout->blocks);
>>> sbi->meta_blkaddr = le32_to_cpu(layout->meta_blkaddr);
>>> #ifdef CONFIG_EROFS_FS_XATTR
>>>
> .
>
^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2019-06-11 1:48 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-06-10 9:36 [PATCH 1/2] staging: erofs: add requirements field in superblock Gao Xiang
2019-06-11 1:37 ` Chao Yu
2019-06-11 1:43 ` Gao Xiang
2019-06-11 1:47 ` Chao Yu
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).