1 /* XTS: as defined in IEEE1619/D16
 
   2  *      http://grouper.ieee.org/groups/1619/email/pdf00086.pdf
 
   3  *      (sector sizes which are not a multiple of 16 bytes are,
 
   4  *      however currently unsupported)
 
   6  * Copyright (c) 2007 Rik Snel <rsnel@cube.dyndns.org>
 
   9  * Copyright (c) 2006 Herbert Xu <herbert@gondor.apana.org.au>
 
  11  * This program is free software; you can redistribute it and/or modify it
 
  12  * under the terms of the GNU General Public License as published by the Free
 
  13  * Software Foundation; either version 2 of the License, or (at your option)
 
  16 #include <crypto/algapi.h>
 
  17 #include <linux/err.h>
 
  18 #include <linux/init.h>
 
  19 #include <linux/kernel.h>
 
  20 #include <linux/module.h>
 
  21 #include <linux/scatterlist.h>
 
  22 #include <linux/slab.h>
 
  24 #include <crypto/b128ops.h>
 
  25 #include <crypto/gf128mul.h>
 
  28         struct crypto_cipher *child;
 
  29         struct crypto_cipher *tweak;
 
  32 static int setkey(struct crypto_tfm *parent, const u8 *key,
 
  35         struct priv *ctx = crypto_tfm_ctx(parent);
 
  36         struct crypto_cipher *child = ctx->tweak;
 
  37         u32 *flags = &parent->crt_flags;
 
  40         /* key consists of keys of equal size concatenated, therefore
 
  41          * the length must be even */
 
  43                 /* tell the user why there was an error */
 
  44                 *flags |= CRYPTO_TFM_RES_BAD_KEY_LEN;
 
  48         /* we need two cipher instances: one to compute the inital 'tweak'
 
  49          * by encrypting the IV (usually the 'plain' iv) and the other
 
  50          * one to encrypt and decrypt the data */
 
  52         /* tweak cipher, uses Key2 i.e. the second half of *key */
 
  53         crypto_cipher_clear_flags(child, CRYPTO_TFM_REQ_MASK);
 
  54         crypto_cipher_set_flags(child, crypto_tfm_get_flags(parent) &
 
  56         err = crypto_cipher_setkey(child, key + keylen/2, keylen/2);
 
  60         crypto_tfm_set_flags(parent, crypto_cipher_get_flags(child) &
 
  65         /* data cipher, uses Key1 i.e. the first half of *key */
 
  66         crypto_cipher_clear_flags(child, CRYPTO_TFM_REQ_MASK);
 
  67         crypto_cipher_set_flags(child, crypto_tfm_get_flags(parent) &
 
  69         err = crypto_cipher_setkey(child, key, keylen/2);
 
  73         crypto_tfm_set_flags(parent, crypto_cipher_get_flags(child) &
 
  81         struct crypto_tfm *tfm;
 
  82         void (*fn)(struct crypto_tfm *, u8 *, const u8 *);
 
  85 static inline void xts_round(struct sinfo *s, void *dst, const void *src)
 
  87         be128_xor(dst, &s->t, src);             /* PP <- T xor P */
 
  88         s->fn(s->tfm, dst, dst);                /* CC <- E(Key1,PP) */
 
  89         be128_xor(dst, dst, &s->t);             /* C <- T xor CC */
 
  92 static int crypt(struct blkcipher_desc *d,
 
  93                  struct blkcipher_walk *w, struct priv *ctx,
 
  94                  void (*tw)(struct crypto_tfm *, u8 *, const u8 *),
 
  95                  void (*fn)(struct crypto_tfm *, u8 *, const u8 *))
 
  99         const int bs = crypto_cipher_blocksize(ctx->child);
 
 101                 .tfm = crypto_cipher_tfm(ctx->child),
 
 108         err = blkcipher_walk_virt(d, w);
 
 114         wsrc = w->src.virt.addr;
 
 115         wdst = w->dst.virt.addr;
 
 117         /* calculate first value of T */
 
 119         tw(crypto_cipher_tfm(ctx->tweak), (void *)&s.t, w->iv);
 
 125                         gf128mul_x_ble(&s.t, &s.t);
 
 128                         xts_round(&s, wdst, wsrc);
 
 132                 } while ((avail -= bs) >= bs);
 
 134                 err = blkcipher_walk_done(d, w, avail);
 
 140                 wsrc = w->src.virt.addr;
 
 141                 wdst = w->dst.virt.addr;
 
 147 static int encrypt(struct blkcipher_desc *desc, struct scatterlist *dst,
 
 148                    struct scatterlist *src, unsigned int nbytes)
 
 150         struct priv *ctx = crypto_blkcipher_ctx(desc->tfm);
 
 151         struct blkcipher_walk w;
 
 153         blkcipher_walk_init(&w, dst, src, nbytes);
 
 154         return crypt(desc, &w, ctx, crypto_cipher_alg(ctx->tweak)->cia_encrypt,
 
 155                      crypto_cipher_alg(ctx->child)->cia_encrypt);
 
 158 static int decrypt(struct blkcipher_desc *desc, struct scatterlist *dst,
 
 159                    struct scatterlist *src, unsigned int nbytes)
 
 161         struct priv *ctx = crypto_blkcipher_ctx(desc->tfm);
 
 162         struct blkcipher_walk w;
 
 164         blkcipher_walk_init(&w, dst, src, nbytes);
 
 165         return crypt(desc, &w, ctx, crypto_cipher_alg(ctx->tweak)->cia_encrypt,
 
 166                      crypto_cipher_alg(ctx->child)->cia_decrypt);
 
 169 static int init_tfm(struct crypto_tfm *tfm)
 
 171         struct crypto_cipher *cipher;
 
 172         struct crypto_instance *inst = (void *)tfm->__crt_alg;
 
 173         struct crypto_spawn *spawn = crypto_instance_ctx(inst);
 
 174         struct priv *ctx = crypto_tfm_ctx(tfm);
 
 175         u32 *flags = &tfm->crt_flags;
 
 177         cipher = crypto_spawn_cipher(spawn);
 
 179                 return PTR_ERR(cipher);
 
 181         if (crypto_cipher_blocksize(cipher) != 16) {
 
 182                 *flags |= CRYPTO_TFM_RES_BAD_BLOCK_LEN;
 
 183                 crypto_free_cipher(cipher);
 
 189         cipher = crypto_spawn_cipher(spawn);
 
 190         if (IS_ERR(cipher)) {
 
 191                 crypto_free_cipher(ctx->child);
 
 192                 return PTR_ERR(cipher);
 
 195         /* this check isn't really needed, leave it here just in case */
 
 196         if (crypto_cipher_blocksize(cipher) != 16) {
 
 197                 crypto_free_cipher(cipher);
 
 198                 crypto_free_cipher(ctx->child);
 
 199                 *flags |= CRYPTO_TFM_RES_BAD_BLOCK_LEN;
 
 208 static void exit_tfm(struct crypto_tfm *tfm)
 
 210         struct priv *ctx = crypto_tfm_ctx(tfm);
 
 211         crypto_free_cipher(ctx->child);
 
 212         crypto_free_cipher(ctx->tweak);
 
 215 static struct crypto_instance *alloc(struct rtattr **tb)
 
 217         struct crypto_instance *inst;
 
 218         struct crypto_alg *alg;
 
 221         err = crypto_check_attr_type(tb, CRYPTO_ALG_TYPE_BLKCIPHER);
 
 225         alg = crypto_get_attr_alg(tb, CRYPTO_ALG_TYPE_CIPHER,
 
 226                                   CRYPTO_ALG_TYPE_MASK);
 
 228                 return ERR_PTR(PTR_ERR(alg));
 
 230         inst = crypto_alloc_instance("xts", alg);
 
 234         inst->alg.cra_flags = CRYPTO_ALG_TYPE_BLKCIPHER;
 
 235         inst->alg.cra_priority = alg->cra_priority;
 
 236         inst->alg.cra_blocksize = alg->cra_blocksize;
 
 238         if (alg->cra_alignmask < 7)
 
 239                 inst->alg.cra_alignmask = 7;
 
 241                 inst->alg.cra_alignmask = alg->cra_alignmask;
 
 243         inst->alg.cra_type = &crypto_blkcipher_type;
 
 245         inst->alg.cra_blkcipher.ivsize = alg->cra_blocksize;
 
 246         inst->alg.cra_blkcipher.min_keysize =
 
 247                 2 * alg->cra_cipher.cia_min_keysize;
 
 248         inst->alg.cra_blkcipher.max_keysize =
 
 249                 2 * alg->cra_cipher.cia_max_keysize;
 
 251         inst->alg.cra_ctxsize = sizeof(struct priv);
 
 253         inst->alg.cra_init = init_tfm;
 
 254         inst->alg.cra_exit = exit_tfm;
 
 256         inst->alg.cra_blkcipher.setkey = setkey;
 
 257         inst->alg.cra_blkcipher.encrypt = encrypt;
 
 258         inst->alg.cra_blkcipher.decrypt = decrypt;
 
 265 static void free(struct crypto_instance *inst)
 
 267         crypto_drop_spawn(crypto_instance_ctx(inst));
 
 271 static struct crypto_template crypto_tmpl = {
 
 275         .module = THIS_MODULE,
 
 278 static int __init crypto_module_init(void)
 
 280         return crypto_register_template(&crypto_tmpl);
 
 283 static void __exit crypto_module_exit(void)
 
 285         crypto_unregister_template(&crypto_tmpl);
 
 288 module_init(crypto_module_init);
 
 289 module_exit(crypto_module_exit);
 
 291 MODULE_LICENSE("GPL");
 
 292 MODULE_DESCRIPTION("XTS block cipher mode");