Sponsored by: The FreeBSD Foundation
Details
Diff Detail
- Repository
- rS FreeBSD src repository - subversion
- Lint
No Lint Coverage - Unit
No Test Coverage - Build Status
Buildable 43725 Build 40613: arc lint + arc unit
Event Timeline
sys/opencrypto/cryptosoft.c | ||
---|---|---|
442 | ||
458 | ||
486 | Couldn't this be a for-loop as well? for (resid = crp->crp_payload_length; resid >= blksz; resid -= todo) | |
521 | Suppose todo == inlen, so the current input segment is a multiple of the block size. Then, on the next iteration we'll bounce the first block of the next segment through blk, even though that's not necessarily required. I don't think there's a correctness problem there, just seems suboptimal. | |
565 | Again, seems like this should be a for-loop. | |
596 | Same comment about not reloading the segment if outlen == 0 after subtracting todo. |
sys/opencrypto/cryptosoft.c | ||
---|---|---|
486 | I did this more to match swcr_encdec(), but I could make it a for loop. I think I want all of them to be the same though, so I might go back and adjust swcr_encdec() then. | |
521 | I think in the chacha20_poly1305 case I noticed this and fixed it. Part of the problem is that the GCM update routine wants blocks except for the last update. I think though I could handle this case by just checking for 'inlen == todo' here. |
sys/opencrypto/cryptosoft.c | ||
---|---|---|
521 | Actually, this suboptimal behavior is present even in swcr_encdec(), so I will have to go back and fix them all. |
- Use for loop instead of while.
- Handle boundary conditions when segment ends on a block boundary.