diff mbox

[v1,2/7] AES for PPC/SPE - aes tables

Message ID cfb098e9-69ae-47ff-afa7-08c922accd31@EXCHANGE.collogia.de (mailing list archive)
State Not Applicable
Delegated to: Michael Ellerman
Headers show

Commit Message

Markus Stockhausen Feb. 16, 2015, 12:45 p.m. UTC
[PATCH v1 2/7] AES for PPC/SPE - aes tables

4K AES tables for big endian

Signed-off-by: Markus Stockhausen <stockhausen@collogia.de>
****************************************************************************
Diese E-Mail enthält vertrauliche und/oder rechtlich geschützte
Informationen. Wenn Sie nicht der richtige Adressat sind oder diese E-Mail
irrtümlich erhalten haben, informieren Sie bitte sofort den Absender und
vernichten Sie diese Mail. Das unerlaubte Kopieren sowie die unbefugte
Weitergabe dieser Mail ist nicht gestattet.

Über das Internet versandte E-Mails können unter fremden Namen erstellt oder
manipuliert werden. Deshalb ist diese als E-Mail verschickte Nachricht keine
rechtsverbindliche Willenserklärung.

Collogia
Unternehmensberatung AG
Ubierring 11
D-50678 Köln

Vorstand:
Kadir Akin
Dr. Michael Höhnerbach

Vorsitzender des Aufsichtsrates:
Hans Kristian Langva

Registergericht: Amtsgericht Köln
Registernummer: HRB 52 497

This e-mail may contain confidential and/or privileged information. If you
are not the intended recipient (or have received this e-mail in error)
please notify the sender immediately and destroy this e-mail. Any
unauthorized copying, disclosure or distribution of the material in this
e-mail is strictly forbidden.

e-mails sent over the internet may have been written under a wrong name or
been manipulated. That is why this message sent as an e-mail is not a
legally binding declaration of intention.

Collogia
Unternehmensberatung AG
Ubierring 11
D-50678 Köln

executive board:
Kadir Akin
Dr. Michael Höhnerbach

President of the supervisory board:
Hans Kristian Langva

Registry office: district court Cologne
Register number: HRB 52 497

****************************************************************************

Comments

David Laight Feb. 16, 2015, 2:19 p.m. UTC | #1
From:  Markus Stockhausen
> 4K AES tables for big endian

I can't help feeling that you could give more information about how the
values are generated.

...
> + * These big endian AES encryption/decryption tables are designed to be simply
> + * accessed by a combination of rlwimi/lwz instructions with a minimum
> + * of table registers (usually only one required). Thus they are aligned to
> + * 4K. The locality of rotated values is derived from the reduced offsets that
> + * are available in the SPE load instructions. E.g. evldw, evlwwsplat, ...
> + *
> + */
> +.data
> +.align 12
> +.globl PPC_AES_4K_ENCTAB
> +PPC_AES_4K_ENCTAB:
> +	.long 0xc66363a5,0xa5c66363,0x63a5c663,0x6363a5c6

These seem to be byte rotates (all down the table).
If so then use a CPP define to generate the rotated values.

I'd like to see a reference to where the values themselves come from.

> +	.long 0xf87c7c84,0x84f87c7c,0x7c84f87c,0x7c7c84f8
...
> +	.long 0x6dbbbbd6,0xd66dbbbb,0xbbd66dbb,0xbbbbd66d
> +	.long 0x2c16163a,0x3a2c1616,0x163a2c16,0x16163a2c
> +.globl PPC_AES_4K_DECTAB
> +PPC_AES_4K_DECTAB:
> +	.long 0x51f4a750,0x5051f4a7,0xa75051f4,0xf4a75051
...
> +	.long 0xd0b85742,0x42d0b857,0x5742d0b8,0xb85742d0

Some explanation of this third dataset is also needed.

> +	.byte 0x52, 0x09, 0x6a, 0xd5, 0x30, 0x36, 0xa5, 0x38
...
> +	.byte 0xe1, 0x69, 0x14, 0x63, 0x55, 0x21, 0x0c, 0x7d

	David
Segher Boessenkool Feb. 16, 2015, 2:37 p.m. UTC | #2
On Mon, Feb 16, 2015 at 02:19:50PM +0000, David Laight wrote:
> From:  Markus Stockhausen
> > 4K AES tables for big endian
> 
> I can't help feeling that you could give more information about how the
> values are generated.

... and an explanation of why this does not open you up to a timing attack?


Segher
Markus Stockhausen Feb. 16, 2015, 5:18 p.m. UTC | #3
> Von: linux-crypto-owner@vger.kernel.org [linux-crypto-owner@vger.kernel.org]&quot; im Auftrag von &quot;Segher Boessenkool [segher@kernel.crashing.org]
> Gesendet: Montag, 16. Februar 2015 15:37
> An: David Laight
> Cc: Markus Stockhausen; linux-crypto@vger.kernel.org; linuxppc-dev@lists.ozlabs.org
> Betreff: Re: [PATCH v1 2/7] AES for PPC/SPE - aes tables
> 
> On Mon, Feb 16, 2015 at 02:19:50PM +0000, David Laight wrote:
> > From:  Markus Stockhausen
> > > 4K AES tables for big endian
> >
> > I can't help feeling that you could give more information about how the
> > values are generated.
> 
> ... and an explanation of why this does not open you up to a timing attack?

Good points,

the tables are only big endian reversed ones of those found in crypto/aes_generic.c.

Regarding timing attacks: I understand, that reducing AES table sizes for a constant 
AES processing time is important to avoid cache timing attacks. Hopefully the 
following points will mitigate the concern.

Target architecture are low performance e500 cores without available caam 
features. These can currently use only aes-generic module. That one depends 
on 16K T-tables. 2*4K for encryption and 2*4K for decryption. The new module
reduces the T-table sizes to 8K+256 bytes. Far away from a minimal 256 byte
S-BOX but at least an improvement.

To narrow it down further. Intended use is for cheap routers. So no multiuser 
environments where a malicous process could drive complex flush+reload 
attacks. In case someone gains unallowed access there will be a lot of other 
and simpler ways to compromise the system.

In case that is sufficient for you I will add respective notes into a patch v2.

Markus
****************************************************************************
Diese E-Mail enthält vertrauliche und/oder rechtlich geschützte
Informationen. Wenn Sie nicht der richtige Adressat sind oder diese E-Mail
irrtümlich erhalten haben, informieren Sie bitte sofort den Absender und
vernichten Sie diese Mail. Das unerlaubte Kopieren sowie die unbefugte
Weitergabe dieser Mail ist nicht gestattet.

Über das Internet versandte E-Mails können unter fremden Namen erstellt oder
manipuliert werden. Deshalb ist diese als E-Mail verschickte Nachricht keine
rechtsverbindliche Willenserklärung.

Collogia
Unternehmensberatung AG
Ubierring 11
D-50678 Köln

Vorstand:
Kadir Akin
Dr. Michael Höhnerbach

Vorsitzender des Aufsichtsrates:
Hans Kristian Langva

Registergericht: Amtsgericht Köln
Registernummer: HRB 52 497

This e-mail may contain confidential and/or privileged information. If you
are not the intended recipient (or have received this e-mail in error)
please notify the sender immediately and destroy this e-mail. Any
unauthorized copying, disclosure or distribution of the material in this
e-mail is strictly forbidden.

e-mails sent over the internet may have been written under a wrong name or
been manipulated. That is why this message sent as an e-mail is not a
legally binding declaration of intention.

Collogia
Unternehmensberatung AG
Ubierring 11
D-50678 Köln

executive board:
Kadir Akin
Dr. Michael Höhnerbach

President of the supervisory board:
Hans Kristian Langva

Registry office: district court Cologne
Register number: HRB 52 497

****************************************************************************
diff mbox

Patch

