author | Dan Anderson <dan.anderson@oracle.com> |
Wed, 20 Jul 2011 10:20:13 -0700 | |
changeset 426 | 8c675b553a27 |
child 603 | 1b966e9a6b03 |
permissions | -rw-r--r-- |
426
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
1 |
/* |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
2 |
* CDDL HEADER START |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
3 |
* |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
4 |
* The contents of this file are subject to the terms of the |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
5 |
* Common Development and Distribution License (the "License"). |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
6 |
* You may not use this file except in compliance with the License. |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
7 |
* |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
8 |
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
9 |
* or http://www.opensolaris.org/os/licensing. |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
10 |
* See the License for the specific language governing permissions |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
11 |
* and limitations under the License. |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
12 |
* |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
13 |
* When distributing Covered Code, include this CDDL HEADER in each |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
14 |
* file and include the License file at usr/src/OPENSOLARIS.LICENSE. |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
15 |
* If applicable, add the following below this CDDL HEADER, with the |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
16 |
* fields enclosed by brackets "[]" replaced with your own identifying |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
17 |
* information: Portions Copyright [yyyy] [name of copyright owner] |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
18 |
* |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
19 |
* CDDL HEADER END |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
20 |
*/ |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
21 |
|
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
22 |
/* |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
23 |
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved. |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
24 |
*/ |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
25 |
|
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
26 |
#ifndef ENG_T4_AES_ASM_H |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
27 |
#define ENG_T4_AES_ASM_H |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
28 |
|
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
29 |
/* |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
30 |
* SPARC AES assembly language functions. |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
31 |
* |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
32 |
* Based on Solaris file aes_impl.h. |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
33 |
*/ |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
34 |
|
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
35 |
#ifdef __cplusplus |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
36 |
extern "C" { |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
37 |
#endif |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
38 |
|
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
39 |
#include <sys/types.h> |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
40 |
|
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
41 |
#if (defined(sun4v) || defined(__sparcv9) || defined(__sparcv8plus) || \ |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
42 |
defined(__sparcv8)) && ! defined(OPENSSL_NO_ASM) |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
43 |
|
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
44 |
extern void t4_aes_expand128(uint64_t *rk, const uint32_t *key); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
45 |
extern void t4_aes_expand192(uint64_t *rk, const uint32_t *key); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
46 |
extern void t4_aes_expand256(uint64_t *rk, const uint32_t *key); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
47 |
extern void t4_aes_encrypt128(const uint64_t *rk, const uint32_t *pt, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
48 |
uint32_t *ct); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
49 |
extern void t4_aes_encrypt192(const uint64_t *rk, const uint32_t *pt, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
50 |
uint32_t *ct); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
51 |
extern void t4_aes_encrypt256(const uint64_t *rk, const uint32_t *pt, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
52 |
uint32_t *ct); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
53 |
extern void t4_aes_decrypt128(const uint64_t *rk, const uint32_t *ct, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
54 |
uint32_t *pt); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
55 |
extern void t4_aes_decrypt192(const uint64_t *rk, const uint32_t *ct, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
56 |
uint32_t *pt); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
57 |
extern void t4_aes_decrypt256(const uint64_t *rk, const uint32_t *ct, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
58 |
uint32_t *pt); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
59 |
extern void t4_aes128_load_keys_for_encrypt(uint64_t *ks); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
60 |
extern void t4_aes192_load_keys_for_encrypt(uint64_t *ks); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
61 |
extern void t4_aes256_load_keys_for_encrypt(uint64_t *ks); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
62 |
extern void t4_aes128_ecb_encrypt(uint64_t *ks, uint64_t *asm_in, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
63 |
uint64_t *asm_out, size_t amount_to_encrypt, uint64_t *dummy); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
64 |
extern void t4_aes192_ecb_encrypt(uint64_t *ks, uint64_t *asm_in, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
65 |
uint64_t *asm_out, size_t amount_to_encrypt, uint64_t *dummy); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
66 |
extern void t4_aes256_ecb_encrypt(uint64_t *ks, uint64_t *asm_in, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
67 |
uint64_t *asm_out, size_t amount_to_encrypt, uint64_t *dummy); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
68 |
extern void t4_aes128_cbc_encrypt(uint64_t *ks, uint64_t *asm_in, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
69 |
uint64_t *asm_out, size_t amount_to_encrypt, uint64_t *iv); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
70 |
extern void t4_aes192_cbc_encrypt(uint64_t *ks, uint64_t *asm_in, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
71 |
uint64_t *asm_out, size_t amount_to_encrypt, uint64_t *iv); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
72 |
extern void t4_aes256_cbc_encrypt(uint64_t *ks, uint64_t *asm_in, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
73 |
uint64_t *asm_out, size_t amount_to_encrypt, uint64_t *iv); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
74 |
extern void t4_aes128_ctr_crypt(uint64_t *ks, uint64_t *asm_in, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
75 |
uint64_t *asm_out, size_t amount_to_encrypt, uint64_t *iv); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
76 |
extern void t4_aes192_ctr_crypt(uint64_t *ks, uint64_t *asm_in, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
77 |
uint64_t *asm_out, size_t amount_to_encrypt, uint64_t *iv); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
78 |
extern void t4_aes256_ctr_crypt(uint64_t *ks, uint64_t *asm_in, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
79 |
uint64_t *asm_out, size_t amount_to_encrypt, uint64_t *iv); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
80 |
extern void t4_aes128_cfb128_encrypt(uint64_t *ks, uint64_t *asm_in, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
81 |
uint64_t *asm_out, size_t amount_to_encrypt, uint64_t *iv); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
82 |
extern void t4_aes192_cfb128_encrypt(uint64_t *ks, uint64_t *asm_in, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
83 |
uint64_t *asm_out, size_t amount_to_encrypt, uint64_t *iv); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
84 |
extern void t4_aes256_cfb128_encrypt(uint64_t *ks, uint64_t *asm_in, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
85 |
uint64_t *asm_out, size_t amount_to_encrypt, uint64_t *iv); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
86 |
extern void t4_aes128_load_keys_for_decrypt(uint64_t *ks); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
87 |
extern void t4_aes192_load_keys_for_decrypt(uint64_t *ks); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
88 |
extern void t4_aes256_load_keys_for_decrypt(uint64_t *ks); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
89 |
extern void t4_aes128_ecb_decrypt(uint64_t *ks, uint64_t *asm_in, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
90 |
uint64_t *asm_out, size_t amount_to_decrypt, uint64_t *dummy); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
91 |
extern void t4_aes192_ecb_decrypt(uint64_t *ks, uint64_t *asm_in, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
92 |
uint64_t *asm_out, size_t amount_to_decrypt, uint64_t *dummy); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
93 |
extern void t4_aes256_ecb_decrypt(uint64_t *ks, uint64_t *asm_in, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
94 |
uint64_t *asm_out, size_t amount_to_decrypt, uint64_t *dummy); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
95 |
extern void t4_aes128_cbc_decrypt(uint64_t *ks, uint64_t *asm_in, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
96 |
uint64_t *asm_out, size_t amount_to_decrypt, uint64_t *iv); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
97 |
extern void t4_aes192_cbc_decrypt(uint64_t *ks, uint64_t *asm_in, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
98 |
uint64_t *asm_out, size_t amount_to_decrypt, uint64_t *iv); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
99 |
extern void t4_aes256_cbc_decrypt(uint64_t *ks, uint64_t *asm_in, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
100 |
uint64_t *asm_out, size_t amount_to_decrypt, uint64_t *iv); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
101 |
extern void t4_aes128_cfb128_decrypt(uint64_t *ks, uint64_t *asm_in, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
102 |
uint64_t *asm_out, size_t amount_to_decrypt, uint64_t *iv); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
103 |
extern void t4_aes192_cfb128_decrypt(uint64_t *ks, uint64_t *asm_in, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
104 |
uint64_t *asm_out, size_t amount_to_decrypt, uint64_t *iv); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
105 |
extern void t4_aes256_cfb128_decrypt(uint64_t *ks, uint64_t *asm_in, |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
106 |
uint64_t *asm_out, size_t amount_to_decrypt, uint64_t *iv); |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
107 |
|
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
108 |
#endif /* (sun4v||__sparv9||__sparcv8plus||__sparvc8) && !OPENSSL_NO_ASM */ |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
109 |
|
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
110 |
#ifdef __cplusplus |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
111 |
} |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
112 |
#endif |
8c675b553a27
7048212 T4 engine needed for openssl
Dan Anderson <dan.anderson@oracle.com>
parents:
diff
changeset
|
113 |
#endif /* ENG_T4_AES_ASM_H */ |