1. 08 8月, 2016 2 次提交
    • H
      crypto: caam - defer aead_set_sh_desc in case of zero authsize · 2fdea258
      Horia Geantă 提交于
      To be able to generate shared descriptors for AEAD, the authentication size
      needs to be known. However, there is no imposed order of calling .setkey,
      .setauthsize callbacks.
      
      Thus, in case authentication size is not known at .setkey time, defer it
      until .setauthsize is called.
      
      The authsize != 0 check was incorrectly removed when converting the driver
      to the new AEAD interface.
      
      Cc: <stable@vger.kernel.org> # 4.3+
      Fixes: 479bcc7c ("crypto: caam - Convert authenc to new AEAD interface")
      Signed-off-by: NHoria Geantă <horia.geanta@nxp.com>
      Signed-off-by: NHerbert Xu <herbert@gondor.apana.org.au>
      2fdea258
    • H
      crypto: caam - fix echainiv(authenc) encrypt shared descriptor · 1d2d87e8
      Horia Geantă 提交于
      There are a few things missed by the conversion to the
      new AEAD interface:
      
      1 - echainiv(authenc) encrypt shared descriptor
      
      The shared descriptor is incorrect: due to the order of operations,
      at some point in time MATH3 register is being overwritten.
      
      2 - buffer used for echainiv(authenc) encrypt shared descriptor
      
      Encrypt and givencrypt shared descriptors (for AEAD ops) are mutually
      exclusive and thus use the same buffer in context state: sh_desc_enc.
      
      However, there's one place missed by s/sh_desc_givenc/sh_desc_enc,
      leading to errors when echainiv(authenc(...)) algorithms are used:
      DECO: desc idx 14: Header Error. Invalid length or parity, or
      certain other problems.
      
      While here, also fix a typo: dma_mapping_error() is checking
      for validity of sh_desc_givenc_dma instead of sh_desc_enc_dma.
      
      Cc: <stable@vger.kernel.org> # 4.3+
      Fixes: 479bcc7c ("crypto: caam - Convert authenc to new AEAD interface")
      Signed-off-by: NHoria Geantă <horia.geanta@nxp.com>
      Signed-off-by: NHerbert Xu <herbert@gondor.apana.org.au>
      1d2d87e8
  2. 08 10月, 2015 1 次提交
  3. 01 10月, 2015 1 次提交
  4. 24 8月, 2015 1 次提交
  5. 17 8月, 2015 1 次提交
  6. 10 8月, 2015 2 次提交
  7. 04 8月, 2015 1 次提交
  8. 31 7月, 2015 1 次提交
  9. 14 7月, 2015 1 次提交
  10. 19 6月, 2015 2 次提交
  11. 17 6月, 2015 1 次提交
    • H
      crypto: caam - Convert GCM to new AEAD interface · f2147b88
      Herbert Xu 提交于
      This patch converts the caam GCM implementations to the new AEAD
      interface.  This is compile-tested only.
      
      Note that all IV generation for GCM algorithms have been removed.
      The reason is that the current generation uses purely random IVs
      which is not appropriate for counter-based algorithms where we
      first and foremost require uniqueness.
      
      Of course there is no reason why you couldn't implement seqiv or
      seqniv within caam since all they do is xor the sequence number
      with a salt, but since I can't test this on actual hardware I'll
      leave it alone for now.
      Signed-off-by: NHerbert Xu <herbert@gondor.apana.org.au>
      f2147b88
  12. 09 6月, 2015 1 次提交
    • H
      crypto: caam - Clamp AEAD SG list by input length · 70c3c8a9
      Herbert Xu 提交于
      Currently caam assumes that the SG list contains exactly the number
      of bytes required.  This assumption is incorrect.
      
      Up until now this has been harmless.  However with the new AEAD
      interface this now breaks as the AD SG list contains more bytes
      than just the AD.
      
      This patch fixes this by always clamping the AD SG list by the
      specified AD length.
      Signed-off-by: NHerbert Xu <herbert@gondor.apana.org.au>
      70c3c8a9
  13. 22 5月, 2015 1 次提交
  14. 13 5月, 2015 1 次提交
  15. 23 4月, 2015 1 次提交
  16. 26 1月, 2015 1 次提交
  17. 12 11月, 2014 1 次提交
  18. 06 11月, 2014 6 次提交
  19. 24 10月, 2014 2 次提交
  20. 23 7月, 2014 3 次提交
  21. 10 7月, 2014 1 次提交
  22. 25 6月, 2014 1 次提交
  23. 13 5月, 2014 1 次提交
  24. 08 5月, 2014 1 次提交
  25. 21 3月, 2014 3 次提交
  26. 20 12月, 2013 1 次提交
  27. 28 11月, 2013 1 次提交
    • H
      crypto: caam - fix aead sglen for case 'dst != src' · bbf9c893
      Horia Geanta 提交于
      For aead case when source and destination buffers are different,
      there is an incorrect assumption that the source length includes the ICV
      length. Fix this, since it leads to an oops when using sg_count() to
      find the number of nents in the scatterlist:
      
      Unable to handle kernel paging request for data at address 0x00000004
      Faulting instruction address: 0xf91f7634
      Oops: Kernel access of bad area, sig: 11 [#1]
      SMP NR_CPUS=8 P4080 DS
      Modules linked in: caamalg(+) caam_jr caam
      CPU: 1 PID: 1053 Comm: cryptomgr_test Not tainted 3.11.0 #16
      task: eeb24ab0 ti: eeafa000 task.ti: eeafa000
      NIP: f91f7634 LR: f91f7f24 CTR: f91f7ef0
      REGS: eeafbbc0 TRAP: 0300   Not tainted  (3.11.0)
      MSR: 00029002 <CE,EE,ME>  CR: 44044044  XER: 00000000
      DEAR: 00000004, ESR: 00000000
      
      GPR00: f91f7f24 eeafbc70 eeb24ab0 00000002 ee8e0900 ee8e0800 00000024 c45c4462
      GPR08: 00000010 00000000 00000014 0c0e4000 24044044 00000000 00000000 c0691590
      GPR16: eeab0000 eeb23000 00000000 00000000 00000000 00000001 00000001 eeafbcc8
      GPR24: 000000d1 00000010 ee2d5000 ee49ea10 ee49ea10 ee46f640 ee46f640 c0691590
      NIP [f91f7634] aead_edesc_alloc.constprop.14+0x144/0x780 [caamalg]
      LR [f91f7f24] aead_encrypt+0x34/0x288 [caamalg]
      Call Trace:
      [eeafbc70] [a1004000] 0xa1004000 (unreliable)
      [eeafbcc0] [f91f7f24] aead_encrypt+0x34/0x288 [caamalg]
      [eeafbcf0] [c020d77c] __test_aead+0x3ec/0xe20
      [eeafbe20] [c020f35c] test_aead+0x6c/0xe0
      [eeafbe40] [c020f420] alg_test_aead+0x50/0xd0
      [eeafbe60] [c020e5e4] alg_test+0x114/0x2e0
      [eeafbee0] [c020bd1c] cryptomgr_test+0x4c/0x60
      [eeafbef0] [c0047058] kthread+0xa8/0xb0
      [eeafbf40] [c000eb0c] ret_from_kernel_thread+0x5c/0x64
      Instruction dump:
      69084321 7d080034 5508d97e 69080001 0f080000 81290024 552807fe 0f080000
      3a600001 5529003a 2f8a0000 40dd0028 <80e90004> 3ab50001 8109000c 70e30002
      ---[ end trace b3c3e23925c7484e ]---
      
      While here, add a tcrypt mode for making it easy to test authenc
      (needed for triggering case above).
      Signed-off-by: NHoria Geanta <horia.geanta@freescale.com>
      Signed-off-by: NHerbert Xu <herbert@gondor.apana.org.au>
      bbf9c893