1 /*---------------------------------------------------------------------------* 2 Project: Horizon 3 File: crypto_CcmDecryptor.h 4 5 Copyright (C)2009-2012 Nintendo Co., Ltd. All rights reserved. 6 7 These coded instructions, statements, and computer programs contain 8 proprietary information of Nintendo of America Inc. and/or Nintendo 9 Company Ltd., and are protected by Federal copyright law. They may 10 not be disclosed to third parties or copied or duplicated in any form, 11 in whole or in part, without the prior written consent of Nintendo. 12 13 $Rev: 46347 $ 14 *---------------------------------------------------------------------------*/ 15 16 #ifndef NN_CRYPTO_CRYPTO_CCMDECRYPTOR_H_ 17 #define NN_CRYPTO_CRYPTO_CCMDECRYPTOR_H_ 18 19 20 #include <nn/crypto/crypto_AuthenticatedDecryptor.h> 21 #include <nn/crypto/detail/crypto_CcmMode.h> 22 23 24 namespace nn { 25 namespace crypto { 26 27 28 29 /* Please see man pages for details 30 31 32 33 34 35 36 37 38 39 40 */ 41 class CcmDecryptor : public AuthenticatedDecryptor 42 { 43 private: 44 typedef detail::CcmMode ImplT; 45 46 public: 47 // 48 // 49 // 50 static const size_t BLOCK_SIZE = ImplT::BLOCK_SIZE; 51 52 // 53 // 54 // 55 static const size_t IV_SIZE = ImplT::MAX_IV_SIZE; 56 57 // 58 // 59 // 60 static const size_t UNIT_SIZE = ImplT::UNIT_SIZE; 61 62 // 63 // 64 // 65 static const size_t MAC_SIZE = ImplT::MAX_MAC_SIZE; 66 67 public: CcmDecryptor()68 CcmDecryptor(){} ~CcmDecryptor()69 virtual ~CcmDecryptor(){} 70 71 /* Please see man pages for details 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 */ Initialize(const BlockCipher & c,const void * pIv,size_t ivSize,size_t adataSize,size_t cdataSize,size_t macSize)90 void Initialize(const BlockCipher& c, const void* pIv, size_t ivSize, 91 size_t adataSize, size_t cdataSize, size_t macSize) 92 { return m_Impl.Initialize(c, pIv, ivSize, adataSize, cdataSize, macSize); } 93 94 /* Please see man pages for details 95 96 97 98 */ Finalize()99 virtual void Finalize() 100 { return m_Impl.Finalize(); } 101 102 /* Please see man pages for details 103 104 105 106 107 108 */ GetIvSize()109 virtual size_t GetIvSize() const { return ImplT::GetIvSize(); } 110 111 /* Please see man pages for details 112 113 114 115 116 117 */ GetUnitSize()118 virtual size_t GetUnitSize() const { return ImplT::GetUnitSize(); } 119 120 /* Please see man pages for details 121 122 123 124 125 126 */ GetMacSize()127 virtual size_t GetMacSize() const { return ImplT::GetMacSize(); } 128 129 130 131 /* Please see man pages for details 132 133 134 135 136 137 138 */ UpdateAdata(const void * pSrc,size_t size)139 virtual void UpdateAdata(const void* pSrc, size_t size) 140 { return m_Impl.UpdateAdata(pSrc, size); } 141 142 /* Please see man pages for details 143 144 145 146 */ UpdateAdataFinal()147 virtual void UpdateAdataFinal() 148 { return m_Impl.UpdateAdataFinal(); } 149 150 /* Please see man pages for details 151 152 153 154 155 156 157 158 159 160 */ UpdateCdata(void * pDst,size_t dstSize,const void * pSrc,size_t srcSize)161 virtual size_t UpdateCdata(void* pDst, size_t dstSize, const void* pSrc, size_t srcSize) 162 { return m_Impl.UpdateCdata(pDst, dstSize, pSrc, srcSize); } 163 164 /* Please see man pages for details 165 166 167 168 169 170 171 172 */ UpdateCdataFinal(void * pDst,size_t size)173 virtual size_t UpdateCdataFinal(void* pDst, size_t size) 174 { return m_Impl.UpdateCdataFinal(pDst, size); } 175 176 /* Please see man pages for details 177 178 179 180 181 182 183 */ GenerateMac(void * pDst,size_t size)184 virtual void GenerateMac(void* pDst, size_t size) 185 { return m_Impl.GenerateMac(pDst, size); } 186 187 188 189 /* Please see man pages for details 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 */ DecryptAndVerify(void * pDst,size_t dstSize,const void * pAdata,size_t adataSize,const void * pCdata,size_t cdataSize,const void * pIv,size_t ivSize,const void * pMac,size_t macSize,const BlockCipher & c)219 static bool DecryptAndVerify( 220 void* pDst, size_t dstSize, const void* pAdata, size_t adataSize, 221 const void* pCdata, size_t cdataSize, const void* pIv, size_t ivSize, 222 const void* pMac, size_t macSize, const BlockCipher& c) 223 { 224 CcmDecryptor e; 225 e.Initialize(c, pIv, ivSize, adataSize, cdataSize, macSize); 226 bool ret = e.AuthenticatedDecryptor::DecryptAndVerify( 227 pDst, dstSize, pAdata, adataSize, 228 pCdata, cdataSize, pMac, macSize); 229 e.Finalize(); 230 return ret; 231 } 232 233 private: 234 ImplT m_Impl; 235 }; 236 237 238 239 } // namespace crypto 240 } // namespace nn 241 242 243 244 #endif /* NN_CRYPTO_CRYPTO_CCMDECRYPTOR_H_ */ 245