blob: 39b8237ce71e591b79c93f4b5fccaf21c60c171d (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
|
/*
* Copyright 1995-2017 The OpenSSL Project Authors. All Rights Reserved.
*
* Licensed under the Apache License 2.0 (the "License"). You may not use
* this file except in compliance with the License. You can obtain a copy
* in the file LICENSE in the source distribution or at
* https://www.openssl.org/source/license.html
*/
#include "des_local.h"
#include <openssl/opensslv.h>
#include <openssl/bio.h>
const char *DES_options(void)
{
static int init = 1;
static char buf[12];
if (init) {
if (sizeof(DES_LONG) != sizeof(long))
OPENSSL_strlcpy(buf, "des(int)", sizeof(buf));
else
OPENSSL_strlcpy(buf, "des(long)", sizeof(buf));
init = 0;
}
return buf;
}
void DES_ecb_encrypt(const_DES_cblock *input, DES_cblock *output,
DES_key_schedule *ks, int enc)
{
register DES_LONG l;
DES_LONG ll[2];
const unsigned char *in = &(*input)[0];
unsigned char *out = &(*output)[0];
c2l(in, l);
ll[0] = l;
c2l(in, l);
ll[1] = l;
DES_encrypt1(ll, ks, enc);
l = ll[0];
l2c(l, out);
l = ll[1];
l2c(l, out);
l = ll[0] = ll[1] = 0;
}
|