* 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