diff options
Diffstat (limited to 'drivers/md')
-rw-r--r-- | drivers/md/dm-crypt.c | 34 |
1 files changed, 30 insertions, 4 deletions
diff --git a/drivers/md/dm-crypt.c b/drivers/md/dm-crypt.c index 446153a071d6..91e1bf91769f 100644 --- a/drivers/md/dm-crypt.c +++ b/drivers/md/dm-crypt.c | |||
@@ -1,7 +1,7 @@ | |||
1 | /* | 1 | /* |
2 | * Copyright (C) 2003 Christophe Saout <christophe@saout.de> | 2 | * Copyright (C) 2003 Christophe Saout <christophe@saout.de> |
3 | * Copyright (C) 2004 Clemens Fruhwirth <clemens@endorphin.org> | 3 | * Copyright (C) 2004 Clemens Fruhwirth <clemens@endorphin.org> |
4 | * Copyright (C) 2006-2008 Red Hat, Inc. All rights reserved. | 4 | * Copyright (C) 2006-2009 Red Hat, Inc. All rights reserved. |
5 | * | 5 | * |
6 | * This file is released under the GPL. | 6 | * This file is released under the GPL. |
7 | */ | 7 | */ |
@@ -72,6 +72,7 @@ struct crypt_iv_operations { | |||
72 | const char *opts); | 72 | const char *opts); |
73 | void (*dtr)(struct crypt_config *cc); | 73 | void (*dtr)(struct crypt_config *cc); |
74 | int (*init)(struct crypt_config *cc); | 74 | int (*init)(struct crypt_config *cc); |
75 | int (*wipe)(struct crypt_config *cc); | ||
75 | int (*generator)(struct crypt_config *cc, u8 *iv, sector_t sector); | 76 | int (*generator)(struct crypt_config *cc, u8 *iv, sector_t sector); |
76 | }; | 77 | }; |
77 | 78 | ||
@@ -199,6 +200,17 @@ static int crypt_iv_essiv_init(struct crypt_config *cc) | |||
199 | crypto_hash_digestsize(essiv->hash_tfm)); | 200 | crypto_hash_digestsize(essiv->hash_tfm)); |
200 | } | 201 | } |
201 | 202 | ||
203 | /* Wipe salt and reset key derived from volume key */ | ||
204 | static int crypt_iv_essiv_wipe(struct crypt_config *cc) | ||
205 | { | ||
206 | struct iv_essiv_private *essiv = &cc->iv_gen_private.essiv; | ||
207 | unsigned salt_size = crypto_hash_digestsize(essiv->hash_tfm); | ||
208 | |||
209 | memset(essiv->salt, 0, salt_size); | ||
210 | |||
211 | return crypto_cipher_setkey(essiv->tfm, essiv->salt, salt_size); | ||
212 | } | ||
213 | |||
202 | static void crypt_iv_essiv_dtr(struct crypt_config *cc) | 214 | static void crypt_iv_essiv_dtr(struct crypt_config *cc) |
203 | { | 215 | { |
204 | struct iv_essiv_private *essiv = &cc->iv_gen_private.essiv; | 216 | struct iv_essiv_private *essiv = &cc->iv_gen_private.essiv; |
@@ -334,6 +346,7 @@ static struct crypt_iv_operations crypt_iv_essiv_ops = { | |||
334 | .ctr = crypt_iv_essiv_ctr, | 346 | .ctr = crypt_iv_essiv_ctr, |
335 | .dtr = crypt_iv_essiv_dtr, | 347 | .dtr = crypt_iv_essiv_dtr, |
336 | .init = crypt_iv_essiv_init, | 348 | .init = crypt_iv_essiv_init, |
349 | .wipe = crypt_iv_essiv_wipe, | ||
337 | .generator = crypt_iv_essiv_gen | 350 | .generator = crypt_iv_essiv_gen |
338 | }; | 351 | }; |
339 | 352 | ||
@@ -1305,6 +1318,7 @@ static void crypt_resume(struct dm_target *ti) | |||
1305 | static int crypt_message(struct dm_target *ti, unsigned argc, char **argv) | 1318 | static int crypt_message(struct dm_target *ti, unsigned argc, char **argv) |
1306 | { | 1319 | { |
1307 | struct crypt_config *cc = ti->private; | 1320 | struct crypt_config *cc = ti->private; |
1321 | int ret = -EINVAL; | ||
1308 | 1322 | ||
1309 | if (argc < 2) | 1323 | if (argc < 2) |
1310 | goto error; | 1324 | goto error; |
@@ -1314,10 +1328,22 @@ static int crypt_message(struct dm_target *ti, unsigned argc, char **argv) | |||
1314 | DMWARN("not suspended during key manipulation."); | 1328 | DMWARN("not suspended during key manipulation."); |
1315 | return -EINVAL; | 1329 | return -EINVAL; |
1316 | } | 1330 | } |
1317 | if (argc == 3 && !strnicmp(argv[1], MESG_STR("set"))) | 1331 | if (argc == 3 && !strnicmp(argv[1], MESG_STR("set"))) { |
1318 | return crypt_set_key(cc, argv[2]); | 1332 | ret = crypt_set_key(cc, argv[2]); |
1319 | if (argc == 2 && !strnicmp(argv[1], MESG_STR("wipe"))) | 1333 | if (ret) |
1334 | return ret; | ||
1335 | if (cc->iv_gen_ops && cc->iv_gen_ops->init) | ||
1336 | ret = cc->iv_gen_ops->init(cc); | ||
1337 | return ret; | ||
1338 | } | ||
1339 | if (argc == 2 && !strnicmp(argv[1], MESG_STR("wipe"))) { | ||
1340 | if (cc->iv_gen_ops && cc->iv_gen_ops->wipe) { | ||
1341 | ret = cc->iv_gen_ops->wipe(cc); | ||
1342 | if (ret) | ||
1343 | return ret; | ||
1344 | } | ||
1320 | return crypt_wipe_key(cc); | 1345 | return crypt_wipe_key(cc); |
1346 | } | ||
1321 | } | 1347 | } |
1322 | 1348 | ||
1323 | error: | 1349 | error: |