[LTP] ftruncate04 broken on kernels without mandatory locking
    Jiri Jaburek 
    jjaburek@redhat.com
       
    Wed Jun  8 17:23:01 CEST 2016
    
    
  
Upstream kernel commit
  9e8925b67a809bb27ce4b7d352d67f25cf1d7fc5
  locks: Allow disabling mandatory locking at compile time
added a config option to remove support for mandatory locking
(mount -o mand, MS_MANDLOCK), which went into v4.5.
Some distributions (like Fedora) already disable it, causing
ftruncate04 to fail:
ftruncate04    0  TINFO  :  TMPDIR does not support mandatory locks
ftruncate04    0  TINFO  :  Found free device '/dev/loop0'
ftruncate04    0  TINFO  :  Formatting /dev/loop0 with ext2 opts=''
extra opts=''
mke2fs 1.42.13 (17-May-2015)
ftruncate04    1  TBROK  :  safe_macros.c:728: ftruncate04.c:247:
mount(/dev/loop0, dir/, ext2, 64, (nil)) failed: errno=EPERM(1):
Operation not permitted
ftruncate04    2  TBROK  :  safe_macros.c:728: Remaining cases broken
and indeed
$ mount /dev/loop0 /mnt/
$ umount /mnt
$ mount /dev/loop0 /mnt/ -o mand
mount: permission denied
The question is how to best fix the testcase - do the mount unsafely
and assume EPERM should be TCONF? Or somehow check kernel config?
Maybe do the mount first without MS_MANDLOCK (to rule out other perm
issues) and then remount with MS_MANDLOCK, checking EPERM?
Any other ideas?
Thanks,
Jiri
    
    
More information about the ltp
mailing list