osdir.com
mailing list archive

Subject: [CVS] OpenSSL: OpenSSL_0_9_7-stable: openssl/crypto/aes/ aes_ctr.c - msg#00001

List: encryption.openssl.cvs

Mail Archive Navigation:
by Date: Prev Next Index by Thread: Prev Next Index
OpenSSL CVS Repository
http://cvs.openssl.org/
____________________________________________________________________________

Server: cvs.openssl.org Name: Richard Levitte
Root: /e/openssl/cvs Email: levitte@xxxxxxxxxxx
Module: openssl Date: 03-Jul-2003 08:41:33
Branch: OpenSSL_0_9_7-stable Handle: 2003070307413300

Modified files: (Branch: OpenSSL_0_9_7-stable)
openssl/crypto/aes aes_ctr.c

Log:
Change AES-CTR to increment the IV by 1 instead of 2^64.

Summary:
Revision Changes Path
1.1.2.6 +43 -7 openssl/crypto/aes/aes_ctr.c
____________________________________________________________________________

patch -p0 <<'@@ .'
Index: openssl/crypto/aes/aes_ctr.c
============================================================================
$ cvs diff -u -r1.1.2.5 -r1.1.2.6 aes_ctr.c
--- openssl/crypto/aes/aes_ctr.c 13 Nov 2002 14:01:19 -0000 1.1.2.5
+++ openssl/crypto/aes/aes_ctr.c 3 Jul 2003 06:41:33 -0000 1.1.2.6
@@ -62,19 +62,49 @@
/* NOTE: CTR mode is big-endian. The rest of the AES code
* is endian-neutral. */

