Adds calls to the newer info level for query info using SMB3.1.1 posix extensions.
The remaining two places that call the older query info (non-SMB3.1.1 POSIX)
require passing in the fid and can be updated in a later patch.
Signed-off-by: Steve French <stfrench@microsoft.com>
Reviewed-by: Aurelien Aptel <aaptel@suse.com>
                rc = cifs_get_inode_info_unix(&newinode, full_path, inode->i_sb,
                                              xid);
        else {
+               /* TODO: Add support for calling POSIX query info here, but passing in fid */
                rc = cifs_get_inode_info(&newinode, full_path, buf, inode->i_sb,
                                         xid, fid);
                if (newinode) {
 
        if (rc)
                goto out;
 
+       /* TODO: Add support for calling posix query info but with passing in fid */
        if (tcon->unix_ext)
                rc = cifs_get_inode_info_unix(&inode, full_path, inode->i_sb,
                                              xid);
                if (!is_interrupt_error(rc))
                        mapping_set_error(inode->i_mapping, rc);
 
-               if (tcon->unix_ext)
+               if (tcon->posix_extensions)
+                       rc = smb311_posix_get_inode_info(&inode, full_path, inode->i_sb, xid);
+               else if (tcon->unix_ext)
                        rc = cifs_get_inode_info_unix(&inode, full_path,
                                                      inode->i_sb, xid);
                else
 
        }
 
        convert_delimiter(path, CIFS_DIR_SEP(cifs_sb));
-       rc = cifs_get_inode_info(&inode, path, NULL, sb, xid, NULL);
+       if (tcon->posix_extensions)
+               rc = smb311_posix_get_inode_info(&inode, path, sb, xid);
+       else
+               rc = cifs_get_inode_info(&inode, path, NULL, sb, xid, NULL);
 
 iget_no_retry:
        if (!inode) {
        int rc = 0;
        struct inode *inode = NULL;
 
-       if (tcon->unix_ext)
+       if (tcon->posix_extensions)
+               rc = smb311_posix_get_inode_info(&inode, full_path, parent->i_sb, xid);
+       else if (tcon->unix_ext)
                rc = cifs_get_inode_info_unix(&inode, full_path, parent->i_sb,
                                              xid);
        else
 
                                        cifs_sb_target->local_nls); */
 
        if (rc == 0) {
-               if (pTcon->unix_ext)
+               if (pTcon->posix_extensions)
+                       rc = smb311_posix_get_inode_info(&newinode, full_path, inode->i_sb, xid);
+               else if (pTcon->unix_ext)
                        rc = cifs_get_inode_info_unix(&newinode, full_path,
                                                      inode->i_sb, xid);
                else