diff options
Diffstat (limited to 'net/sunrpc/rpcb_clnt.c')
-rw-r--r-- | net/sunrpc/rpcb_clnt.c | 46 |
1 files changed, 20 insertions, 26 deletions
diff --git a/net/sunrpc/rpcb_clnt.c b/net/sunrpc/rpcb_clnt.c index 63912a1a2983..c652e4cc9fe9 100644 --- a/net/sunrpc/rpcb_clnt.c +++ b/net/sunrpc/rpcb_clnt.c | |||
@@ -706,18 +706,16 @@ static void rpcb_enc_mapping(struct rpc_rqst *req, struct xdr_stream *xdr, | |||
706 | *p = cpu_to_be32(rpcb->r_port); | 706 | *p = cpu_to_be32(rpcb->r_port); |
707 | } | 707 | } |
708 | 708 | ||
709 | static int rpcb_dec_getport(struct rpc_rqst *req, __be32 *p, | 709 | static int rpcb_dec_getport(struct rpc_rqst *req, struct xdr_stream *xdr, |
710 | struct rpcbind_args *rpcb) | 710 | struct rpcbind_args *rpcb) |
711 | { | 711 | { |
712 | struct rpc_task *task = req->rq_task; | 712 | struct rpc_task *task = req->rq_task; |
713 | struct xdr_stream xdr; | ||
714 | unsigned long port; | 713 | unsigned long port; |
715 | 714 | __be32 *p; | |
716 | xdr_init_decode(&xdr, &req->rq_rcv_buf, p); | ||
717 | 715 | ||
718 | rpcb->r_port = 0; | 716 | rpcb->r_port = 0; |
719 | 717 | ||
720 | p = xdr_inline_decode(&xdr, 4); | 718 | p = xdr_inline_decode(xdr, 4); |
721 | if (unlikely(p == NULL)) | 719 | if (unlikely(p == NULL)) |
722 | return -EIO; | 720 | return -EIO; |
723 | 721 | ||
@@ -731,20 +729,18 @@ static int rpcb_dec_getport(struct rpc_rqst *req, __be32 *p, | |||
731 | return 0; | 729 | return 0; |
732 | } | 730 | } |
733 | 731 | ||
734 | static int rpcb_dec_set(struct rpc_rqst *req, __be32 *p, | 732 | static int rpcb_dec_set(struct rpc_rqst *req, struct xdr_stream *xdr, |
735 | unsigned int *boolp) | 733 | unsigned int *boolp) |
736 | { | 734 | { |
737 | struct rpc_task *task = req->rq_task; | 735 | struct rpc_task *task = req->rq_task; |
738 | struct xdr_stream xdr; | 736 | __be32 *p; |
739 | |||
740 | xdr_init_decode(&xdr, &req->rq_rcv_buf, p); | ||
741 | 737 | ||
742 | p = xdr_inline_decode(&xdr, 4); | 738 | p = xdr_inline_decode(xdr, 4); |
743 | if (unlikely(p == NULL)) | 739 | if (unlikely(p == NULL)) |
744 | return -EIO; | 740 | return -EIO; |
745 | 741 | ||
746 | *boolp = 0; | 742 | *boolp = 0; |
747 | if (*p) | 743 | if (*p != xdr_zero) |
748 | *boolp = 1; | 744 | *boolp = 1; |
749 | 745 | ||
750 | dprintk("RPC: %5u RPCB_%s call %s\n", | 746 | dprintk("RPC: %5u RPCB_%s call %s\n", |
@@ -785,20 +781,18 @@ static void rpcb_enc_getaddr(struct rpc_rqst *req, struct xdr_stream *xdr, | |||
785 | encode_rpcb_string(xdr, rpcb->r_owner, RPCB_MAXOWNERLEN); | 781 | encode_rpcb_string(xdr, rpcb->r_owner, RPCB_MAXOWNERLEN); |
786 | } | 782 | } |
787 | 783 | ||
788 | static int rpcb_dec_getaddr(struct rpc_rqst *req, __be32 *p, | 784 | static int rpcb_dec_getaddr(struct rpc_rqst *req, struct xdr_stream *xdr, |
789 | struct rpcbind_args *rpcb) | 785 | struct rpcbind_args *rpcb) |
790 | { | 786 | { |
791 | struct sockaddr_storage address; | 787 | struct sockaddr_storage address; |
792 | struct sockaddr *sap = (struct sockaddr *)&address; | 788 | struct sockaddr *sap = (struct sockaddr *)&address; |
793 | struct rpc_task *task = req->rq_task; | 789 | struct rpc_task *task = req->rq_task; |
794 | struct xdr_stream xdr; | 790 | __be32 *p; |
795 | u32 len; | 791 | u32 len; |
796 | 792 | ||
797 | rpcb->r_port = 0; | 793 | rpcb->r_port = 0; |
798 | 794 | ||
799 | xdr_init_decode(&xdr, &req->rq_rcv_buf, p); | 795 | p = xdr_inline_decode(xdr, 4); |
800 | |||
801 | p = xdr_inline_decode(&xdr, 4); | ||
802 | if (unlikely(p == NULL)) | 796 | if (unlikely(p == NULL)) |
803 | goto out_fail; | 797 | goto out_fail; |
804 | len = be32_to_cpup(p); | 798 | len = be32_to_cpup(p); |
@@ -816,7 +810,7 @@ static int rpcb_dec_getaddr(struct rpc_rqst *req, __be32 *p, | |||
816 | if (unlikely(len > RPCBIND_MAXUADDRLEN)) | 810 | if (unlikely(len > RPCBIND_MAXUADDRLEN)) |
817 | goto out_fail; | 811 | goto out_fail; |
818 | 812 | ||
819 | p = xdr_inline_decode(&xdr, len); | 813 | p = xdr_inline_decode(xdr, len); |
820 | if (unlikely(p == NULL)) | 814 | if (unlikely(p == NULL)) |
821 | goto out_fail; | 815 | goto out_fail; |
822 | dprintk("RPC: %5u RPCB_%s reply: %s\n", task->tk_pid, | 816 | dprintk("RPC: %5u RPCB_%s reply: %s\n", task->tk_pid, |
@@ -843,7 +837,7 @@ static struct rpc_procinfo rpcb_procedures2[] = { | |||
843 | [RPCBPROC_SET] = { | 837 | [RPCBPROC_SET] = { |
844 | .p_proc = RPCBPROC_SET, | 838 | .p_proc = RPCBPROC_SET, |
845 | .p_encode = (kxdreproc_t)rpcb_enc_mapping, | 839 | .p_encode = (kxdreproc_t)rpcb_enc_mapping, |
846 | .p_decode = (kxdrproc_t)rpcb_dec_set, | 840 | .p_decode = (kxdrdproc_t)rpcb_dec_set, |
847 | .p_arglen = RPCB_mappingargs_sz, | 841 | .p_arglen = RPCB_mappingargs_sz, |
848 | .p_replen = RPCB_setres_sz, | 842 | .p_replen = RPCB_setres_sz, |
849 | .p_statidx = RPCBPROC_SET, | 843 | .p_statidx = RPCBPROC_SET, |
@@ -853,7 +847,7 @@ static struct rpc_procinfo rpcb_procedures2[] = { | |||
853 | [RPCBPROC_UNSET] = { | 847 | [RPCBPROC_UNSET] = { |
854 | .p_proc = RPCBPROC_UNSET, | 848 | .p_proc = RPCBPROC_UNSET, |
855 | .p_encode = (kxdreproc_t)rpcb_enc_mapping, | 849 | .p_encode = (kxdreproc_t)rpcb_enc_mapping, |
856 | .p_decode = (kxdrproc_t)rpcb_dec_set, | 850 | .p_decode = (kxdrdproc_t)rpcb_dec_set, |
857 | .p_arglen = RPCB_mappingargs_sz, | 851 | .p_arglen = RPCB_mappingargs_sz, |
858 | .p_replen = RPCB_setres_sz, | 852 | .p_replen = RPCB_setres_sz, |
859 | .p_statidx = RPCBPROC_UNSET, | 853 | .p_statidx = RPCBPROC_UNSET, |
@@ -863,7 +857,7 @@ static struct rpc_procinfo rpcb_procedures2[] = { | |||
863 | [RPCBPROC_GETPORT] = { | 857 | [RPCBPROC_GETPORT] = { |
864 | .p_proc = RPCBPROC_GETPORT, | 858 | .p_proc = RPCBPROC_GETPORT, |
865 | .p_encode = (kxdreproc_t)rpcb_enc_mapping, | 859 | .p_encode = (kxdreproc_t)rpcb_enc_mapping, |
866 | .p_decode = (kxdrproc_t)rpcb_dec_getport, | 860 | .p_decode = (kxdrdproc_t)rpcb_dec_getport, |
867 | .p_arglen = RPCB_mappingargs_sz, | 861 | .p_arglen = RPCB_mappingargs_sz, |
868 | .p_replen = RPCB_getportres_sz, | 862 | .p_replen = RPCB_getportres_sz, |
869 | .p_statidx = RPCBPROC_GETPORT, | 863 | .p_statidx = RPCBPROC_GETPORT, |
@@ -876,7 +870,7 @@ static struct rpc_procinfo rpcb_procedures3[] = { | |||
876 | [RPCBPROC_SET] = { | 870 | [RPCBPROC_SET] = { |
877 | .p_proc = RPCBPROC_SET, | 871 | .p_proc = RPCBPROC_SET, |
878 | .p_encode = (kxdreproc_t)rpcb_enc_getaddr, | 872 | .p_encode = (kxdreproc_t)rpcb_enc_getaddr, |
879 | .p_decode = (kxdrproc_t)rpcb_dec_set, | 873 | .p_decode = (kxdrdproc_t)rpcb_dec_set, |
880 | .p_arglen = RPCB_getaddrargs_sz, | 874 | .p_arglen = RPCB_getaddrargs_sz, |
881 | .p_replen = RPCB_setres_sz, | 875 | .p_replen = RPCB_setres_sz, |
882 | .p_statidx = RPCBPROC_SET, | 876 | .p_statidx = RPCBPROC_SET, |
@@ -886,7 +880,7 @@ static struct rpc_procinfo rpcb_procedures3[] = { | |||
886 | [RPCBPROC_UNSET] = { | 880 | [RPCBPROC_UNSET] = { |
887 | .p_proc = RPCBPROC_UNSET, | 881 | .p_proc = RPCBPROC_UNSET, |
888 | .p_encode = (kxdreproc_t)rpcb_enc_getaddr, | 882 | .p_encode = (kxdreproc_t)rpcb_enc_getaddr, |
889 | .p_decode = (kxdrproc_t)rpcb_dec_set, | 883 | .p_decode = (kxdrdproc_t)rpcb_dec_set, |
890 | .p_arglen = RPCB_getaddrargs_sz, | 884 | .p_arglen = RPCB_getaddrargs_sz, |
891 | .p_replen = RPCB_setres_sz, | 885 | .p_replen = RPCB_setres_sz, |
892 | .p_statidx = RPCBPROC_UNSET, | 886 | .p_statidx = RPCBPROC_UNSET, |
@@ -896,7 +890,7 @@ static struct rpc_procinfo rpcb_procedures3[] = { | |||
896 | [RPCBPROC_GETADDR] = { | 890 | [RPCBPROC_GETADDR] = { |
897 | .p_proc = RPCBPROC_GETADDR, | 891 | .p_proc = RPCBPROC_GETADDR, |
898 | .p_encode = (kxdreproc_t)rpcb_enc_getaddr, | 892 | .p_encode = (kxdreproc_t)rpcb_enc_getaddr, |
899 | .p_decode = (kxdrproc_t)rpcb_dec_getaddr, | 893 | .p_decode = (kxdrdproc_t)rpcb_dec_getaddr, |
900 | .p_arglen = RPCB_getaddrargs_sz, | 894 | .p_arglen = RPCB_getaddrargs_sz, |
901 | .p_replen = RPCB_getaddrres_sz, | 895 | .p_replen = RPCB_getaddrres_sz, |
902 | .p_statidx = RPCBPROC_GETADDR, | 896 | .p_statidx = RPCBPROC_GETADDR, |
@@ -909,7 +903,7 @@ static struct rpc_procinfo rpcb_procedures4[] = { | |||
909 | [RPCBPROC_SET] = { | 903 | [RPCBPROC_SET] = { |
910 | .p_proc = RPCBPROC_SET, | 904 | .p_proc = RPCBPROC_SET, |
911 | .p_encode = (kxdreproc_t)rpcb_enc_getaddr, | 905 | .p_encode = (kxdreproc_t)rpcb_enc_getaddr, |
912 | .p_decode = (kxdrproc_t)rpcb_dec_set, | 906 | .p_decode = (kxdrdproc_t)rpcb_dec_set, |
913 | .p_arglen = RPCB_getaddrargs_sz, | 907 | .p_arglen = RPCB_getaddrargs_sz, |
914 | .p_replen = RPCB_setres_sz, | 908 | .p_replen = RPCB_setres_sz, |
915 | .p_statidx = RPCBPROC_SET, | 909 | .p_statidx = RPCBPROC_SET, |
@@ -919,7 +913,7 @@ static struct rpc_procinfo rpcb_procedures4[] = { | |||
919 | [RPCBPROC_UNSET] = { | 913 | [RPCBPROC_UNSET] = { |
920 | .p_proc = RPCBPROC_UNSET, | 914 | .p_proc = RPCBPROC_UNSET, |
921 | .p_encode = (kxdreproc_t)rpcb_enc_getaddr, | 915 | .p_encode = (kxdreproc_t)rpcb_enc_getaddr, |
922 | .p_decode = (kxdrproc_t)rpcb_dec_set, | 916 | .p_decode = (kxdrdproc_t)rpcb_dec_set, |
923 | .p_arglen = RPCB_getaddrargs_sz, | 917 | .p_arglen = RPCB_getaddrargs_sz, |
924 | .p_replen = RPCB_setres_sz, | 918 | .p_replen = RPCB_setres_sz, |
925 | .p_statidx = RPCBPROC_UNSET, | 919 | .p_statidx = RPCBPROC_UNSET, |
@@ -929,7 +923,7 @@ static struct rpc_procinfo rpcb_procedures4[] = { | |||
929 | [RPCBPROC_GETADDR] = { | 923 | [RPCBPROC_GETADDR] = { |
930 | .p_proc = RPCBPROC_GETADDR, | 924 | .p_proc = RPCBPROC_GETADDR, |
931 | .p_encode = (kxdreproc_t)rpcb_enc_getaddr, | 925 | .p_encode = (kxdreproc_t)rpcb_enc_getaddr, |
932 | .p_decode = (kxdrproc_t)rpcb_dec_getaddr, | 926 | .p_decode = (kxdrdproc_t)rpcb_dec_getaddr, |
933 | .p_arglen = RPCB_getaddrargs_sz, | 927 | .p_arglen = RPCB_getaddrargs_sz, |
934 | .p_replen = RPCB_getaddrres_sz, | 928 | .p_replen = RPCB_getaddrres_sz, |
935 | .p_statidx = RPCBPROC_GETADDR, | 929 | .p_statidx = RPCBPROC_GETADDR, |