* Herbert Xu | 2007-08-02 10:30:06 [+0800]: >> I noticed this, after my code did not work properly. The reason was, >> that my private ctx was not retrieved with >> crypto_ablkcipher_ctx_aligned() (attached) but with >> crypto_ablkcipher_ctx() (and it was not properly aligned anymore). >> My fault right? > >Yeah if your ctx needs to be aligned you need to use >crypto_tfm_ctx_aligned.
Okey this makes sense. What about crypto_ctxsize()? Isn't a bug there? I can't specify an alignmask of 16 (what I assumed yesterday after a part of brain switched to sleep()) because this brakes the ALIGN() macro. Isn't something like --- a/crypto/api.c +++ b/crypto/api.c @@ -273,7 +273,7 @@ static unsigned int crypto_ctxsize(struc const struct crypto_type *type_obj = alg->cra_type; unsigned int len; - len = alg->cra_alignmask & ~(crypto_tfm_ctx_alignment() - 1); + len = alg->cra_alignmask | (crypto_tfm_ctx_alignment() -1) if (type_obj) return len + type_obj->ctxsize(alg, type, mask); ---- required? VIA's PadLock driver uses manully ALIGN() instead of crypto_.*_ctx_aligned() to do this. Therefore it will overwrite memory or am I overlooking something? >> --- a/include/crypto/algapi.h >> +++ b/include/crypto/algapi.h >> @@ -160,6 +160,11 @@ static inline void *crypto_ablkcipher_ct >> return crypto_tfm_ctx(&tfm->base); >> } >> >> +static inline void *crypto_ablkcipher_ctx_aligned(struct crypto_ablkcipher >> *tfm) >> +{ >> + return crypto_tfm_ctx_aligned(&tfm->base); >> +} >> + >> static inline struct crypto_blkcipher *crypto_spawn_blkcipher( >> struct crypto_spawn *spawn) > >Looks good. Could you add a description and sign-off? Yes, no problem. Sebastian - To unsubscribe from this list: send the line "unsubscribe linux-crypto" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html