• M
    locks: use file_inode() · 6343a212
    Miklos Szeredi 提交于
    (Another one for the f_path debacle.)
    
    ltp fcntl33 testcase caused an Oops in selinux_file_send_sigiotask.
    
    The reason is that generic_add_lease() used filp->f_path.dentry->inode
    while all the others use file_inode().  This makes a difference for files
    opened on overlayfs since the former will point to the overlay inode the
    latter to the underlying inode.
    
    So generic_add_lease() added the lease to the overlay inode and
    generic_delete_lease() removed it from the underlying inode.  When the file
    was released the lease remained on the overlay inode's lock list, resulting
    in use after free.
    Reported-by: NEryu Guan <eguan@redhat.com>
    Fixes: 4bacc9c9 ("overlayfs: Make f_path always point to the overlay and f_inode to the underlay")
    Cc: <stable@vger.kernel.org>
    Signed-off-by: NMiklos Szeredi <mszeredi@redhat.com>
    Reviewed-by: NJeff Layton <jlayton@redhat.com>
    Signed-off-by: NJ. Bruce Fields <bfields@redhat.com>
    6343a212
locks.c 71.5 KB