grpc
third_party
boringssl-with-bazel
src
crypto
fipsmodule
modes
ofb.c
Go to the documentation of this file.
1
/* ====================================================================
2
* Copyright (c) 2008 The OpenSSL Project. All rights reserved.
3
*
4
* Redistribution and use in source and binary forms, with or without
5
* modification, are permitted provided that the following conditions
6
* are met:
7
*
8
* 1. Redistributions of source code must retain the above copyright
9
* notice, this list of conditions and the following disclaimer.
10
*
11
* 2. Redistributions in binary form must reproduce the above copyright
12
* notice, this list of conditions and the following disclaimer in
13
* the documentation and/or other materials provided with the
14
* distribution.
15
*
16
* 3. All advertising materials mentioning features or use of this
17
* software must display the following acknowledgment:
18
* "This product includes software developed by the OpenSSL Project
19
* for use in the OpenSSL Toolkit. (http://www.openssl.org/)"
20
*
21
* 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
22
* endorse or promote products derived from this software without
23
* prior written permission. For written permission, please contact
24
* openssl-core@openssl.org.
25
*
26
* 5. Products derived from this software may not be called "OpenSSL"
27
* nor may "OpenSSL" appear in their names without prior written
28
* permission of the OpenSSL Project.
29
*
30
* 6. Redistributions of any form whatsoever must retain the following
31
* acknowledgment:
32
* "This product includes software developed by the OpenSSL Project
33
* for use in the OpenSSL Toolkit (http://www.openssl.org/)"
34
*
35
* THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
36
* EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
37
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
38
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OpenSSL PROJECT OR
39
* ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
40
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
41
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
42
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
43
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
44
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
45
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
46
* OF THE POSSIBILITY OF SUCH DAMAGE.
47
* ==================================================================== */
48
49
#include <
openssl/type_check.h
>
50
51
#include <assert.h>
52
#include <
string.h
>
53
54
#include "
internal.h
"
55
56
57
OPENSSL_STATIC_ASSERT
(16 %
sizeof
(
size_t
) == 0,
58
"block cannot be divided into size_t"
);
59
60
void
CRYPTO_ofb128_encrypt
(
const
uint8_t
*
in
,
uint8_t
*
out
,
size_t
len
,
61
const
AES_KEY
*
key
,
uint8_t
ivec[16],
unsigned
*
num
,
62
block128_f
block
) {
63
assert(
key
!= NULL && ivec != NULL &&
num
!= NULL);
64
assert(
len
== 0 || (
in
!= NULL &&
out
!= NULL));
65
66
unsigned
n
= *
num
;
67
68
while
(
n
&&
len
) {
69
*(
out
++) = *(
in
++) ^ ivec[
n
];
70
--
len
;
71
n
= (
n
+ 1) % 16;
72
}
73
74
while
(
len
>= 16) {
75
(*block)(ivec, ivec,
key
);
76
for
(;
n
< 16;
n
+=
sizeof
(size_t)) {
77
size_t
a
,
b
;
78
OPENSSL_memcpy
(&
a
,
in
+
n
,
sizeof
(
size_t
));
79
OPENSSL_memcpy
(&
b
, ivec +
n
,
sizeof
(
size_t
));
80
81
const
size_t
c
=
a
^
b
;
82
OPENSSL_memcpy
(
out
+
n
, &
c
,
sizeof
(
size_t
));
83
}
84
len
-= 16;
85
out
+= 16;
86
in
+= 16;
87
n
= 0;
88
}
89
if
(
len
) {
90
(*block)(ivec, ivec,
key
);
91
while
(
len
--) {
92
out
[
n
] =
in
[
n
] ^ ivec[
n
];
93
++
n
;
94
}
95
}
96
*
num
=
n
;
97
}
gen_build_yaml.out
dictionary out
Definition:
src/benchmark/gen_build_yaml.py:24
string.h
a
int a
Definition:
abseil-cpp/absl/container/internal/hash_policy_traits_test.cc:88
CRYPTO_ofb128_encrypt
void CRYPTO_ofb128_encrypt(const uint8_t *in, uint8_t *out, size_t len, const AES_KEY *key, uint8_t ivec[16], unsigned *num, block128_f block)
Definition:
ofb.c:60
uint8_t
unsigned char uint8_t
Definition:
stdint-msvc2008.h:78
block
Block * block
Definition:
protobuf/src/google/protobuf/descriptor.cc:1041
in
const char * in
Definition:
third_party/abseil-cpp/absl/strings/internal/str_format/parser_test.cc:391
c
void c(T a)
Definition:
miscompile_with_no_unique_address_test.cc:40
OPENSSL_memcpy
static void * OPENSSL_memcpy(void *dst, const void *src, size_t n)
Definition:
third_party/boringssl-with-bazel/src/crypto/internal.h:819
b
uint64_t b
Definition:
abseil-cpp/absl/container/internal/layout_test.cc:53
n
int n
Definition:
abseil-cpp/absl/container/btree_test.cc:1080
internal.h
key
const char * key
Definition:
hpack_parser_table.cc:164
xds_manager.num
num
Definition:
xds_manager.py:56
type_check.h
len
int len
Definition:
abseil-cpp/absl/base/internal/low_level_alloc_test.cc:46
aes_key_st
Definition:
aes.h:72
OPENSSL_STATIC_ASSERT
OPENSSL_STATIC_ASSERT(16 % sizeof(size_t)==0, "block cannot be divided into size_t")
block128_f
void(* block128_f)(const uint8_t in[16], uint8_t out[16], const AES_KEY *key)
Definition:
third_party/boringssl-with-bazel/src/crypto/fipsmodule/modes/internal.h:76
grpc
Author(s):
autogenerated on Fri May 16 2025 02:59:35