2 * QEMU Crypto block IV generator - plain
4 * Copyright (c) 2015-2016 Red Hat, Inc.
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, see <http://www.gnu.org/licenses/>.
21 #include "qemu/osdep.h"
22 #include "qapi/error.h"
23 #include "qemu/bswap.h"
24 #include "crypto/ivgen-plain.h"
26 static int qcrypto_ivgen_plain_init(QCryptoIVGen
*ivgen
,
27 const uint8_t *key
, size_t nkey
,
33 static int qcrypto_ivgen_plain_calculate(QCryptoIVGen
*ivgen
,
35 uint8_t *iv
, size_t niv
,
39 uint32_t shortsector
= cpu_to_le32((sector
& 0xffffffff));
40 ivprefix
= sizeof(shortsector
);
44 memcpy(iv
, &shortsector
, ivprefix
);
46 memset(iv
+ ivprefix
, 0, niv
- ivprefix
);
51 static void qcrypto_ivgen_plain_cleanup(QCryptoIVGen
*ivgen
)
56 struct QCryptoIVGenDriver qcrypto_ivgen_plain
= {
57 .init
= qcrypto_ivgen_plain_init
,
58 .calculate
= qcrypto_ivgen_plain_calculate
,
59 .cleanup
= qcrypto_ivgen_plain_cleanup
,