On Fri, Mar 07, 2014 at 06:15:43PM -0800, Behan Webster wrote:True, possibly a few more bytes. Nothing significant. However, I will fix this too.
On 03/07/14 17:56, Joe Perches wrote:Could you explain that? It looks like aead_req_data can be bigger than
On Fri, 2014-03-07 at 17:26 -0800, behanw@xxxxxxxxxxxxxxxxxx wrote:No more stack being used than with the the original code. The stack
From: Jan-Simon Möller <dl9pf@xxxxxx>[]
Replaced the use of a Variable Length Array In Struct (VLAIS) with a C99
compliant equivalent. This is the original VLAIS struct.
diff --git a/net/mac80211/aes_ccm.c b/net/mac80211/aes_ccm.c[]
@@ -23,12 +23,14 @@ void ieee80211_aes_ccm_encrypt(struct crypto_aead *tfm, u8 *b_0, u8 *aad,Can this be a too large amount of stack?
u8 *data, size_t data_len, u8 *mic)
{
struct scatterlist assoc, pt, ct[2];
- struct {
- struct aead_request req;
- u8 priv[crypto_aead_reqsize(tfm)];
- } aead_req;
- memset(&aead_req, 0, sizeof(aead_req));
+ char aead_req_data[sizeof(struct aead_request) +
+ crypto_aead_reqsize(tfm) +
+ CRYPTO_MINALIGN] CRYPTO_MINALIGN_ATTR;
Is crypto_aead_reqsize() limited to < ~1k?
Perhaps it'd be better to use kzalloc for this
or another reserved pool
memory use is identical.
original struct aead_req up to CRYPTO_MINALIGN bytes. IOW adding
CRYPTO_MINALIGN to size seems unneeded as aead_request->__ctx alignment
requirement should by assured by proper sizeof(struct aead_request).
Besides, why not add VLAIS feature to llvm instead of fixing allYou aren't the first to ask this (I certainly get asked this regularly). :)
programs that use it?