-/* increment counter (128-bit int) by 2^64 */
+/* increment counter (128-bit int) by 1 */
static void AES_ctr128_inc(unsigned char *counter) {
unsigned long c;

- /* Grab 3rd dword of counter and increment */
+ /* Grab bottom dword of counter and increment */
#ifdef L_ENDIAN
- c = GETU32(counter + 8);
+ c = GETU32(counter + 0);
+ c++;
+ PUTU32(counter + 0, c);
+#else
+ c = GETU32(counter + 12);
+ c++;
+ PUTU32(counter + 12, c);
+#endif
+
+ /* if no overflow, we're done */
+ if (c)
+ return;
+
+ /* Grab 1st dword of counter and increment */
+#ifdef L_ENDIAN
+ c = GETU32(counter + 4);
+ c++;
+ PUTU32(counter + 4, c);
+#else
+ c = GETU32(counter + 8);
+ c++;
+ PUTU32(counter + 8, c);
+#endif
+
+ /* if no overflow, we're done */
+ if (c)
+ return;
+
+ /* Grab 2nd dword of counter and increment */
+#ifdef L_ENDIAN
+ c = GETU32(counter + 8);
c++;
- PUTU32(counter + 8, c);
+ PUTU32(counter + 8, c);
#else
- c = GETU32(counter + 4);
+ c = GETU32(counter + 4);
c++;
- PUTU32(counter + 4, c);
+ PUTU32(counter + 4, c);
#endif

/* if no overflow, we're done */
@@ -100,10 +130,16 @@
* encrypted counter is kept in ecount_buf. Both *num and
* ecount_buf must be initialised with zeros before the first
* call to AES_ctr128_encrypt().
+ *
+ * This algorithm assumes that the counter is in the x lower bits
+ * of the IV (ivec), and that the application has full control over
+ * overflow and the rest of the IV. This implementation takes NO
+ * responsability for checking that the counter doesn't overflow
+ * into the rest of the IV when incremented.
*/
void AES_ctr128_encrypt(const unsigned char *in, unsigned char *out,
const unsigned long length, const AES_KEY *key,
- unsigned char counter[AES_BLOCK_SIZE],
+ unsigned char ivec[AES_BLOCK_SIZE],
unsigned char ecount_buf[AES_BLOCK_SIZE],
unsigned int *num) {

@@ .
______________________________________________________________________
OpenSSL Project http://www.openssl.org
CVS Repository Commit List openssl-cvs@xxxxxxxxxxx
Automated List Manager majordomo@xxxxxxxxxxx



Find Programming Jobs at git.net
(osdir sister site)

Thread at a glance:

Previous Message by Date:

[CVS] OpenSSL: openssl/crypto/aes/ aes_ctr.c

OpenSSL CVS Repository http://cvs.openssl.org/ ____________________________________________________________________________ Server: cvs.openssl.org Name: Richard Levitte Root: /e/openssl/cvs Email: levitte@xxxxxxxxxxx Module: openssl Date: 03-Jul-2003 08:41:31 Branch: HEAD Handle: 2003070307413000 Modified files: openssl/crypto/aes aes_ctr.c Log: Change AES-CTR to increment the IV by 1 instead of 2^64. Summary: Revision Changes Path 1.6 +43 -7 openssl/crypto/aes/aes_ctr.c ____________________________________________________________________________ patch -p0 <<'@@ .' Index: openssl/crypto/aes/aes_ctr.c ============================================================================ $ cvs diff -u -r1.5 -r1.6 aes_ctr.c --- openssl/crypto/aes/aes_ctr.c 13 Nov 2002 14:01:34 -0000 1.5 +++ openssl/crypto/aes/aes_ctr.c 3 Jul 2003 06:41:30 -0000 1.6 @@ -62,19 +62,49 @@ /* NOTE: CTR mode is big-endian. The rest of the AES code * is endian-neutral. */ -/* increment counter (128-bit int) by 2^64 */ +/* increment counter (128-bit int) by 1 */ static void AES_ctr128_inc(unsigned char *counter) { unsigned long c; - /* Grab 3rd dword of counter and increment */ + /* Grab bottom dword of counter and increment */ #ifdef L_ENDIAN - c = GETU32(counter + 8); + c = GETU32(counter + 0); + c++; + PUTU32(counter + 0, c); +#else + c = GETU32(counter + 12); + c++; + PUTU32(counter + 12, c); +#endif + + /* if no overflow, we're done */ + if (c) + return; + + /* Grab 1st dword of counter and increment */ +#ifdef L_ENDIAN + c = GETU32(counter + 4); + c++; + PUTU32(counter + 4, c); +#else + c = GETU32(counter + 8); + c++; + PUTU32(counter + 8, c); +#endif + + /* if no overflow, we're done */ + if (c) + return; + + /* Grab 2nd dword of counter and increment */ +#ifdef L_ENDIAN + c = GETU32(counter + 8); c++; - PUTU32(counter + 8, c); + PUTU32(counter + 8, c); #else - c = GETU32(counter + 4); + c = GETU32(counter + 4); c++; - PUTU32(counter + 4, c); + PUTU32(counter + 4, c); #endif /* if no overflow, we're done */ @@ -100,10 +130,16 @@ * encrypted counter is kept in ecount_buf. Both *num and * ecount_buf must be initialised with zeros before the first * call to AES_ctr128_encrypt(). + * + * This algorithm assumes that the counter is in the x lower bits + * of the IV (ivec), and that the application has full control over + * overflow and the rest of the IV. This implementation takes NO + * responsability for checking that the counter doesn't overflow + * into the rest of the IV when incremented. */ void AES_ctr128_encrypt(const unsigned char *in, unsigned char *out, const unsigned long length, const AES_KEY *key, - unsigned char counter[AES_BLOCK_SIZE], + unsigned char ivec[AES_BLOCK_SIZE], unsigned char ecount_buf[AES_BLOCK_SIZE], unsigned int *num) { @@ . ______________________________________________________________________ OpenSSL Project http://www.openssl.org CVS Repository Commit List openssl-cvs@xxxxxxxxxxx Automated List Manager majordomo@xxxxxxxxxxx

Next Message by Date:

[CVS] OpenSSL: openssl/crypto/aes/ aes.h

OpenSSL CVS Repository http://cvs.openssl.org/ ____________________________________________________________________________ Server: cvs.openssl.org Name: Richard Levitte Root: /e/openssl/cvs Email: levitte@xxxxxxxxxxx Module: openssl Date: 03-Jul-2003 08:42:43 Branch: HEAD Handle: 2003070307424300 Modified files: openssl/crypto/aes aes.h Log: The 'counter' is really the IV. Summary: Revision Changes Path 1.6 +1 -1 openssl/crypto/aes/aes.h ____________________________________________________________________________ patch -p0 <<'@@ .' Index: openssl/crypto/aes/aes.h ============================================================================ $ cvs diff -u -r1.5 -r1.6 aes.h --- openssl/crypto/aes/aes.h 20 Mar 2003 23:15:51 -0000 1.5 +++ openssl/crypto/aes/aes.h 3 Jul 2003 06:42:43 -0000 1.6 @@ -102,7 +102,7 @@ unsigned char *ivec, int *num); void AES_ctr128_encrypt(const unsigned char *in, unsigned char *out, const unsigned long length, const AES_KEY *key, - unsigned char counter[AES_BLOCK_SIZE], + unsigned char ivec[AES_BLOCK_SIZE], unsigned char ecount_buf[AES_BLOCK_SIZE], unsigned int *num); @@ . ______________________________________________________________________ OpenSSL Project http://www.openssl.org CVS Repository Commit List openssl-cvs@xxxxxxxxxxx Automated List Manager majordomo@xxxxxxxxxxx

Previous Message by Thread:

[CVS] OpenSSL: openssl/crypto/aes/ aes_ctr.c

OpenSSL CVS Repository http://cvs.openssl.org/ ____________________________________________________________________________ Server: cvs.openssl.org Name: Richard Levitte Root: /e/openssl/cvs Email: levitte@xxxxxxxxxxx Module: openssl Date: 03-Jul-2003 08:41:31 Branch: HEAD Handle: 2003070307413000 Modified files: openssl/crypto/aes aes_ctr.c Log: Change AES-CTR to increment the IV by 1 instead of 2^64. Summary: Revision Changes Path 1.6 +43 -7 openssl/crypto/aes/aes_ctr.c ____________________________________________________________________________ patch -p0 <<'@@ .' Index: openssl/crypto/aes/aes_ctr.c ============================================================================ $ cvs diff -u -r1.5 -r1.6 aes_ctr.c --- openssl/crypto/aes/aes_ctr.c 13 Nov 2002 14:01:34 -0000 1.5 +++ openssl/crypto/aes/aes_ctr.c 3 Jul 2003 06:41:30 -0000 1.6 @@ -62,19 +62,49 @@ /* NOTE: CTR mode is big-endian. The rest of the AES code * is endian-neutral. */ -/* increment counter (128-bit int) by 2^64 */ +/* increment counter (128-bit int) by 1 */ static void AES_ctr128_inc(unsigned char *counter) { unsigned long c; - /* Grab 3rd dword of counter and increment */ + /* Grab bottom dword of counter and increment */ #ifdef L_ENDIAN - c = GETU32(counter + 8); + c = GETU32(counter + 0); + c++; + PUTU32(counter + 0, c); +#else + c = GETU32(counter + 12); + c++; + PUTU32(counter + 12, c); +#endif + + /* if no overflow, we're done */ + if (c) + return; + + /* Grab 1st dword of counter and increment */ +#ifdef L_ENDIAN + c = GETU32(counter + 4); + c++; + PUTU32(counter + 4, c); +#else + c = GETU32(counter + 8); + c++; + PUTU32(counter + 8, c); +#endif + + /* if no overflow, we're done */ + if (c) + return; + + /* Grab 2nd dword of counter and increment */ +#ifdef L_ENDIAN + c = GETU32(counter + 8); c++; - PUTU32(counter + 8, c); + PUTU32(counter + 8, c); #else - c = GETU32(counter + 4); + c = GETU32(counter + 4); c++; - PUTU32(counter + 4, c); + PUTU32(counter + 4, c); #endif /* if no overflow, we're done */ @@ -100,10 +130,16 @@ * encrypted counter is kept in ecount_buf. Both *num and * ecount_buf must be initialised with zeros before the first * call to AES_ctr128_encrypt(). + * + * This algorithm assumes that the counter is in the x lower bits + * of the IV (ivec), and that the application has full control over + * overflow and the rest of the IV. This implementation takes NO + * responsability for checking that the counter doesn't overflow + * into the rest of the IV when incremented. */ void AES_ctr128_encrypt(const unsigned char *in, unsigned char *out, const unsigned long length, const AES_KEY *key, - unsigned char counter[AES_BLOCK_SIZE], + unsigned char ivec[AES_BLOCK_SIZE], unsigned char ecount_buf[AES_BLOCK_SIZE], unsigned int *num) { @@ . ______________________________________________________________________ OpenSSL Project http://www.openssl.org CVS Repository Commit List openssl-cvs@xxxxxxxxxxx Automated List Manager majordomo@xxxxxxxxxxx

Next Message by Thread:

[CVS] OpenSSL: OpenSSL_0_9_7-stable: openssl/crypto/aes/ aes_ctr.c

OpenSSL CVS Repository http://cvs.openssl.org/ ____________________________________________________________________________ Server: cvs.openssl.org Name: Richard Levitte Root: /e/openssl/cvs Email: levitte@xxxxxxxxxxx Module: openssl Date: 03-Jul-2003 22:50:46 Branch: OpenSSL_0_9_7-stable Handle: 2003070321504600 Modified files: (Branch: OpenSSL_0_9_7-stable) openssl/crypto/aes aes_ctr.c Log: Oops, I forgot to replace 'counter' with 'ivec' when used... Summary: Revision Changes Path 1.1.2.7 +2 -2 openssl/crypto/aes/aes_ctr.c ____________________________________________________________________________ patch -p0 <<'@@ .' Index: openssl/crypto/aes/aes_ctr.c ============================================================================ $ cvs diff -u -r1.1.2.6 -r1.1.2.7 aes_ctr.c --- openssl/crypto/aes/aes_ctr.c 3 Jul 2003 06:41:33 -0000 1.1.2.6 +++ openssl/crypto/aes/aes_ctr.c 3 Jul 2003 20:50:46 -0000 1.1.2.7 @@ -153,8 +153,8 @@ while (l--) { if (n == 0) { - AES_encrypt(counter, ecount_buf, key); - AES_ctr128_inc(counter); + AES_encrypt(ivec, ecount_buf, key); + AES_ctr128_inc(ivec); } *(out++) = *(in++) ^ ecount_buf[n]; n = (n+1) % AES_BLOCK_SIZE; @@ . ______________________________________________________________________ OpenSSL Project http://www.openssl.org CVS Repository Commit List openssl-cvs@xxxxxxxxxxx Automated List Manager majordomo@xxxxxxxxxxx

Web Hosting Reviews from OSDir.com Sister Site iBizWebHosting.com

Home | News | Patents | Sitemap | FAQ | advertise | OSDir is an Inevitable website. GBiz & git.net are too!

Advertising by