Commit f046d71e authored by Enzo Matsumiya's avatar Enzo Matsumiya Committed by Steve French

smb: client: insert compression check/call on write requests

On smb2_async_writev(), set CIFS_COMPRESS_REQ on request flags if
should_compress() returns true.

On smb_send_rqst() check the flags, and compress and send the request to
the server.

(*) If the compression fails with -EMSGSIZE (i.e. compressed size is >=
uncompressed size), the original uncompressed request is sent instead.
Signed-off-by: default avatarEnzo Matsumiya <ematsumiya@suse.de>
Signed-off-by: default avatarSteve French <stfrench@microsoft.com>
parent d14bbfff
...@@ -42,6 +42,7 @@ ...@@ -42,6 +42,7 @@
#include "dfs_cache.h" #include "dfs_cache.h"
#endif #endif
#include "cached_dir.h" #include "cached_dir.h"
#include "compress.h"
/* /*
* The following table defines the expected "StructureSize" of SMB2 requests * The following table defines the expected "StructureSize" of SMB2 requests
...@@ -5020,6 +5021,10 @@ smb2_async_writev(struct cifs_io_subrequest *wdata) ...@@ -5020,6 +5021,10 @@ smb2_async_writev(struct cifs_io_subrequest *wdata)
flags |= CIFS_HAS_CREDITS; flags |= CIFS_HAS_CREDITS;
} }
/* XXX: compression + encryption is unsupported for now */
if (((flags & CIFS_TRANSFORM_REQ) != CIFS_TRANSFORM_REQ) && should_compress(tcon, &rqst))
flags |= CIFS_COMPRESS_REQ;
rc = cifs_call_async(server, &rqst, NULL, smb2_writev_callback, NULL, rc = cifs_call_async(server, &rqst, NULL, smb2_writev_callback, NULL,
wdata, flags, &wdata->credits); wdata, flags, &wdata->credits);
/* Can't touch wdata if rc == 0 */ /* Can't touch wdata if rc == 0 */
......
...@@ -28,6 +28,7 @@ ...@@ -28,6 +28,7 @@
#include "cifs_debug.h" #include "cifs_debug.h"
#include "smb2proto.h" #include "smb2proto.h"
#include "smbdirect.h" #include "smbdirect.h"
#include "compress.h"
/* Max number of iovectors we can use off the stack when sending requests. */ /* Max number of iovectors we can use off the stack when sending requests. */
#define CIFS_MAX_IOV_SIZE 8 #define CIFS_MAX_IOV_SIZE 8
...@@ -432,6 +433,9 @@ smb_send_rqst(struct TCP_Server_Info *server, int num_rqst, ...@@ -432,6 +433,9 @@ smb_send_rqst(struct TCP_Server_Info *server, int num_rqst,
struct kvec *iov; struct kvec *iov;
int rc; int rc;
if (flags & CIFS_COMPRESS_REQ)
return smb_compress(server, &rqst[0], __smb_send_rqst);
if (!(flags & CIFS_TRANSFORM_REQ)) if (!(flags & CIFS_TRANSFORM_REQ))
return __smb_send_rqst(server, num_rqst, rqst); return __smb_send_rqst(server, num_rqst, rqst);
......
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