mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-09-18 22:14:16 +00:00
fix ufs_isblockset()
Cc: stable@vger.kernel.org Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
This commit is contained in:
parent
8785d84d00
commit
414cf7186d
1 changed files with 7 additions and 3 deletions
|
|
@ -473,15 +473,19 @@ static inline unsigned _ubh_find_last_zero_bit_(
|
||||||
static inline int _ubh_isblockset_(struct ufs_sb_private_info * uspi,
|
static inline int _ubh_isblockset_(struct ufs_sb_private_info * uspi,
|
||||||
struct ufs_buffer_head * ubh, unsigned begin, unsigned block)
|
struct ufs_buffer_head * ubh, unsigned begin, unsigned block)
|
||||||
{
|
{
|
||||||
|
u8 mask;
|
||||||
switch (uspi->s_fpb) {
|
switch (uspi->s_fpb) {
|
||||||
case 8:
|
case 8:
|
||||||
return (*ubh_get_addr (ubh, begin + block) == 0xff);
|
return (*ubh_get_addr (ubh, begin + block) == 0xff);
|
||||||
case 4:
|
case 4:
|
||||||
return (*ubh_get_addr (ubh, begin + (block >> 1)) == (0x0f << ((block & 0x01) << 2)));
|
mask = 0x0f << ((block & 0x01) << 2);
|
||||||
|
return (*ubh_get_addr (ubh, begin + (block >> 1)) & mask) == mask;
|
||||||
case 2:
|
case 2:
|
||||||
return (*ubh_get_addr (ubh, begin + (block >> 2)) == (0x03 << ((block & 0x03) << 1)));
|
mask = 0x03 << ((block & 0x03) << 1);
|
||||||
|
return (*ubh_get_addr (ubh, begin + (block >> 2)) & mask) == mask;
|
||||||
case 1:
|
case 1:
|
||||||
return (*ubh_get_addr (ubh, begin + (block >> 3)) == (0x01 << (block & 0x07)));
|
mask = 0x01 << (block & 0x07);
|
||||||
|
return (*ubh_get_addr (ubh, begin + (block >> 3)) & mask) == mask;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue