Commit abf1b9a8 authored by Pavel Shilovsky's avatar Pavel Shilovsky Committed by Thadeu Lima de Souza Cascardo

CIFS: Add transform header handling callbacks

BugLink: http://bugs.launchpad.net/bugs/1670508

We need to recognize and parse transformed packets in demultiplex
thread to find a corresponsing mid and process it further.
Signed-off-by: default avatarPavel Shilovsky <pshilov@microsoft.com>
(cherry picked from commit 9bb17e09)
Signed-off-by: default avatarJoseph Salisbury <joseph.salisbury@canonical.com>
parent b0485e22
...@@ -438,6 +438,9 @@ struct smb_version_operations { ...@@ -438,6 +438,9 @@ struct smb_version_operations {
struct smb_rqst *); struct smb_rqst *);
/* free transform request */ /* free transform request */
void (*free_transform_rq)(struct smb_rqst *); void (*free_transform_rq)(struct smb_rqst *);
int (*is_transform_hdr)(void *buf);
int (*receive_transform)(struct TCP_Server_Info *,
struct mid_q_entry **);
}; };
struct smb_version_values { struct smb_version_values {
......
...@@ -857,12 +857,19 @@ cifs_demultiplex_thread(void *p) ...@@ -857,12 +857,19 @@ cifs_demultiplex_thread(void *p)
continue; continue;
server->total_read += length; server->total_read += length;
mid_entry = server->ops->find_mid(server, buf); if (server->ops->is_transform_hdr &&
server->ops->receive_transform &&
server->ops->is_transform_hdr(buf)) {
length = server->ops->receive_transform(server,
&mid_entry);
} else {
mid_entry = server->ops->find_mid(server, buf);
if (!mid_entry || !mid_entry->receive) if (!mid_entry || !mid_entry->receive)
length = standard_receive3(server, mid_entry); length = standard_receive3(server, mid_entry);
else else
length = mid_entry->receive(server, mid_entry); length = mid_entry->receive(server, mid_entry);
}
if (length < 0) if (length < 0)
continue; continue;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment