cifs: is_network_name_deleted should return a bool
Currently, is_network_name_deleted and it's implementations do not return anything if the network name did get deleted. So the function doesn't fully achieve what it advertizes. Changed the function to return a bool instead. It will now return true if the error returned is STATUS_NETWORK_NAME_DELETED and the share (tree id) was found to be connected. It returns false otherwise. Signed-off-by: Shyam Prasad N <sprasad@microsoft.com> Acked-by: Paulo Alcantara (SUSE) <pc@manguebit.com> Signed-off-by: Steve French <stfrench@microsoft.com>
This commit is contained in:
parent
bf99f6be2d
commit
c071b34f62
@ -532,7 +532,7 @@ struct smb_version_operations {
|
||||
/* Check for STATUS_IO_TIMEOUT */
|
||||
bool (*is_status_io_timeout)(char *buf);
|
||||
/* Check for STATUS_NETWORK_NAME_DELETED */
|
||||
void (*is_network_name_deleted)(char *buf, struct TCP_Server_Info *srv);
|
||||
bool (*is_network_name_deleted)(char *buf, struct TCP_Server_Info *srv);
|
||||
};
|
||||
|
||||
struct smb_version_values {
|
||||
|
@ -1226,9 +1226,14 @@ next_pdu:
|
||||
if (mids[i] != NULL) {
|
||||
mids[i]->resp_buf_size = server->pdu_size;
|
||||
|
||||
if (bufs[i] && server->ops->is_network_name_deleted)
|
||||
server->ops->is_network_name_deleted(bufs[i],
|
||||
server);
|
||||
if (bufs[i] != NULL) {
|
||||
if (server->ops->is_network_name_deleted &&
|
||||
server->ops->is_network_name_deleted(bufs[i],
|
||||
server)) {
|
||||
cifs_server_dbg(FYI,
|
||||
"Share deleted. Reconnect needed");
|
||||
}
|
||||
}
|
||||
|
||||
if (!mids[i]->multiRsp || mids[i]->multiEnd)
|
||||
mids[i]->callback(mids[i]);
|
||||
|
@ -2395,7 +2395,7 @@ smb2_is_status_io_timeout(char *buf)
|
||||
return false;
|
||||
}
|
||||
|
||||
static void
|
||||
static bool
|
||||
smb2_is_network_name_deleted(char *buf, struct TCP_Server_Info *server)
|
||||
{
|
||||
struct smb2_hdr *shdr = (struct smb2_hdr *)buf;
|
||||
@ -2404,7 +2404,7 @@ smb2_is_network_name_deleted(char *buf, struct TCP_Server_Info *server)
|
||||
struct cifs_tcon *tcon;
|
||||
|
||||
if (shdr->Status != STATUS_NETWORK_NAME_DELETED)
|
||||
return;
|
||||
return false;
|
||||
|
||||
/* If server is a channel, select the primary channel */
|
||||
pserver = CIFS_SERVER_IS_CHAN(server) ? server->primary_server : server;
|
||||
@ -2419,11 +2419,13 @@ smb2_is_network_name_deleted(char *buf, struct TCP_Server_Info *server)
|
||||
spin_unlock(&cifs_tcp_ses_lock);
|
||||
pr_warn_once("Server share %s deleted.\n",
|
||||
tcon->tree_name);
|
||||
return;
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
spin_unlock(&cifs_tcp_ses_lock);
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
static int
|
||||
|
Loading…
x
Reference in New Issue
Block a user