*/
-#include "silc.h"
+#include "silccrypto.h"
#include "cast_internal.h"
#include "cast.h"
/* Sets the key for the cipher. */
-SILC_CIPHER_API_SET_KEY(cast)
+SILC_CIPHER_API_SET_KEY(cast_cbc)
{
SilcUInt32 k[8];
return TRUE;
}
-/* Returns the size of the cipher context. */
+/* Sets IV for the cipher. */
-SILC_CIPHER_API_CONTEXT_LEN(cast)
+SILC_CIPHER_API_SET_IV(cast_cbc)
{
- return sizeof(CastContext);
+
+}
+
+/* Initialize */
+
+SILC_CIPHER_API_INIT(cast_cbc)
+{
+ return silc_calloc(1, sizeof(CastContext));
+}
+
+/* Uninitialize */
+
+SILC_CIPHER_API_UNINIT(cast_cbc)
+{
+ CastContext *cast = context;
+ memset(cast, 0, sizeof(*cast));
+ silc_free(cast);
}
/* Encrypts with the cipher in CBC mode. Source and destination buffers
maybe one and same. */
-SILC_CIPHER_API_ENCRYPT_CBC(cast)
+SILC_CIPHER_API_ENCRYPT(cast_cbc)
{
SilcUInt32 tiv[4];
int i;
+ SILC_ASSERT((len & (16 - 1)) == 0);
+ if (len & (16 - 1))
+ return FALSE;
+
SILC_CBC_GET_IV(tiv, iv);
SILC_CBC_ENC_PRE(tiv, src);
/* Decrypts with the cipher in CBC mode. Source and destination buffers
maybe one and same. */
-SILC_CIPHER_API_DECRYPT_CBC(cast)
+SILC_CIPHER_API_DECRYPT(cast_cbc)
{
SilcUInt32 tmp[4], tmp2[4], tiv[4];
int i;
+ if (len & (16 - 1))
+ return FALSE;
+
SILC_CBC_GET_IV(tiv, iv);
SILC_CBC_DEC_PRE(tmp, src);