diff options
author | Pavel Shilovsky <piastry@etersoft.ru> | 2012-05-17 05:02:51 -0400 |
---|---|---|
committer | Pavel Shilovsky <pshilovsky@samba.org> | 2012-05-23 04:33:09 -0400 |
commit | eb37871118abfc30629ee2bef11013eddb42c756 (patch) | |
tree | 9ee1a048ccda5ce06e626af41a2eb83cbba6fce9 /fs/cifs/cifssmb.c | |
parent | 1887f60103aaeeeb7a3fbf3b366d626043873164 (diff) |
CIFS: Move protocol specific part from cifs_readv_receive to ops struct
Acked-by: Shirish Pargaonkar <shirishpargaonkar@gmail.com>
Reviewed-by: Jeff Layton <jlayton@redhat.com>
Signed-off-by: Pavel Shilovsky <piastry@etersoft.ru>
Signed-off-by: Steve French <sfrench@us.ibm.com>
Diffstat (limited to 'fs/cifs/cifssmb.c')
-rw-r--r-- | fs/cifs/cifssmb.c | 34 |
1 files changed, 7 insertions, 27 deletions
diff --git a/fs/cifs/cifssmb.c b/fs/cifs/cifssmb.c index 77463f701f01..b1f375135f48 100644 --- a/fs/cifs/cifssmb.c +++ b/fs/cifs/cifssmb.c | |||
@@ -1411,27 +1411,6 @@ cifs_readv_discard(struct TCP_Server_Info *server, struct mid_q_entry *mid) | |||
1411 | return 0; | 1411 | return 0; |
1412 | } | 1412 | } |
1413 | 1413 | ||
1414 | static inline size_t | ||
1415 | read_rsp_size(void) | ||
1416 | { | ||
1417 | return sizeof(READ_RSP); | ||
1418 | } | ||
1419 | |||
1420 | static inline unsigned int | ||
1421 | read_data_offset(char *buf) | ||
1422 | { | ||
1423 | READ_RSP *rsp = (READ_RSP *)buf; | ||
1424 | return le16_to_cpu(rsp->DataOffset); | ||
1425 | } | ||
1426 | |||
1427 | static inline unsigned int | ||
1428 | read_data_length(char *buf) | ||
1429 | { | ||
1430 | READ_RSP *rsp = (READ_RSP *)buf; | ||
1431 | return (le16_to_cpu(rsp->DataLengthHigh) << 16) + | ||
1432 | le16_to_cpu(rsp->DataLength); | ||
1433 | } | ||
1434 | |||
1435 | static int | 1414 | static int |
1436 | cifs_readv_receive(struct TCP_Server_Info *server, struct mid_q_entry *mid) | 1415 | cifs_readv_receive(struct TCP_Server_Info *server, struct mid_q_entry *mid) |
1437 | { | 1416 | { |
@@ -1449,7 +1428,7 @@ cifs_readv_receive(struct TCP_Server_Info *server, struct mid_q_entry *mid) | |||
1449 | * can if there's not enough data. At this point, we've read down to | 1428 | * can if there's not enough data. At this point, we've read down to |
1450 | * the Mid. | 1429 | * the Mid. |
1451 | */ | 1430 | */ |
1452 | len = min_t(unsigned int, buflen, read_rsp_size()) - | 1431 | len = min_t(unsigned int, buflen, server->vals->read_rsp_size) - |
1453 | HEADER_SIZE(server) + 1; | 1432 | HEADER_SIZE(server) + 1; |
1454 | 1433 | ||
1455 | rdata->iov[0].iov_base = buf + HEADER_SIZE(server) - 1; | 1434 | rdata->iov[0].iov_base = buf + HEADER_SIZE(server) - 1; |
@@ -1461,7 +1440,7 @@ cifs_readv_receive(struct TCP_Server_Info *server, struct mid_q_entry *mid) | |||
1461 | server->total_read += length; | 1440 | server->total_read += length; |
1462 | 1441 | ||
1463 | /* Was the SMB read successful? */ | 1442 | /* Was the SMB read successful? */ |
1464 | rdata->result = map_smb_to_linux_error(buf, false); | 1443 | rdata->result = server->ops->map_error(buf, false); |
1465 | if (rdata->result != 0) { | 1444 | if (rdata->result != 0) { |
1466 | cFYI(1, "%s: server returned error %d", __func__, | 1445 | cFYI(1, "%s: server returned error %d", __func__, |
1467 | rdata->result); | 1446 | rdata->result); |
@@ -1469,14 +1448,15 @@ cifs_readv_receive(struct TCP_Server_Info *server, struct mid_q_entry *mid) | |||
1469 | } | 1448 | } |
1470 | 1449 | ||
1471 | /* Is there enough to get to the rest of the READ_RSP header? */ | 1450 | /* Is there enough to get to the rest of the READ_RSP header? */ |
1472 | if (server->total_read < read_rsp_size()) { | 1451 | if (server->total_read < server->vals->read_rsp_size) { |
1473 | cFYI(1, "%s: server returned short header. got=%u expected=%zu", | 1452 | cFYI(1, "%s: server returned short header. got=%u expected=%zu", |
1474 | __func__, server->total_read, read_rsp_size()); | 1453 | __func__, server->total_read, |
1454 | server->vals->read_rsp_size); | ||
1475 | rdata->result = -EIO; | 1455 | rdata->result = -EIO; |
1476 | return cifs_readv_discard(server, mid); | 1456 | return cifs_readv_discard(server, mid); |
1477 | } | 1457 | } |
1478 | 1458 | ||
1479 | data_offset = read_data_offset(buf) + 4; | 1459 | data_offset = server->ops->read_data_offset(buf) + 4; |
1480 | if (data_offset < server->total_read) { | 1460 | if (data_offset < server->total_read) { |
1481 | /* | 1461 | /* |
1482 | * win2k8 sometimes sends an offset of 0 when the read | 1462 | * win2k8 sometimes sends an offset of 0 when the read |
@@ -1515,7 +1495,7 @@ cifs_readv_receive(struct TCP_Server_Info *server, struct mid_q_entry *mid) | |||
1515 | rdata->iov[0].iov_base, rdata->iov[0].iov_len); | 1495 | rdata->iov[0].iov_base, rdata->iov[0].iov_len); |
1516 | 1496 | ||
1517 | /* how much data is in the response? */ | 1497 | /* how much data is in the response? */ |
1518 | data_len = read_data_length(buf); | 1498 | data_len = server->ops->read_data_length(buf); |
1519 | if (data_offset + data_len > buflen) { | 1499 | if (data_offset + data_len > buflen) { |
1520 | /* data_len is corrupt -- discard frame */ | 1500 | /* data_len is corrupt -- discard frame */ |
1521 | rdata->result = -EIO; | 1501 | rdata->result = -EIO; |