diff options
author | Paulo Alcantara <pc@cjr.nz> | 2020-04-21 01:42:57 +0300 |
---|---|---|
committer | Steve French <stfrench@microsoft.com> | 2020-04-23 04:22:08 +0300 |
commit | 65303de829dd6d291a4947c1a31de31896f8a060 (patch) | |
tree | 74667aea74467fa09b4d36e58570e7e977395d09 /drivers/usb/cdns3/cdns3-ti.c | |
parent | d92c7ce41eb7f5d7d9f680a935d59552c5518d3c (diff) | |
download | linux-65303de829dd6d291a4947c1a31de31896f8a060.tar.xz |
cifs: do not share tcons with DFS
This disables tcon re-use for DFS shares.
tcon->dfs_path stores the path that the tcon should connect to when
doing failing over.
If that tcon is used multiple times e.g. 2 mounts using it with
different prefixpath, each will need a different dfs_path but there is
only one tcon. The other solution would be to split the tcon in 2
tcons during failover but that is much harder.
tcons could not be shared with DFS in cifs.ko because in a
DFS namespace like:
//domain/dfsroot -> /serverA/dfsroot, /serverB/dfsroot
//serverA/dfsroot/link -> /serverA/target1/aa/bb
//serverA/dfsroot/link2 -> /serverA/target1/cc/dd
you can see that link and link2 are two DFS links that both resolve to
the same target share (/serverA/target1), so cifs.ko will only contain a
single tcon for both link and link2.
The problem with that is, if we (auto)mount "link" and "link2", cifs.ko
will only contain a single tcon for both DFS links so we couldn't
perform failover or refresh the DFS cache for both links because
tcon->dfs_path was set to either "link" or "link2", but not both --
which is wrong.
Signed-off-by: Paulo Alcantara (SUSE) <pc@cjr.nz>
Reviewed-by: Aurelien Aptel <aaptel@suse.com>
Reviewed-by: Ronnie Sahlberg <lsahlber@redhat.com>
Signed-off-by: Steve French <stfrench@microsoft.com>
Diffstat (limited to 'drivers/usb/cdns3/cdns3-ti.c')
0 files changed, 0 insertions, 0 deletions