diff --git a/arch/powerpc/crypto/aes-tab-4k.S b/arch/powerpc/crypto/aes-tab-4k.S
new file mode 100644
index 0000000..6bc1755
--- /dev/null
+++ b/arch/powerpc/crypto/aes-tab-4k.S
@@ -0,0 +1,570 @@ 
+/*
+ * 4K AES tables for PPC AES implementation
+ *
+ * Copyright (c) 2015 Markus Stockhausen <stockhausen@collogia.de>
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License as published by the Free
+ * Software Foundation; either version 2 of the License, or (at your option)
+ * any later version.
+ *
+ */
+
+/*
+ * These big endian AES encryption/decryption tables are designed to be simply
+ * accessed by a combination of rlwimi/lwz instructions with a minimum
+ * of table registers (usually only one required). Thus they are aligned to
+ * 4K. The locality of rotated values is derived from the reduced offsets that
+ * are available in the SPE load instructions. E.g. evldw, evlwwsplat, ...
+ *
+ */
+.data
+.align 12
+.globl PPC_AES_4K_ENCTAB
+PPC_AES_4K_ENCTAB:
+	.long 0xc66363a5,0xa5c66363,0x63a5c663,0x6363a5c6
+	.long 0xf87c7c84,0x84f87c7c,0x7c84f87c,0x7c7c84f8
+	.long 0xee777799,0x99ee7777,0x7799ee77,0x777799ee
+	.long 0xf67b7b8d,0x8df67b7b,0x7b8df67b,0x7b7b8df6
+	.long 0xfff2f20d,0x0dfff2f2,0xf20dfff2,0xf2f20dff
+	.long 0xd66b6bbd,0xbdd66b6b,0x6bbdd66b,0x6b6bbdd6
+	.long 0xde6f6fb1,0xb1de6f6f,0x6fb1de6f,0x6f6fb1de
+	.long 0x91c5c554,0x5491c5c5,0xc55491c5,0xc5c55491
+	.long 0x60303050,0x50603030,0x30506030,0x30305060
+	.long 0x02010103,0x03020101,0x01030201,0x01010302
+	.long 0xce6767a9,0xa9ce6767,0x67a9ce67,0x6767a9ce
+	.long 0x562b2b7d,0x7d562b2b,0x2b7d562b,0x2b2b7d56
+	.long 0xe7fefe19,0x19e7fefe,0xfe19e7fe,0xfefe19e7
+	.long 0xb5d7d762,0x62b5d7d7,0xd762b5d7,0xd7d762b5
+	.long 0x4dababe6,0xe64dabab,0xabe64dab,0xababe64d
+	.long 0xec76769a,0x9aec7676,0x769aec76,0x76769aec
+	.long 0x8fcaca45,0x458fcaca,0xca458fca,0xcaca458f
+	.long 0x1f82829d,0x9d1f8282,0x829d1f82,0x82829d1f
+	.long 0x89c9c940,0x4089c9c9,0xc94089c9,0xc9c94089
+	.long 0xfa7d7d87,0x87fa7d7d,0x7d87fa7d,0x7d7d87fa
+	.long 0xeffafa15,0x15effafa,0xfa15effa,0xfafa15ef
+	.long 0xb25959eb,0xebb25959,0x59ebb259,0x5959ebb2
+	.long 0x8e4747c9,0xc98e4747,0x47c98e47,0x4747c98e
+	.long 0xfbf0f00b,0x0bfbf0f0,0xf00bfbf0,0xf0f00bfb
+	.long 0x41adadec,0xec41adad,0xadec41ad,0xadadec41
+	.long 0xb3d4d467,0x67b3d4d4,0xd467b3d4,0xd4d467b3
+	.long 0x5fa2a2fd,0xfd5fa2a2,0xa2fd5fa2,0xa2a2fd5f
+	.long 0x45afafea,0xea45afaf,0xafea45af,0xafafea45
+	.long 0x239c9cbf,0xbf239c9c,0x9cbf239c,0x9c9cbf23
+	.long 0x53a4a4f7,0xf753a4a4,0xa4f753a4,0xa4a4f753
+	.long 0xe4727296,0x96e47272,0x7296e472,0x727296e4
+	.long 0x9bc0c05b,0x5b9bc0c0,0xc05b9bc0,0xc0c05b9b
+	.long 0x75b7b7c2,0xc275b7b7,0xb7c275b7,0xb7b7c275
+	.long 0xe1fdfd1c,0x1ce1fdfd,0xfd1ce1fd,0xfdfd1ce1
+	.long 0x3d9393ae,0xae3d9393,0x93ae3d93,0x9393ae3d
+	.long 0x4c26266a,0x6a4c2626,0x266a4c26,0x26266a4c
+	.long 0x6c36365a,0x5a6c3636,0x365a6c36,0x36365a6c
+	.long 0x7e3f3f41,0x417e3f3f,0x3f417e3f,0x3f3f417e
+	.long 0xf5f7f702,0x02f5f7f7,0xf702f5f7,0xf7f702f5
+	.long 0x83cccc4f,0x4f83cccc,0xcc4f83cc,0xcccc4f83
+	.long 0x6834345c,0x5c683434,0x345c6834,0x34345c68
+	.long 0x51a5a5f4,0xf451a5a5,0xa5f451a5,0xa5a5f451
+	.long 0xd1e5e534,0x34d1e5e5,0xe534d1e5,0xe5e534d1
+	.long 0xf9f1f108,0x08f9f1f1,0xf108f9f1,0xf1f108f9
+	.long 0xe2717193,0x93e27171,0x7193e271,0x717193e2
+	.long 0xabd8d873,0x73abd8d8,0xd873abd8,0xd8d873ab
+	.long 0x62313153,0x53623131,0x31536231,0x31315362
+	.long 0x2a15153f,0x3f2a1515,0x153f2a15,0x15153f2a
+	.long 0x0804040c,0x0c080404,0x040c0804,0x04040c08
+	.long 0x95c7c752,0x5295c7c7,0xc75295c7,0xc7c75295
+	.long 0x46232365,0x65462323,0x23654623,0x23236546
+	.long 0x9dc3c35e,0x5e9dc3c3,0xc35e9dc3,0xc3c35e9d
+	.long 0x30181828,0x28301818,0x18283018,0x18182830
+	.long 0x379696a1,0xa1379696,0x96a13796,0x9696a137
+	.long 0x0a05050f,0x0f0a0505,0x050f0a05,0x05050f0a
+	.long 0x2f9a9ab5,0xb52f9a9a,0x9ab52f9a,0x9a9ab52f
+	.long 0x0e070709,0x090e0707,0x07090e07,0x0707090e
+	.long 0x24121236,0x36241212,0x12362412,0x12123624
+	.long 0x1b80809b,0x9b1b8080,0x809b1b80,0x80809b1b
+	.long 0xdfe2e23d,0x3ddfe2e2,0xe23ddfe2,0xe2e23ddf
+	.long 0xcdebeb26,0x26cdebeb,0xeb26cdeb,0xebeb26cd
+	.long 0x4e272769,0x694e2727,0x27694e27,0x2727694e
+	.long 0x7fb2b2cd,0xcd7fb2b2,0xb2cd7fb2,0xb2b2cd7f
+	.long 0xea75759f,0x9fea7575,0x759fea75,0x75759fea
+	.long 0x1209091b,0x1b120909,0x091b1209,0x09091b12
+	.long 0x1d83839e,0x9e1d8383,0x839e1d83,0x83839e1d
+	.long 0x582c2c74,0x74582c2c,0x2c74582c,0x2c2c7458
+	.long 0x341a1a2e,0x2e341a1a,0x1a2e341a,0x1a1a2e34
+	.long 0x361b1b2d,0x2d361b1b,0x1b2d361b,0x1b1b2d36
+	.long 0xdc6e6eb2,0xb2dc6e6e,0x6eb2dc6e,0x6e6eb2dc
+	.long 0xb45a5aee,0xeeb45a5a,0x5aeeb45a,0x5a5aeeb4
+	.long 0x5ba0a0fb,0xfb5ba0a0,0xa0fb5ba0,0xa0a0fb5b
+	.long 0xa45252f6,0xf6a45252,0x52f6a452,0x5252f6a4
+	.long 0x763b3b4d,0x4d763b3b,0x3b4d763b,0x3b3b4d76
+	.long 0xb7d6d661,0x61b7d6d6,0xd661b7d6,0xd6d661b7
+	.long 0x7db3b3ce,0xce7db3b3,0xb3ce7db3,0xb3b3ce7d
+	.long 0x5229297b,0x7b522929,0x297b5229,0x29297b52
+	.long 0xdde3e33e,0x3edde3e3,0xe33edde3,0xe3e33edd
+	.long 0x5e2f2f71,0x715e2f2f,0x2f715e2f,0x2f2f715e
+	.long 0x13848497,0x97138484,0x84971384,0x84849713
+	.long 0xa65353f5,0xf5a65353,0x53f5a653,0x5353f5a6
+	.long 0xb9d1d168,0x68b9d1d1,0xd168b9d1,0xd1d168b9
+	.long 0x00000000,0x00000000,0x00000000,0x00000000
+	.long 0xc1eded2c,0x2cc1eded,0xed2cc1ed,0xeded2cc1
+	.long 0x40202060,0x60402020,0x20604020,0x20206040
+	.long 0xe3fcfc1f,0x1fe3fcfc,0xfc1fe3fc,0xfcfc1fe3
+	.long 0x79b1b1c8,0xc879b1b1,0xb1c879b1,0xb1b1c879
+	.long 0xb65b5bed,0xedb65b5b,0x5bedb65b,0x5b5bedb6
+	.long 0xd46a6abe,0xbed46a6a,0x6abed46a,0x6a6abed4
+	.long 0x8dcbcb46,0x468dcbcb,0xcb468dcb,0xcbcb468d
+	.long 0x67bebed9,0xd967bebe,0xbed967be,0xbebed967
+	.long 0x7239394b,0x4b723939,0x394b7239,0x39394b72
+	.long 0x944a4ade,0xde944a4a,0x4ade944a,0x4a4ade94
+	.long 0x984c4cd4,0xd4984c4c,0x4cd4984c,0x4c4cd498
+	.long 0xb05858e8,0xe8b05858,0x58e8b058,0x5858e8b0
+	.long 0x85cfcf4a,0x4a85cfcf,0xcf4a85cf,0xcfcf4a85
+	.long 0xbbd0d06b,0x6bbbd0d0,0xd06bbbd0,0xd0d06bbb
+	.long 0xc5efef2a,0x2ac5efef,0xef2ac5ef,0xefef2ac5
+	.long 0x4faaaae5,0xe54faaaa,0xaae54faa,0xaaaae54f
+	.long 0xedfbfb16,0x16edfbfb,0xfb16edfb,0xfbfb16ed
+	.long 0x864343c5,0xc5864343,0x43c58643,0x4343c586
+	.long 0x9a4d4dd7,0xd79a4d4d,0x4dd79a4d,0x4d4dd79a
+	.long 0x66333355,0x55663333,0x33556633,0x33335566
+	.long 0x11858594,0x94118585,0x85941185,0x85859411
+	.long 0x8a4545cf,0xcf8a4545,0x45cf8a45,0x4545cf8a
+	.long 0xe9f9f910,0x10e9f9f9,0xf910e9f9,0xf9f910e9
+	.long 0x04020206,0x06040202,0x02060402,0x02020604
+	.long 0xfe7f7f81,0x81fe7f7f,0x7f81fe7f,0x7f7f81fe
+	.long 0xa05050f0,0xf0a05050,0x50f0a050,0x5050f0a0
+	.long 0x783c3c44,0x44783c3c,0x3c44783c,0x3c3c4478
+	.long 0x259f9fba,0xba259f9f,0x9fba259f,0x9f9fba25
+	.long 0x4ba8a8e3,0xe34ba8a8,0xa8e34ba8,0xa8a8e34b
+	.long 0xa25151f3,0xf3a25151,0x51f3a251,0x5151f3a2
+	.long 0x5da3a3fe,0xfe5da3a3,0xa3fe5da3,0xa3a3fe5d
+	.long 0x804040c0,0xc0804040,0x40c08040,0x4040c080
+	.long 0x058f8f8a,0x8a058f8f,0x8f8a058f,0x8f8f8a05
+	.long 0x3f9292ad,0xad3f9292,0x92ad3f92,0x9292ad3f
+	.long 0x219d9dbc,0xbc219d9d,0x9dbc219d,0x9d9dbc21
+	.long 0x70383848,0x48703838,0x38487038,0x38384870
+	.long 0xf1f5f504,0x04f1f5f5,0xf504f1f5,0xf5f504f1
+	.long 0x63bcbcdf,0xdf63bcbc,0xbcdf63bc,0xbcbcdf63
+	.long 0x77b6b6c1,0xc177b6b6,0xb6c177b6,0xb6b6c177
+	.long 0xafdada75,0x75afdada,0xda75afda,0xdada75af
+	.long 0x42212163,0x63422121,0x21634221,0x21216342
+	.long 0x20101030,0x30201010,0x10302010,0x10103020
+	.long 0xe5ffff1a,0x1ae5ffff,0xff1ae5ff,0xffff1ae5
+	.long 0xfdf3f30e,0x0efdf3f3,0xf30efdf3,0xf3f30efd
+	.long 0xbfd2d26d,0x6dbfd2d2,0xd26dbfd2,0xd2d26dbf
+	.long 0x81cdcd4c,0x4c81cdcd,0xcd4c81cd,0xcdcd4c81
+	.long 0x180c0c14,0x14180c0c,0x0c14180c,0x0c0c1418
+	.long 0x26131335,0x35261313,0x13352613,0x13133526
+	.long 0xc3ecec2f,0x2fc3ecec,0xec2fc3ec,0xecec2fc3
+	.long 0xbe5f5fe1,0xe1be5f5f,0x5fe1be5f,0x5f5fe1be
+	.long 0x359797a2,0xa2359797,0x97a23597,0x9797a235
+	.long 0x884444cc,0xcc884444,0x44cc8844,0x4444cc88
+	.long 0x2e171739,0x392e1717,0x17392e17,0x1717392e
+	.long 0x93c4c457,0x5793c4c4,0xc45793c4,0xc4c45793
+	.long 0x55a7a7f2,0xf255a7a7,0xa7f255a7,0xa7a7f255
+	.long 0xfc7e7e82,0x82fc7e7e,0x7e82fc7e,0x7e7e82fc
+	.long 0x7a3d3d47,0x477a3d3d,0x3d477a3d,0x3d3d477a
+	.long 0xc86464ac,0xacc86464,0x64acc864,0x6464acc8
+	.long 0xba5d5de7,0xe7ba5d5d,0x5de7ba5d,0x5d5de7ba
+	.long 0x3219192b,0x2b321919,0x192b3219,0x19192b32
+	.long 0xe6737395,0x95e67373,0x7395e673,0x737395e6
+	.long 0xc06060a0,0xa0c06060,0x60a0c060,0x6060a0c0
+	.long 0x19818198,0x98198181,0x81981981,0x81819819
+	.long 0x9e4f4fd1,0xd19e4f4f,0x4fd19e4f,0x4f4fd19e
+	.long 0xa3dcdc7f,0x7fa3dcdc,0xdc7fa3dc,0xdcdc7fa3
+	.long 0x44222266,0x66442222,0x22664422,0x22226644
+	.long 0x542a2a7e,0x7e542a2a,0x2a7e542a,0x2a2a7e54
+	.long 0x3b9090ab,0xab3b9090,0x90ab3b90,0x9090ab3b
+	.long 0x0b888883,0x830b8888,0x88830b88,0x8888830b
+	.long 0x8c4646ca,0xca8c4646,0x46ca8c46,0x4646ca8c
+	.long 0xc7eeee29,0x29c7eeee,0xee29c7ee,0xeeee29c7
+	.long 0x6bb8b8d3,0xd36bb8b8,0xb8d36bb8,0xb8b8d36b
+	.long 0x2814143c,0x3c281414,0x143c2814,0x14143c28
+	.long 0xa7dede79,0x79a7dede,0xde79a7de,0xdede79a7
+	.long 0xbc5e5ee2,0xe2bc5e5e,0x5ee2bc5e,0x5e5ee2bc
+	.long 0x160b0b1d,0x1d160b0b,0x0b1d160b,0x0b0b1d16
+	.long 0xaddbdb76,0x76addbdb,0xdb76addb,0xdbdb76ad
+	.long 0xdbe0e03b,0x3bdbe0e0,0xe03bdbe0,0xe0e03bdb
+	.long 0x64323256,0x56643232,0x32566432,0x32325664
+	.long 0x743a3a4e,0x4e743a3a,0x3a4e743a,0x3a3a4e74
+	.long 0x140a0a1e,0x1e140a0a,0x0a1e140a,0x0a0a1e14
+	.long 0x924949db,0xdb924949,0x49db9249,0x4949db92
+	.long 0x0c06060a,0x0a0c0606,0x060a0c06,0x06060a0c
+	.long 0x4824246c,0x6c482424,0x246c4824,0x24246c48
+	.long 0xb85c5ce4,0xe4b85c5c,0x5ce4b85c,0x5c5ce4b8
+	.long 0x9fc2c25d,0x5d9fc2c2,0xc25d9fc2,0xc2c25d9f
+	.long 0xbdd3d36e,0x6ebdd3d3,0xd36ebdd3,0xd3d36ebd
+	.long 0x43acacef,0xef43acac,0xacef43ac,0xacacef43
+	.long 0xc46262a6,0xa6c46262,0x62a6c462,0x6262a6c4
+	.long 0x399191a8,0xa8399191,0x91a83991,0x9191a839
+	.long 0x319595a4,0xa4319595,0x95a43195,0x9595a431
+	.long 0xd3e4e437,0x37d3e4e4,0xe437d3e4,0xe4e437d3
+	.long 0xf279798b,0x8bf27979,0x798bf279,0x79798bf2
+	.long 0xd5e7e732,0x32d5e7e7,0xe732d5e7,0xe7e732d5
+	.long 0x8bc8c843,0x438bc8c8,0xc8438bc8,0xc8c8438b
+	.long 0x6e373759,0x596e3737,0x37596e37,0x3737596e
+	.long 0xda6d6db7,0xb7da6d6d,0x6db7da6d,0x6d6db7da
+	.long 0x018d8d8c,0x8c018d8d,0x8d8c018d,0x8d8d8c01
+	.long 0xb1d5d564,0x64b1d5d5,0xd564b1d5,0xd5d564b1
+	.long 0x9c4e4ed2,0xd29c4e4e,0x4ed29c4e,0x4e4ed29c
+	.long 0x49a9a9e0,0xe049a9a9,0xa9e049a9,0xa9a9e049
+	.long 0xd86c6cb4,0xb4d86c6c,0x6cb4d86c,0x6c6cb4d8
+	.long 0xac5656fa,0xfaac5656,0x56faac56,0x5656faac
+	.long 0xf3f4f407,0x07f3f4f4,0xf407f3f4,0xf4f407f3
+	.long 0xcfeaea25,0x25cfeaea,0xea25cfea,0xeaea25cf
+	.long 0xca6565af,0xafca6565,0x65afca65,0x6565afca
+	.long 0xf47a7a8e,0x8ef47a7a,0x7a8ef47a,0x7a7a8ef4
+	.long 0x47aeaee9,0xe947aeae,0xaee947ae,0xaeaee947
+	.long 0x10080818,0x18100808,0x08181008,0x08081810
+	.long 0x6fbabad5,0xd56fbaba,0xbad56fba,0xbabad56f
+	.long 0xf0787888,0x88f07878,0x7888f078,0x787888f0
+	.long 0x4a25256f,0x6f4a2525,0x256f4a25,0x25256f4a
+	.long 0x5c2e2e72,0x725c2e2e,0x2e725c2e,0x2e2e725c
+	.long 0x381c1c24,0x24381c1c,0x1c24381c,0x1c1c2438
+	.long 0x57a6a6f1,0xf157a6a6,0xa6f157a6,0xa6a6f157
+	.long 0x73b4b4c7,0xc773b4b4,0xb4c773b4,0xb4b4c773
+	.long 0x97c6c651,0x5197c6c6,0xc65197c6,0xc6c65197
+	.long 0xcbe8e823,0x23cbe8e8,0xe823cbe8,0xe8e823cb
+	.long 0xa1dddd7c,0x7ca1dddd,0xdd7ca1dd,0xdddd7ca1
+	.long 0xe874749c,0x9ce87474,0x749ce874,0x74749ce8
+	.long 0x3e1f1f21,0x213e1f1f,0x1f213e1f,0x1f1f213e
+	.long 0x964b4bdd,0xdd964b4b,0x4bdd964b,0x4b4bdd96
+	.long 0x61bdbddc,0xdc61bdbd,0xbddc61bd,0xbdbddc61
+	.long 0x0d8b8b86,0x860d8b8b,0x8b860d8b,0x8b8b860d
+	.long 0x0f8a8a85,0x850f8a8a,0x8a850f8a,0x8a8a850f
+	.long 0xe0707090,0x90e07070,0x7090e070,0x707090e0
+	.long 0x7c3e3e42,0x427c3e3e,0x3e427c3e,0x3e3e427c
+	.long 0x71b5b5c4,0xc471b5b5,0xb5c471b5,0xb5b5c471
+	.long 0xcc6666aa,0xaacc6666,0x66aacc66,0x6666aacc
+	.long 0x904848d8,0xd8904848,0x48d89048,0x4848d890
+	.long 0x06030305,0x05060303,0x03050603,0x03030506
+	.long 0xf7f6f601,0x01f7f6f6,0xf601f7f6,0xf6f601f7
+	.long 0x1c0e0e12,0x121c0e0e,0x0e121c0e,0x0e0e121c
+	.long 0xc26161a3,0xa3c26161,0x61a3c261,0x6161a3c2
+	.long 0x6a35355f,0x5f6a3535,0x355f6a35,0x35355f6a
+	.long 0xae5757f9,0xf9ae5757,0x57f9ae57,0x5757f9ae
+	.long 0x69b9b9d0,0xd069b9b9,0xb9d069b9,0xb9b9d069
+	.long 0x17868691,0x91178686,0x86911786,0x86869117
+	.long 0x99c1c158,0x5899c1c1,0xc15899c1,0xc1c15899
+	.long 0x3a1d1d27,0x273a1d1d,0x1d273a1d,0x1d1d273a
+	.long 0x279e9eb9,0xb9279e9e,0x9eb9279e,0x9e9eb927
+	.long 0xd9e1e138,0x38d9e1e1,0xe138d9e1,0xe1e138d9
+	.long 0xebf8f813,0x13ebf8f8,0xf813ebf8,0xf8f813eb
+	.long 0x2b9898b3,0xb32b9898,0x98b32b98,0x9898b32b
+	.long 0x22111133,0x33221111,0x11332211,0x11113322
+	.long 0xd26969bb,0xbbd26969,0x69bbd269,0x6969bbd2
+	.long 0xa9d9d970,0x70a9d9d9,0xd970a9d9,0xd9d970a9
+	.long 0x078e8e89,0x89078e8e,0x8e89078e,0x8e8e8907
+	.long 0x339494a7,0xa7339494,0x94a73394,0x9494a733
+	.long 0x2d9b9bb6,0xb62d9b9b,0x9bb62d9b,0x9b9bb62d
+	.long 0x3c1e1e22,0x223c1e1e,0x1e223c1e,0x1e1e223c
+	.long 0x15878792,0x92158787,0x87921587,0x87879215
+	.long 0xc9e9e920,0x20c9e9e9,0xe920c9e9,0xe9e920c9
+	.long 0x87cece49,0x4987cece,0xce4987ce,0xcece4987
+	.long 0xaa5555ff,0xffaa5555,0x55ffaa55,0x5555ffaa
+	.long 0x50282878,0x78502828,0x28785028,0x28287850
+	.long 0xa5dfdf7a,0x7aa5dfdf,0xdf7aa5df,0xdfdf7aa5
+	.long 0x038c8c8f,0x8f038c8c,0x8c8f038c,0x8c8c8f03
+	.long 0x59a1a1f8,0xf859a1a1,0xa1f859a1,0xa1a1f859
+	.long 0x09898980,0x80098989,0x89800989,0x89898009
+	.long 0x1a0d0d17,0x171a0d0d,0x0d171a0d,0x0d0d171a
+	.long 0x65bfbfda,0xda65bfbf,0xbfda65bf,0xbfbfda65
+	.long 0xd7e6e631,0x31d7e6e6,0xe631d7e6,0xe6e631d7
+	.long 0x844242c6,0xc6844242,0x42c68442,0x4242c684
+	.long 0xd06868b8,0xb8d06868,0x68b8d068,0x6868b8d0
+	.long 0x824141c3,0xc3824141,0x41c38241,0x4141c382
+	.long 0x299999b0,0xb0299999,0x99b02999,0x9999b029
+	.long 0x5a2d2d77,0x775a2d2d,0x2d775a2d,0x2d2d775a
+	.long 0x1e0f0f11,0x111e0f0f,0x0f111e0f,0x0f0f111e
+	.long 0x7bb0b0cb,0xcb7bb0b0,0xb0cb7bb0,0xb0b0cb7b
+	.long 0xa85454fc,0xfca85454,0x54fca854,0x5454fca8
+	.long 0x6dbbbbd6,0xd66dbbbb,0xbbd66dbb,0xbbbbd66d
+	.long 0x2c16163a,0x3a2c1616,0x163a2c16,0x16163a2c
+.globl PPC_AES_4K_DECTAB
+PPC_AES_4K_DECTAB:
+	.long 0x51f4a750,0x5051f4a7,0xa75051f4,0xf4a75051
+	.long 0x7e416553,0x537e4165,0x65537e41,0x4165537e
+	.long 0x1a17a4c3,0xc31a17a4,0xa4c31a17,0x17a4c31a
+	.long 0x3a275e96,0x963a275e,0x5e963a27,0x275e963a
+	.long 0x3bab6bcb,0xcb3bab6b,0x6bcb3bab,0xab6bcb3b
+	.long 0x1f9d45f1,0xf11f9d45,0x45f11f9d,0x9d45f11f
+	.long 0xacfa58ab,0xabacfa58,0x58abacfa,0xfa58abac
+	.long 0x4be30393,0x934be303,0x03934be3,0xe303934b
+	.long 0x2030fa55,0x552030fa,0xfa552030,0x30fa5520
+	.long 0xad766df6,0xf6ad766d,0x6df6ad76,0x766df6ad
+	.long 0x88cc7691,0x9188cc76,0x769188cc,0xcc769188
+	.long 0xf5024c25,0x25f5024c,0x4c25f502,0x024c25f5
+	.long 0x4fe5d7fc,0xfc4fe5d7,0xd7fc4fe5,0xe5d7fc4f
+	.long 0xc52acbd7,0xd7c52acb,0xcbd7c52a,0x2acbd7c5
+	.long 0x26354480,0x80263544,0x44802635,0x35448026
+	.long 0xb562a38f,0x8fb562a3,0xa38fb562,0x62a38fb5
+	.long 0xdeb15a49,0x49deb15a,0x5a49deb1,0xb15a49de
+	.long 0x25ba1b67,0x6725ba1b,0x1b6725ba,0xba1b6725
+	.long 0x45ea0e98,0x9845ea0e,0x0e9845ea,0xea0e9845
+	.long 0x5dfec0e1,0xe15dfec0,0xc0e15dfe,0xfec0e15d
+	.long 0xc32f7502,0x02c32f75,0x7502c32f,0x2f7502c3
+	.long 0x814cf012,0x12814cf0,0xf012814c,0x4cf01281
+	.long 0x8d4697a3,0xa38d4697,0x97a38d46,0x4697a38d
+	.long 0x6bd3f9c6,0xc66bd3f9,0xf9c66bd3,0xd3f9c66b
+	.long 0x038f5fe7,0xe7038f5f,0x5fe7038f,0x8f5fe703
+	.long 0x15929c95,0x9515929c,0x9c951592,0x929c9515
+	.long 0xbf6d7aeb,0xebbf6d7a,0x7aebbf6d,0x6d7aebbf
+	.long 0x955259da,0xda955259,0x59da9552,0x5259da95
+	.long 0xd4be832d,0x2dd4be83,0x832dd4be,0xbe832dd4
+	.long 0x587421d3,0xd3587421,0x21d35874,0x7421d358
+	.long 0x49e06929,0x2949e069,0x692949e0,0xe0692949
+	.long 0x8ec9c844,0x448ec9c8,0xc8448ec9,0xc9c8448e
+	.long 0x75c2896a,0x6a75c289,0x896a75c2,0xc2896a75
+	.long 0xf48e7978,0x78f48e79,0x7978f48e,0x8e7978f4
+	.long 0x99583e6b,0x6b99583e,0x3e6b9958,0x583e6b99
+	.long 0x27b971dd,0xdd27b971,0x71dd27b9,0xb971dd27
+	.long 0xbee14fb6,0xb6bee14f,0x4fb6bee1,0xe14fb6be
+	.long 0xf088ad17,0x17f088ad,0xad17f088,0x88ad17f0
+	.long 0xc920ac66,0x66c920ac,0xac66c920,0x20ac66c9
+	.long 0x7dce3ab4,0xb47dce3a,0x3ab47dce,0xce3ab47d
+	.long 0x63df4a18,0x1863df4a,0x4a1863df,0xdf4a1863
+	.long 0xe51a3182,0x82e51a31,0x3182e51a,0x1a3182e5
+	.long 0x97513360,0x60975133,0x33609751,0x51336097
+	.long 0x62537f45,0x4562537f,0x7f456253,0x537f4562
+	.long 0xb16477e0,0xe0b16477,0x77e0b164,0x6477e0b1
+	.long 0xbb6bae84,0x84bb6bae,0xae84bb6b,0x6bae84bb
+	.long 0xfe81a01c,0x1cfe81a0,0xa01cfe81,0x81a01cfe
+	.long 0xf9082b94,0x94f9082b,0x2b94f908,0x082b94f9
+	.long 0x70486858,0x58704868,0x68587048,0x48685870
+	.long 0x8f45fd19,0x198f45fd,0xfd198f45,0x45fd198f
+	.long 0x94de6c87,0x8794de6c,0x6c8794de,0xde6c8794
+	.long 0x527bf8b7,0xb7527bf8,0xf8b7527b,0x7bf8b752
+	.long 0xab73d323,0x23ab73d3,0xd323ab73,0x73d323ab
+	.long 0x724b02e2,0xe2724b02,0x02e2724b,0x4b02e272
+	.long 0xe31f8f57,0x57e31f8f,0x8f57e31f,0x1f8f57e3
+	.long 0x6655ab2a,0x2a6655ab,0xab2a6655,0x55ab2a66
+	.long 0xb2eb2807,0x07b2eb28,0x2807b2eb,0xeb2807b2
+	.long 0x2fb5c203,0x032fb5c2,0xc2032fb5,0xb5c2032f
+	.long 0x86c57b9a,0x9a86c57b,0x7b9a86c5,0xc57b9a86
+	.long 0xd33708a5,0xa5d33708,0x08a5d337,0x3708a5d3
+	.long 0x302887f2,0xf2302887,0x87f23028,0x2887f230
+	.long 0x23bfa5b2,0xb223bfa5,0xa5b223bf,0xbfa5b223
+	.long 0x02036aba,0xba02036a,0x6aba0203,0x036aba02
+	.long 0xed16825c,0x5ced1682,0x825ced16,0x16825ced
+	.long 0x8acf1c2b,0x2b8acf1c,0x1c2b8acf,0xcf1c2b8a
+	.long 0xa779b492,0x92a779b4,0xb492a779,0x79b492a7
+	.long 0xf307f2f0,0xf0f307f2,0xf2f0f307,0x07f2f0f3
+	.long 0x4e69e2a1,0xa14e69e2,0xe2a14e69,0x69e2a14e
+	.long 0x65daf4cd,0xcd65daf4,0xf4cd65da,0xdaf4cd65
+	.long 0x0605bed5,0xd50605be,0xbed50605,0x05bed506
+	.long 0xd134621f,0x1fd13462,0x621fd134,0x34621fd1
+	.long 0xc4a6fe8a,0x8ac4a6fe,0xfe8ac4a6,0xa6fe8ac4
+	.long 0x342e539d,0x9d342e53,0x539d342e,0x2e539d34
+	.long 0xa2f355a0,0xa0a2f355,0x55a0a2f3,0xf355a0a2
+	.long 0x058ae132,0x32058ae1,0xe132058a,0x8ae13205
+	.long 0xa4f6eb75,0x75a4f6eb,0xeb75a4f6,0xf6eb75a4
+	.long 0x0b83ec39,0x390b83ec,0xec390b83,0x83ec390b
+	.long 0x4060efaa,0xaa4060ef,0xefaa4060,0x60efaa40
+	.long 0x5e719f06,0x065e719f,0x9f065e71,0x719f065e
+	.long 0xbd6e1051,0x51bd6e10,0x1051bd6e,0x6e1051bd
+	.long 0x3e218af9,0xf93e218a,0x8af93e21,0x218af93e
+	.long 0x96dd063d,0x3d96dd06,0x063d96dd,0xdd063d96
+	.long 0xdd3e05ae,0xaedd3e05,0x05aedd3e,0x3e05aedd
+	.long 0x4de6bd46,0x464de6bd,0xbd464de6,0xe6bd464d
+	.long 0x91548db5,0xb591548d,0x8db59154,0x548db591
+	.long 0x71c45d05,0x0571c45d,0x5d0571c4,0xc45d0571
+	.long 0x0406d46f,0x6f0406d4,0xd46f0406,0x06d46f04
+	.long 0x605015ff,0xff605015,0x15ff6050,0x5015ff60
+	.long 0x1998fb24,0x241998fb,0xfb241998,0x98fb2419
+	.long 0xd6bde997,0x97d6bde9,0xe997d6bd,0xbde997d6
+	.long 0x894043cc,0xcc894043,0x43cc8940,0x4043cc89
+	.long 0x67d99e77,0x7767d99e,0x9e7767d9,0xd99e7767
+	.long 0xb0e842bd,0xbdb0e842,0x42bdb0e8,0xe842bdb0
+	.long 0x07898b88,0x8807898b,0x8b880789,0x898b8807
+	.long 0xe7195b38,0x38e7195b,0x5b38e719,0x195b38e7
+	.long 0x79c8eedb,0xdb79c8ee,0xeedb79c8,0xc8eedb79
+	.long 0xa17c0a47,0x47a17c0a,0x0a47a17c,0x7c0a47a1
+	.long 0x7c420fe9,0xe97c420f,0x0fe97c42,0x420fe97c
+	.long 0xf8841ec9,0xc9f8841e,0x1ec9f884,0x841ec9f8
+	.long 0x00000000,0x00000000,0x00000000,0x00000000
+	.long 0x09808683,0x83098086,0x86830980,0x80868309
+	.long 0x322bed48,0x48322bed,0xed48322b,0x2bed4832
+	.long 0x1e1170ac,0xac1e1170,0x70ac1e11,0x1170ac1e
+	.long 0x6c5a724e,0x4e6c5a72,0x724e6c5a,0x5a724e6c
+	.long 0xfd0efffb,0xfbfd0eff,0xfffbfd0e,0x0efffbfd
+	.long 0x0f853856,0x560f8538,0x38560f85,0x8538560f
+	.long 0x3daed51e,0x1e3daed5,0xd51e3dae,0xaed51e3d
+	.long 0x362d3927,0x27362d39,0x3927362d,0x2d392736
+	.long 0x0a0fd964,0x640a0fd9,0xd9640a0f,0x0fd9640a
+	.long 0x685ca621,0x21685ca6,0xa621685c,0x5ca62168
+	.long 0x9b5b54d1,0xd19b5b54,0x54d19b5b,0x5b54d19b
+	.long 0x24362e3a,0x3a24362e,0x2e3a2436,0x362e3a24
+	.long 0x0c0a67b1,0xb10c0a67,0x67b10c0a,0x0a67b10c
+	.long 0x9357e70f,0x0f9357e7,0xe70f9357,0x57e70f93
+	.long 0xb4ee96d2,0xd2b4ee96,0x96d2b4ee,0xee96d2b4
+	.long 0x1b9b919e,0x9e1b9b91,0x919e1b9b,0x9b919e1b
+	.long 0x80c0c54f,0x4f80c0c5,0xc54f80c0,0xc0c54f80
+	.long 0x61dc20a2,0xa261dc20,0x20a261dc,0xdc20a261
+	.long 0x5a774b69,0x695a774b,0x4b695a77,0x774b695a
+	.long 0x1c121a16,0x161c121a,0x1a161c12,0x121a161c
+	.long 0xe293ba0a,0x0ae293ba,0xba0ae293,0x93ba0ae2
+	.long 0xc0a02ae5,0xe5c0a02a,0x2ae5c0a0,0xa02ae5c0
+	.long 0x3c22e043,0x433c22e0,0xe0433c22,0x22e0433c
+	.long 0x121b171d,0x1d121b17,0x171d121b,0x1b171d12
+	.long 0x0e090d0b,0x0b0e090d,0x0d0b0e09,0x090d0b0e
+	.long 0xf28bc7ad,0xadf28bc7,0xc7adf28b,0x8bc7adf2
+	.long 0x2db6a8b9,0xb92db6a8,0xa8b92db6,0xb6a8b92d
+	.long 0x141ea9c8,0xc8141ea9,0xa9c8141e,0x1ea9c814
+	.long 0x57f11985,0x8557f119,0x198557f1,0xf1198557
+	.long 0xaf75074c,0x4caf7507,0x074caf75,0x75074caf
+	.long 0xee99ddbb,0xbbee99dd,0xddbbee99,0x99ddbbee
+	.long 0xa37f60fd,0xfda37f60,0x60fda37f,0x7f60fda3
+	.long 0xf701269f,0x9ff70126,0x269ff701,0x01269ff7
+	.long 0x5c72f5bc,0xbc5c72f5,0xf5bc5c72,0x72f5bc5c
+	.long 0x44663bc5,0xc544663b,0x3bc54466,0x663bc544
+	.long 0x5bfb7e34,0x345bfb7e,0x7e345bfb,0xfb7e345b
+	.long 0x8b432976,0x768b4329,0x29768b43,0x4329768b
+	.long 0xcb23c6dc,0xdccb23c6,0xc6dccb23,0x23c6dccb
+	.long 0xb6edfc68,0x68b6edfc,0xfc68b6ed,0xedfc68b6
+	.long 0xb8e4f163,0x63b8e4f1,0xf163b8e4,0xe4f163b8
+	.long 0xd731dcca,0xcad731dc,0xdccad731,0x31dccad7
+	.long 0x42638510,0x10426385,0x85104263,0x63851042
+	.long 0x13972240,0x40139722,0x22401397,0x97224013
+	.long 0x84c61120,0x2084c611,0x112084c6,0xc6112084
+	.long 0x854a247d,0x7d854a24,0x247d854a,0x4a247d85
+	.long 0xd2bb3df8,0xf8d2bb3d,0x3df8d2bb,0xbb3df8d2
+	.long 0xaef93211,0x11aef932,0x3211aef9,0xf93211ae
+	.long 0xc729a16d,0x6dc729a1,0xa16dc729,0x29a16dc7
+	.long 0x1d9e2f4b,0x4b1d9e2f,0x2f4b1d9e,0x9e2f4b1d
+	.long 0xdcb230f3,0xf3dcb230,0x30f3dcb2,0xb230f3dc
+	.long 0x0d8652ec,0xec0d8652,0x52ec0d86,0x8652ec0d
+	.long 0x77c1e3d0,0xd077c1e3,0xe3d077c1,0xc1e3d077
+	.long 0x2bb3166c,0x6c2bb316,0x166c2bb3,0xb3166c2b
+	.long 0xa970b999,0x99a970b9,0xb999a970,0x70b999a9
+	.long 0x119448fa,0xfa119448,0x48fa1194,0x9448fa11
+	.long 0x47e96422,0x2247e964,0x642247e9,0xe9642247
+	.long 0xa8fc8cc4,0xc4a8fc8c,0x8cc4a8fc,0xfc8cc4a8
+	.long 0xa0f03f1a,0x1aa0f03f,0x3f1aa0f0,0xf03f1aa0
+	.long 0x567d2cd8,0xd8567d2c,0x2cd8567d,0x7d2cd856
+	.long 0x223390ef,0xef223390,0x90ef2233,0x3390ef22
+	.long 0x87494ec7,0xc787494e,0x4ec78749,0x494ec787
+	.long 0xd938d1c1,0xc1d938d1,0xd1c1d938,0x38d1c1d9
+	.long 0x8ccaa2fe,0xfe8ccaa2,0xa2fe8cca,0xcaa2fe8c
+	.long 0x98d40b36,0x3698d40b,0x0b3698d4,0xd40b3698
+	.long 0xa6f581cf,0xcfa6f581,0x81cfa6f5,0xf581cfa6
+	.long 0xa57ade28,0x28a57ade,0xde28a57a,0x7ade28a5
+	.long 0xdab78e26,0x26dab78e,0x8e26dab7,0xb78e26da
+	.long 0x3fadbfa4,0xa43fadbf,0xbfa43fad,0xadbfa43f
+	.long 0x2c3a9de4,0xe42c3a9d,0x9de42c3a,0x3a9de42c
+	.long 0x5078920d,0x0d507892,0x920d5078,0x78920d50
+	.long 0x6a5fcc9b,0x9b6a5fcc,0xcc9b6a5f,0x5fcc9b6a
+	.long 0x547e4662,0x62547e46,0x4662547e,0x7e466254
+	.long 0xf68d13c2,0xc2f68d13,0x13c2f68d,0x8d13c2f6
+	.long 0x90d8b8e8,0xe890d8b8,0xb8e890d8,0xd8b8e890
+	.long 0x2e39f75e,0x5e2e39f7,0xf75e2e39,0x39f75e2e
+	.long 0x82c3aff5,0xf582c3af,0xaff582c3,0xc3aff582
+	.long 0x9f5d80be,0xbe9f5d80,0x80be9f5d,0x5d80be9f
+	.long 0x69d0937c,0x7c69d093,0x937c69d0,0xd0937c69
+	.long 0x6fd52da9,0xa96fd52d,0x2da96fd5,0xd52da96f
+	.long 0xcf2512b3,0xb3cf2512,0x12b3cf25,0x2512b3cf
+	.long 0xc8ac993b,0x3bc8ac99,0x993bc8ac,0xac993bc8
+	.long 0x10187da7,0xa710187d,0x7da71018,0x187da710
+	.long 0xe89c636e,0x6ee89c63,0x636ee89c,0x9c636ee8
+	.long 0xdb3bbb7b,0x7bdb3bbb,0xbb7bdb3b,0x3bbb7bdb
+	.long 0xcd267809,0x09cd2678,0x7809cd26,0x267809cd
+	.long 0x6e5918f4,0xf46e5918,0x18f46e59,0x5918f46e
+	.long 0xec9ab701,0x01ec9ab7,0xb701ec9a,0x9ab701ec
+	.long 0x834f9aa8,0xa8834f9a,0x9aa8834f,0x4f9aa883
+	.long 0xe6956e65,0x65e6956e,0x6e65e695,0x956e65e6
+	.long 0xaaffe67e,0x7eaaffe6,0xe67eaaff,0xffe67eaa
+	.long 0x21bccf08,0x0821bccf,0xcf0821bc,0xbccf0821
+	.long 0xef15e8e6,0xe6ef15e8,0xe8e6ef15,0x15e8e6ef
+	.long 0xbae79bd9,0xd9bae79b,0x9bd9bae7,0xe79bd9ba
+	.long 0x4a6f36ce,0xce4a6f36,0x36ce4a6f,0x6f36ce4a
+	.long 0xea9f09d4,0xd4ea9f09,0x09d4ea9f,0x9f09d4ea
+	.long 0x29b07cd6,0xd629b07c,0x7cd629b0,0xb07cd629
+	.long 0x31a4b2af,0xaf31a4b2,0xb2af31a4,0xa4b2af31
+	.long 0x2a3f2331,0x312a3f23,0x23312a3f,0x3f23312a
+	.long 0xc6a59430,0x30c6a594,0x9430c6a5,0xa59430c6
+	.long 0x35a266c0,0xc035a266,0x66c035a2,0xa266c035
+	.long 0x744ebc37,0x37744ebc,0xbc37744e,0x4ebc3774
+	.long 0xfc82caa6,0xa6fc82ca,0xcaa6fc82,0x82caa6fc
+	.long 0xe090d0b0,0xb0e090d0,0xd0b0e090,0x90d0b0e0
+	.long 0x33a7d815,0x1533a7d8,0xd81533a7,0xa7d81533
+	.long 0xf104984a,0x4af10498,0x984af104,0x04984af1
+	.long 0x41ecdaf7,0xf741ecda,0xdaf741ec,0xecdaf741
+	.long 0x7fcd500e,0x0e7fcd50,0x500e7fcd,0xcd500e7f
+	.long 0x1791f62f,0x2f1791f6,0xf62f1791,0x91f62f17
+	.long 0x764dd68d,0x8d764dd6,0xd68d764d,0x4dd68d76
+	.long 0x43efb04d,0x4d43efb0,0xb04d43ef,0xefb04d43
+	.long 0xccaa4d54,0x54ccaa4d,0x4d54ccaa,0xaa4d54cc
+	.long 0xe49604df,0xdfe49604,0x04dfe496,0x9604dfe4
+	.long 0x9ed1b5e3,0xe39ed1b5,0xb5e39ed1,0xd1b5e39e
+	.long 0x4c6a881b,0x1b4c6a88,0x881b4c6a,0x6a881b4c
+	.long 0xc12c1fb8,0xb8c12c1f,0x1fb8c12c,0x2c1fb8c1
+	.long 0x4665517f,0x7f466551,0x517f4665,0x65517f46
+	.long 0x9d5eea04,0x049d5eea,0xea049d5e,0x5eea049d
+	.long 0x018c355d,0x5d018c35,0x355d018c,0x8c355d01
+	.long 0xfa877473,0x73fa8774,0x7473fa87,0x877473fa
+	.long 0xfb0b412e,0x2efb0b41,0x412efb0b,0x0b412efb
+	.long 0xb3671d5a,0x5ab3671d,0x1d5ab367,0x671d5ab3
+	.long 0x92dbd252,0x5292dbd2,0xd25292db,0xdbd25292
+	.long 0xe9105633,0x33e91056,0x5633e910,0x105633e9
+	.long 0x6dd64713,0x136dd647,0x47136dd6,0xd647136d
+	.long 0x9ad7618c,0x8c9ad761,0x618c9ad7,0xd7618c9a
+	.long 0x37a10c7a,0x7a37a10c,0x0c7a37a1,0xa10c7a37
+	.long 0x59f8148e,0x8e59f814,0x148e59f8,0xf8148e59
+	.long 0xeb133c89,0x89eb133c,0x3c89eb13,0x133c89eb
+	.long 0xcea927ee,0xeecea927,0x27eecea9,0xa927eece
+	.long 0xb761c935,0x35b761c9,0xc935b761,0x61c935b7
+	.long 0xe11ce5ed,0xede11ce5,0xe5ede11c,0x1ce5ede1
+	.long 0x7a47b13c,0x3c7a47b1,0xb13c7a47,0x47b13c7a
+	.long 0x9cd2df59,0x599cd2df,0xdf599cd2,0xd2df599c
+	.long 0x55f2733f,0x3f55f273,0x733f55f2,0xf2733f55
+	.long 0x1814ce79,0x791814ce,0xce791814,0x14ce7918
+	.long 0x73c737bf,0xbf73c737,0x37bf73c7,0xc737bf73
+	.long 0x53f7cdea,0xea53f7cd,0xcdea53f7,0xf7cdea53
+	.long 0x5ffdaa5b,0x5b5ffdaa,0xaa5b5ffd,0xfdaa5b5f
+	.long 0xdf3d6f14,0x14df3d6f,0x6f14df3d,0x3d6f14df
+	.long 0x7844db86,0x867844db,0xdb867844,0x44db8678
+	.long 0xcaaff381,0x81caaff3,0xf381caaf,0xaff381ca
+	.long 0xb968c43e,0x3eb968c4,0xc43eb968,0x68c43eb9
+	.long 0x3824342c,0x2c382434,0x342c3824,0x24342c38
+	.long 0xc2a3405f,0x5fc2a340,0x405fc2a3,0xa3405fc2
+	.long 0x161dc372,0x72161dc3,0xc372161d,0x1dc37216
+	.long 0xbce2250c,0x0cbce225,0x250cbce2,0xe2250cbc
+	.long 0x283c498b,0x8b283c49,0x498b283c,0x3c498b28
+	.long 0xff0d9541,0x41ff0d95,0x9541ff0d,0x0d9541ff
+	.long 0x39a80171,0x7139a801,0x017139a8,0xa8017139
+	.long 0x080cb3de,0xde080cb3,0xb3de080c,0x0cb3de08
+	.long 0xd8b4e49c,0x9cd8b4e4,0xe49cd8b4,0xb4e49cd8
+	.long 0x6456c190,0x906456c1,0xc1906456,0x56c19064
+	.long 0x7bcb8461,0x617bcb84,0x84617bcb,0xcb84617b
+	.long 0xd532b670,0x70d532b6,0xb670d532,0x32b670d5
+	.long 0x486c5c74,0x74486c5c,0x5c74486c,0x6c5c7448
+	.long 0xd0b85742,0x42d0b857,0x5742d0b8,0xb85742d0
+	.byte 0x52, 0x09, 0x6a, 0xd5, 0x30, 0x36, 0xa5, 0x38
+	.byte 0xbf, 0x40, 0xa3, 0x9e, 0x81, 0xf3, 0xd7, 0xfb
+	.byte 0x7c, 0xe3, 0x39, 0x82, 0x9b, 0x2f, 0xff, 0x87
+	.byte 0x34, 0x8e, 0x43, 0x44, 0xc4, 0xde, 0xe9, 0xcb
+	.byte 0x54, 0x7b, 0x94, 0x32, 0xa6, 0xc2, 0x23, 0x3d
+	.byte 0xee, 0x4c, 0x95, 0x0b, 0x42, 0xfa, 0xc3, 0x4e
+	.byte 0x08, 0x2e, 0xa1, 0x66, 0x28, 0xd9, 0x24, 0xb2
+	.byte 0x76, 0x5b, 0xa2, 0x49, 0x6d, 0x8b, 0xd1, 0x25
+	.byte 0x72, 0xf8, 0xf6, 0x64, 0x86, 0x68, 0x98, 0x16
+	.byte 0xd4, 0xa4, 0x5c, 0xcc, 0x5d, 0x65, 0xb6, 0x92
+	.byte 0x6c, 0x70, 0x48, 0x50, 0xfd, 0xed, 0xb9, 0xda
+	.byte 0x5e, 0x15, 0x46, 0x57, 0xa7, 0x8d, 0x9d, 0x84
+	.byte 0x90, 0xd8, 0xab, 0x00, 0x8c, 0xbc, 0xd3, 0x0a
+	.byte 0xf7, 0xe4, 0x58, 0x05, 0xb8, 0xb3, 0x45, 0x06
+	.byte 0xd0, 0x2c, 0x1e, 0x8f, 0xca, 0x3f, 0x0f, 0x02
+	.byte 0xc1, 0xaf, 0xbd, 0x03, 0x01, 0x13, 0x8a, 0x6b
+	.byte 0x3a, 0x91, 0x11, 0x41, 0x4f, 0x67, 0xdc, 0xea
+	.byte 0x97, 0xf2, 0xcf, 0xce, 0xf0, 0xb4, 0xe6, 0x73
+	.byte 0x96, 0xac, 0x74, 0x22, 0xe7, 0xad, 0x35, 0x85
+	.byte 0xe2, 0xf9, 0x37, 0xe8, 0x1c, 0x75, 0xdf, 0x6e
+	.byte 0x47, 0xf1, 0x1a, 0x71, 0x1d, 0x29, 0xc5, 0x89
+	.byte 0x6f, 0xb7, 0x62, 0x0e, 0xaa, 0x18, 0xbe, 0x1b
+	.byte 0xfc, 0x56, 0x3e, 0x4b, 0xc6, 0xd2, 0x79, 0x20
+	.byte 0x9a, 0xdb, 0xc0, 0xfe, 0x78, 0xcd, 0x5a, 0xf4
+	.byte 0x1f, 0xdd, 0xa8, 0x33, 0x88, 0x07, 0xc7, 0x31
+	.byte 0xb1, 0x12, 0x10, 0x59, 0x27, 0x80, 0xec, 0x5f
+	.byte 0x60, 0x51, 0x7f, 0xa9, 0x19, 0xb5, 0x4a, 0x0d
+	.byte 0x2d, 0xe5, 0x7a, 0x9f, 0x93, 0xc9, 0x9c, 0xef
+	.byte 0xa0, 0xe0, 0x3b, 0x4d, 0xae, 0x2a, 0xf5, 0xb0
+	.byte 0xc8, 0xeb, 0xbb, 0x3c, 0x83, 0x53, 0x99, 0x61
+	.byte 0x17, 0x2b, 0x04, 0x7e, 0xba, 0x77, 0xd6, 0x26
+	.byte 0xe1, 0x69, 0x14, 0x63, 0x55, 0x21, 0x0c, 0x7d