On Thu, Jul 19, 2018 at 11:22:01AM +0200, David Sterba wrote:
> On Thu, Jul 19, 2018 at 08:18:25AM +0000, Gu, Jinxiang wrote:
> > 
> > 
> > > -----Original Message-----
> > > From: Dan Carpenter [mailto:dan.carpen...@oracle.com]
> > > Sent: Thursday, July 19, 2018 4:11 PM
> > > To: Gu, Jinxiang/顾 金香 <g...@cn.fujitsu.com>
> > > Cc: linux-btrfs@vger.kernel.org
> > > Subject: [bug report] btrfs: Add type check when reading a chunk
> > > 
> > > Hello Gu Jinxiang,
> > > 
> > > The patch 72e75ed03c8d: "btrfs: Add type check when reading a chunk"
> > > from Jul 4, 2018, leads to the following static checker warning:
> > > 
> > >   fs/btrfs/volumes.c:6388 btrfs_check_chunk_valid()
> > >   warn: AND to zero '0x4 & 0x1'
> > > 
> > > fs/btrfs/volumes.c
> > >   6356          if (!is_power_of_2(stripe_len) || stripe_len != 
> > > BTRFS_STRIPE_LEN) {
> > >   6357                  btrfs_err(fs_info, "invalid chunk stripe length: 
> > > %llu",
> > >   6358                            stripe_len);
> > >   6359                  return -EIO;
> > >   6360          }
> > >   6361          if (~(BTRFS_BLOCK_GROUP_TYPE_MASK | 
> > > BTRFS_BLOCK_GROUP_PROFILE_MASK) &
> > >   6362              type) {
> > >   6363                  btrfs_err(fs_info, "unrecognized chunk type: 
> > > %llu",
> > >   6364                            ~(BTRFS_BLOCK_GROUP_TYPE_MASK |
> > >   6365                              BTRFS_BLOCK_GROUP_PROFILE_MASK) &
> > >   6366                            btrfs_chunk_type(leaf, chunk));
> > >   6367                  return -EIO;
> > >   6368          }
> > >   6369
> > >   6370          if ((type & BTRFS_BLOCK_GROUP_TYPE_MASK) == 0) {
> > >   6371                  btrfs_err(fs_info, "missing chunk type flag: 
> > > %llu", type);
> > >   6372                  return -EIO;
> > >   6373          }
> > >   6374
> > >   6375          if ((type & BTRFS_BLOCK_GROUP_SYSTEM) &&
> > >   6376              (type & (BTRFS_BLOCK_GROUP_METADATA | 
> > > BTRFS_BLOCK_GROUP_DATA))) {
> > >   6377                  btrfs_err(fs_info,
> > >   6378                          "system chunk with data or metadata type: 
> > > %llu", type);
> > >   6379                  return -EIO;
> > >   6380          }
> > >   6381
> > >   6382          features = 
> > > btrfs_super_incompat_flags(fs_info->super_copy);
> > >   6383          if (features & BTRFS_FEATURE_INCOMPAT_MIXED_GROUPS)
> > >   6384                  mixed = 1;
> > >   6385
> > >   6386          if (!mixed) {
> > >   6387                  if (type &
> > >   6388                      (BTRFS_BLOCK_GROUP_METADATA & 
> > > BTRFS_BLOCK_GROUP_DATA)) {
> > >                              
> > > ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
> > > Was this supposed to be | or perhaps check that both are set?
> > Yes. It should be |.
> > Thank you, I'll send a patch to fix it.
> 
> Not needed, I'll fix the patch directly.

And that leads to failed mount:

[   10.867868] BTRFS error (device vda): mixed chunk type in non-mixed mode: 1
[   10.871084] BTRFS error (device vda): failed to read chunk tree: -5
[   10.908541] BTRFS error (device vda): open_ctree failed

Please send fixed version.
--
To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to