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