struct aead_instance *inst;
        int err;
 
-       inst = aead_geniv_alloc(tmpl, tb, 0, 0);
+       inst = aead_geniv_alloc(tmpl, tb);
 
        if (IS_ERR(inst))
                return PTR_ERR(inst);
 
 }
 
 struct aead_instance *aead_geniv_alloc(struct crypto_template *tmpl,
-                                      struct rtattr **tb, u32 type, u32 mask)
+                                      struct rtattr **tb)
 {
        struct crypto_aead_spawn *spawn;
        struct crypto_attr_type *algt;
        struct aead_alg *alg;
        unsigned int ivsize;
        unsigned int maxauthsize;
+       u32 mask;
        int err;
 
        algt = crypto_get_attr_type(tb);
        spawn = aead_instance_ctx(inst);
 
        /* Ignore async algorithms if necessary. */
-       mask |= crypto_requires_sync(algt->type, algt->mask);
+       mask = crypto_requires_sync(algt->type, algt->mask);
 
        err = crypto_grab_aead(spawn, aead_crypto_instance(inst),
-                              crypto_attr_alg_name(tb[1]), type, mask);
+                              crypto_attr_alg_name(tb[1]), 0, mask);
        if (err)
                goto err_free_inst;
 
 
        struct aead_instance *inst;
        int err;
 
-       inst = aead_geniv_alloc(tmpl, tb, 0, 0);
+       inst = aead_geniv_alloc(tmpl, tb);
 
        if (IS_ERR(inst))
                return PTR_ERR(inst);
 
 };
 
 struct aead_instance *aead_geniv_alloc(struct crypto_template *tmpl,
-                                      struct rtattr **tb, u32 type, u32 mask);
+                                      struct rtattr **tb);
 int aead_init_geniv(struct crypto_aead *tfm);
 void aead_exit_geniv(struct crypto_aead *tfm);