int             ret;
        struct sunrpc_net *sn = net_generic(SVC_NET(rqstp), sunrpc_net_id);
 
-       svcxdr_init_decode(rqstp);
-
        rqstp->rq_auth_stat = rpc_autherr_badcred;
        if (!svcdata)
                svcdata = kmalloc(sizeof(*svcdata), GFP_KERNEL);
 
         * We do this before anything else in order to get a decent
         * auth verifier.
         */
+       svcxdr_init_decode(rqstp);
        auth_res = svc_authenticate(rqstp);
        /* Also give the program a chance to reject this call: */
        if (auth_res == SVC_OK && progp)
 
 int
 svc_authenticate(struct svc_rqst *rqstp)
 {
-       rpc_authflavor_t        flavor;
-       struct auth_ops         *aops;
+       struct auth_ops *aops;
+       u32 flavor;
 
        rqstp->rq_auth_stat = rpc_auth_ok;
 
-       flavor = svc_getnl(&rqstp->rq_arg.head[0]);
-
-       dprintk("svc: svc_authenticate (%d)\n", flavor);
+       /*
+        * Decode the Call credential's flavor field. The credential's
+        * body field is decoded in the chosen ->accept method below.
+        */
+       if (xdr_stream_decode_u32(&rqstp->rq_arg_stream, &flavor) < 0)
+               return SVC_GARBAGE;
 
        aops = svc_get_auth_ops(flavor);
        if (aops == NULL) {
 
        u32 flavor, len;
        void *body;
 
-       svcxdr_init_decode(rqstp);
-
        /* Length of Call's credential body field: */
        if (xdr_stream_decode_u32(xdr, &len) < 0)
                return SVC_GARBAGE;
        u32 flavor, len;
        void *body;
 
-       svcxdr_init_decode(rqstp);
-
        /* Length of Call's credential body field: */
        if (xdr_stream_decode_u32(xdr, &len) < 0)
                return SVC_GARBAGE;
        void *body;
        __be32 *p;
 
-       svcxdr_init_decode(rqstp);
-
        /*
         * This implementation ignores the length of the Call's
         * credential body field and the timestamp and machinename