On Sun, Aug 7, 2011 at 2:29 PM, Joe Perches <joe@xxxxxxxxxxx> wrote: > While not connected to ARM's implementation of sha_transform, > maybe this might make code a bit clearer. > > Remove need to know the size and type of SHA_WORKSPACE_WORDS. > Introduce and use opaque struct sha_workspace instead. The thing is, that workspace thing is likely just broken, and should be removed. On machines with sufficient registers, we can keep the workspace in the register set, and setting it up on stack and passing it in as a buffer is just bad. On x86 and arm it doesn't matter, but on ppc it likely pessimizes the code by resulting in pointless writebacks to that stack buffer. So the right thing to do is probably to just remove it entirely, and just make the sha_transform() thing allocate it on the stack as needed. The only issue then is whether you really want the stackspace cleared afterwards. My personal guess is that it really doesn't matter: if you leak stack space anywhere, you are seriously screwed from a security standpoint anyway, so.. But in the meantime, I don't want to add this kind of abstraction for something that I suspect is just fundamentally broken. Linus -- To unsubscribe from this list: send the line "unsubscribe linux-crypto" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html