| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
 100
 101
 102
 103
 104
 105
 106
 107
 108
 109
 110
 111
 112
 113
 114
 115
 116
 117
 118
 119
 120
 121
 122
 123
 124
 125
 126
 127
 128
 129
 130
 131
 132
 133
 134
 135
 136
 137
 138
 139
 140
 141
 142
 143
 144
 145
 146
 147
 148
 149
 150
 151
 152
 153
 154
 155
 156
 157
 158
 159
 160
 161
 162
 163
 164
 165
 166
 167
 168
 169
 170
 171
 172
 173
 174
 175
 176
 177
 178
 179
 180
 181
 182
 183
 184
 185
 186
 187
 188
 189
 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
 219
 220
 221
 222
 223
 224
 225
 226
 227
 228
 229
 230
 231
 232
 233
 234
 235
 236
 237
 238
 239
 240
 241
 242
 243
 244
 245
 246
 247
 248
 249
 250
 251
 252
 253
 254
 255
 256
 257
 258
 259
 260
 
 | 
<html>
<head>
 <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-a" />
 <meta http-equiv="Content-Language" content="en" />
 <meta name="description" content="SILC Secure Internet Live Conferencing" />
 <meta name="keywords" content="SILC, secure, chat, protocol, cipher, encrypt, SKE" />
 <meta content="INDEX, FOLLOW" name="ROBOTS" />
 <style type="text/css">
  <!--
  body { color: #000000; background: #f0f0f0; font-family: Helvetica, Arial, Sans-serif; }
  a:link { text-decoration: none; color: #2f488f; }
  a:visited { text-decoration: none;color: #2f488f; }
  a:active { text-decoration: none; color: #2f488f; }
  -->
 </style>
</head>
<body topmargin="0" leftmargin="0" marginheight="0" marginwidth="0">
<table border="0" cellspacing="0" cellpadding="6" width="100%">
 <tr valign="top" bgcolor="#dddddd">
  <td><small>Copyright © 2001 - 2007 SILC Project<br />
    <a href="http://silcnet.org">SILC Project Website</a></small></td>
  <td align="right"><small>
   <a href="index.html">SILC Toolkit Reference Manual</a><br />
   <a href="toolkit_index.html">Index</a></small></td>
   </small></td>
 </tr>
</table>
<table border="0" cellspacing="0" cellpadding="0" width="100%">
<tr bgcolor="#444444"><td><img src="space.gif" width="1" height="1"border="0" alt="" ></td></tr>
</table>
<table cellpadding="0" cellspacing="0" border="0">
 <tr valign="top">
  <td width="200" bgcolor="#f0f0f0">
   <img src="space.gif" width="1" height="1" border="0" alt="">
   <table width="100%" cellpadding="2" cellspacing="2" border="0">
    <tr valign="top"><td>
<br />
<small>
<!-- Template file for the big index that appears in the Toolkit reference
manual on the left side.  With this file it is possible to add other than
automatically generated links to that list. -->
<a href="index.html"><img src="box.gif" border="0" alt="">SILC Toolkit Reference Manual</a><br />
<a href=silcvcardlib.html><img src=box.gif border=0 alt=>SILC VCard Library</a><br />
    <a href=silcvcard.html><img src=box2.gif border=0 alt=>SILC VCard Interface</a><br />
<a href=silccryptlib.html><img src=box.gif border=0 alt=>SILC Crypto Library</a><br />
    <a href=silcrng_intro.html><img src=box2.gif border=0 alt=>Introduction to SILC RNG</a><br />
    <a href=silcrng.html><img src=box2.gif border=0 alt=>SILC RNG Interface</a><br />
    <a href=silccipher.html><img src=box2.gif border=0 alt=>SILC Cipher API</a><br />
    <a href=silcpkcs.html><img src=box2.gif border=0 alt=>SILC PKCS API</a><br />
    <a href=silcpk.html><img src=box2.gif border=0 alt=>SILC Public Key API</a><br />
    <a href=silcpkcs1.html><img src=box2.gif border=0 alt=>SILC PKCS #1 API</a><br />
    <a href=silchash.html><img src=box2.gif border=0 alt=>SILC Hash Interface</a><br />
    <a href=silchmac.html><img src=box2.gif border=0 alt=>SILC HMAC Interface</a><br />
<a href=silcclientlib.html><img src=box.gif border=0 alt=>SILC Client Library</a><br />
    <a href=silcclient_using.html><img src=box2.gif border=0 alt=>Using SILC Client Library Tutorial</a><br />
    <a href=command_reply_args.html><img src=box2.gif border=0 alt=>Arguments for <b>command_reply</b> Client Operation</a><br />
    <a href=silcstatus_args.html><img src=box2.gif border=0 alt=>SilcStatus Error Arguments in <b>command_reply</b> Client Operation</a><br />
    <a href=notifyargs.html><img src=box2.gif border=0 alt=>Arguments for <b>notify</b> Client Operation</a><br />
    <a href=silcclient_unicode.html><img src=box2.gif border=0 alt=>Unicode and UTF-8 Strings in Client Library</a><br />
    <a href=silcclient.html><img src=box2.gif border=0 alt=>Client Library Interface Reference</a><br />
    <a href=silcclient_entry.html><img src=box2.gif border=0 alt=>Client Entry Interface Reference</a><br />
<a href=silcmathlib.html><img src=box.gif border=0 alt=>SILC Math Library</a><br />
    <a href=silcmp.html><img src=box2.gif border=0 alt=>SILC MP Interface</a><br />
    <a href=silcmath.html><img src=box2.gif border=0 alt=>SILC Math Interface</a><br />
<a href=silcaputillib.html><img src=box.gif border=0 alt=>SILC Application Utility Library</a><br />
    <a href=silcapputil.html><img src=box2.gif border=0 alt=>SILC Application Utilities</a><br />
    <a href=silcidcache.html><img src=box2.gif border=0 alt=>SILC ID Cache Interface</a><br />
<a href=silcskrlib.html><img src=box.gif border=0 alt=>SILC Key Repository Library</a><br />
    <a href=silcskr.html><img src=box2.gif border=0 alt=>SILC SKR Interface</a><br />
<a href=silcasn1lib.html><img src=box.gif border=0 alt=>SILC ASN.1 Library</a><br />
    <a href=silcasn1.html><img src=box2.gif border=0 alt=>SILC ASN.1 Interface</a><br />
    <a href=silcber.html><img src=box2.gif border=0 alt=>SILC BER interface</a><br />
<a href=silcskelib.html><img src=box.gif border=0 alt=>SILC Key Exchange Library</a><br />
    <a href=silcske.html><img src=box2.gif border=0 alt=>SILC SKE Interface</a><br />
    <a href=silcconnauth.html><img src=box2.gif border=0 alt=>SILC Connection Authentication Interface</a><br />
<a href=silcsftplib.html><img src=box.gif border=0 alt=>SILC SFTP Library</a><br />
    <a href=silcsftp.html><img src=box2.gif border=0 alt=>SILC SFTP Interface</a><br />
    <a href=silcsftp_fs.html><img src=box2.gif border=0 alt=>SFTP Filesystems Interface</a><br />
<a href=silccorelib.html><img src=box.gif border=0 alt=>SILC Core Library</a><br />
    <a href=silcauth.html><img src=box2.gif border=0 alt=>SILC Authentication Interface</a><br />
    <a href=silcmessage.html><img src=box2.gif border=0 alt=>SILC Message Interface</a><br />
    <a href=silcchannel.html><img src=box2.gif border=0 alt=>SILC Channel Interface</a><br />
    <a href=silccommand.html><img src=box2.gif border=0 alt=>SILC Command Interface</a><br />
    <a href=silcnotify.html><img src=box2.gif border=0 alt=>SILC Notify Interface</a><br />
    <a href=silcstatus.html><img src=box2.gif border=0 alt=>SILC Status Types</a><br />
    <a href=silcmode.html><img src=box2.gif border=0 alt=>SILC Modes</a><br />
    <a href=silcid.html><img src=box2.gif border=0 alt=>SILC ID Interface</a><br />
    <a href=silcargument.html><img src=box2.gif border=0 alt=>SILC Argument Interface</a><br />
    <a href=silcattrs.html><img src=box2.gif border=0 alt=>SILC Attributes Interface</a><br />
    <a href=silcpacket.html><img src=box2.gif border=0 alt=>Packet Engine Interface</a><br />
    <a href=silcpubkey.html><img src=box2.gif border=0 alt=>SILC Public Key Payload Interface</a><br />
<a href=silcutillib.html><img src=box.gif border=0 alt=>SILC Utility Library</a><br />
    <a href=silctypes.html><img src=box2.gif border=0 alt=>Basic Types and Definitions</a><br />
    <a href=silcbuffer.html><img src=box2.gif border=0 alt=>Data Buffer Interface</a><br />
    <a href=silcbuffmt.html><img src=box2.gif border=0 alt=>Data Buffer Format Interface</a><br />
    <a href=silchashtable.html><img src=box2.gif border=0 alt=>Hash Table Interface</a><br />
    <a href=silcmemory.html><img src=box2.gif border=0 alt=>Memory Allocation Interface</a><br />
    <a href=silcstack.html><img src=box2.gif border=0 alt=>Data Stack (memory pool) Interface</a><br />
    <a href=silcfsm.html><img src=box2.gif border=0 alt=>Finite State Machine Interface</a><br />
    <a href=silcthread.html><img src=box2.gif border=0 alt=>Thread Interface</a><br />
    <a href=silcmutex.html><img src=box2.gif border=0 alt=>Mutual Exclusion Lock Interface</a><br />
    <a href=silccond.html><img src=box2.gif border=0 alt=>Condition Variable Interface</a><br />
    <a href=silcatomic.html><img src=box2.gif border=0 alt=>Atomic Operations Interface</a><br />
    <a href=silcnet.html><img src=box2.gif border=0 alt=>Network (TCP and UDP) Interface</a><br />
    <a href=silcschedule.html><img src=box2.gif border=0 alt=>Scheduler Interface</a><br />
    <a href=silcasync.html><img src=box2.gif border=0 alt=>Asynchronous Operation Interface</a><br />
    <a href=silcstream.html><img src=box2.gif border=0 alt=>Abstract Stream Interface</a><br />
    <a href=silcsocketstream.html><img src=box2.gif border=0 alt=>Socket Stream Interface</a><br />
    <a href=silcfdstream.html><img src=box2.gif border=0 alt=>File Descriptor Stream Interface</a><br />
    <a href=silcfileutil.html><img src=box2.gif border=0 alt=>File Utility Functions</a><br />
    <a href=silcstrutil.html><img src=box2.gif border=0 alt=>String Utility Interface</a><br />
    <a href=silcsnprintf.html><img src=box2.gif border=0 alt=>Snprintf Interface</a><br />
    <a href=silcutf8.html><img src=box2.gif border=0 alt=>UTF-8 String Interface</a><br />
    <a href=silcstringprep.html><img src=box2.gif border=0 alt=>Stringprep Interface</a><br />
    <a href=silcutil.html><img src=box2.gif border=0 alt=>Utility Functions</a><br />
    <a href=silclist.html><img src=box2.gif border=0 alt=>List Interface</a><br />
    <a href=silcdlist.html><img src=box2.gif border=0 alt=>Dynamic List Interface</a><br />
    <a href=silcmime.html><img src=box2.gif border=0 alt=>MIME Interface</a><br />
    <a href=silctime.html><img src=box2.gif border=0 alt=>Time Utility Functions</a><br />
    <a href=silclog.html><img src=box2.gif border=0 alt=>Logging Interface</a><br />
    <a href=silcconfig.html><img src=box2.gif border=0 alt=>Config File Interface</a><br />
<a href=silchttplib.html><img src=box.gif border=0 alt=>SILC HTTP Library</a><br />
    <a href=silchttpserver.html><img src=box2.gif border=0 alt=>SILC HTTP Server Interface</a><br />
    <a href=silchttpphp.html><img src=box2.gif border=0 alt=>SILC HTTP PHP Translator</a><br />
<br />
<b>Resource Links</b>
<br />
<a href="http://silcnet.org"><img src="box.gif" border="0" alt="">SILC Project Website</a><br />
<a href="http://silcnet.org/support/documentation/"><img src="box.gif" border="0" alt="">SILC Protocol Documentation</a><br />
<a href="http://silcnet.org/support/documentation/wp/"><img src="box.gif" border="0" alt="">SILC White Paper</a><br />
<a href="http://silcnet.org/support/faq/"><img src="box.gif" border="0" alt="">SILC FAQs</a><br />
</small>
<br /><br /><br /><br />
    </td></tr>
   </table>
  </td>
  <td bgcolor="#cccccc" background="dot.gif">
   <img src="space.gif" width="1" height="1" border="0" alt=""></td>
  <td width="720" bgcolor="#ffffff">
   <img src="space.gif" width="1" height="1" border="0" alt="">
   <table cellpadding="2" cellspacing="6" width="100%">
    <tr><td valign="top">
<br />
<FONT SIZE="+2" COLOR="#000055"><B>Function <A NAME="silc_cipher_alloc">silc_cipher_alloc</A></FONT></B><BR><BR>
<FONT SIZE="+1"><B>
<FONT COLOR="#000055">SYNOPSIS
</FONT></B></FONT>
<PRE><FONT FACE="courier" size="3">
    <A HREF="silctypes-SilcBool.html">SilcBool</A> <B>silc_cipher_alloc</B>(const unsigned char *name,
                               <A HREF="silccipher-SilcCipher.html">SilcCipher</A> *new_cipher);
</FONT></PRE><FONT SIZE="+1"><B>
<FONT COLOR="#000055">DESCRIPTION
</FONT></B></FONT>
<PRE><FONT FACE="Helvetiva,Arial,Sans-serif">
    Allocates a new SILC cipher object. Function returns 1 on succes and 0
    on error. The allocated cipher is returned in new_cipher argument. The
    caller must set the key to the cipher after this function has returned
    by calling the ciphers set_key function.
    The following ciphers are supported:
    aes-256-ctr            AES-256, Counter mode
    aes-192-ctr            AES-192, Counter mode
    aes-128-ctr            AES,128, Counter mode
    aes-256-cbc            AES-256, Cipher block chaining mode
    aes-192-cbc            AES-192, Cipher block chaining mode
    aes-128-cbc            AES,128, Cipher block chaining mode
    twofish-256-cbc        Twofish-256, Cipher block chaining mode
    twofish-192-cbc        Twofish-192, Cipher block chaining mode
    twofish-128-cbc        Twofish-128, Cipher block chaining mode
    Notes about modes:
    The CTR is normal counter mode.  The CTR mode does not require the
    plaintext length to be multiple by the cipher block size.  If the last
    plaintext block is shorter the remaining bits of the key stream are
    used next time <A HREF="silccipher-silc_cipher_encrypt.html">silc_cipher_encrypt</A> is called.  If <A HREF="silccipher-silc_cipher_set_iv.html">silc_cipher_set_iv</A>
    is called it will reset the counter for a new block (discarding any
    remaining bits from previous key stream).
    The CBC is mode is a standard CBC mode.  The plaintext length must be
    multiple by the cipher block size.  If it isn't the plaintext must be
    padded.
</FONT></PRE>
<br /><br /><br /><br />
    </td></tr>
   </table>
  </td>
  <td bgcolor="#cccccc" background="dot.gif">
   <img src="space.gif" width="1" height="1" border="0" alt=""></td>
  <td width="180" bgcolor="#f0f0f0">
    <img src="space.gif" width="1" height="1" border="0" alt="">
    <table width="100%" cellpadding="4" cellspacing="0">
    <tr valign="top"><td>
<br />
<font face="Helvetica,Arial,Sans-serif" size="1">
<A HREF="silccipher.html"><IMG SRC="index_pic.gif" BORDER="0" ALT="">SILC Cipher Interface</A><BR>
<A HREF="silccipher-SilcCipher.html"><IMG SRC="index_pic.gif" BORDER="0" ALT="">SilcCipher</A><BR>
<A HREF="silccipher-SilcCipherMode.html"><IMG SRC="index_pic.gif" BORDER="0" ALT="">SilcCipherMode</A><BR>
<A HREF="silccipher-silc_cipher_register.html"><IMG SRC="index_pic.gif" BORDER="0" ALT="">silc_cipher_register</A><BR>
<A HREF="silccipher-silc_cipher_unregister.html"><IMG SRC="index_pic.gif" BORDER="0" ALT="">silc_cipher_unregister</A><BR>
<A HREF="silccipher-silc_cipher_register_default.html"><IMG SRC="index_pic.gif" BORDER="0" ALT="">silc_cipher_register_default</A><BR>
<A HREF="silccipher-silc_cipher_unregister_all.html"><IMG SRC="index_pic.gif" BORDER="0" ALT="">silc_cipher_unregister_all</A><BR>
<A HREF="silccipher-silc_cipher_alloc.html"><IMG SRC="index_pic.gif" BORDER="0" ALT="">silc_cipher_alloc</A><BR>
<A HREF="silccipher-silc_cipher_free.html"><IMG SRC="index_pic.gif" BORDER="0" ALT="">silc_cipher_free</A><BR>
<A HREF="silccipher-silc_cipher_is_supported.html"><IMG SRC="index_pic.gif" BORDER="0" ALT="">silc_cipher_is_supported</A><BR>
<A HREF="silccipher-silc_cipher_get_supported.html"><IMG SRC="index_pic.gif" BORDER="0" ALT="">silc_cipher_get_supported</A><BR>
<A HREF="silccipher-silc_cipher_encrypt.html"><IMG SRC="index_pic.gif" BORDER="0" ALT="">silc_cipher_encrypt</A><BR>
<A HREF="silccipher-silc_cipher_decrypt.html"><IMG SRC="index_pic.gif" BORDER="0" ALT="">silc_cipher_decrypt</A><BR>
<A HREF="silccipher-silc_cipher_set_key.html"><IMG SRC="index_pic.gif" BORDER="0" ALT="">silc_cipher_set_key</A><BR>
<A HREF="silccipher-silc_cipher_set_iv.html"><IMG SRC="index_pic.gif" BORDER="0" ALT="">silc_cipher_set_iv</A><BR>
<A HREF="silccipher-silc_cipher_get_iv.html"><IMG SRC="index_pic.gif" BORDER="0" ALT="">silc_cipher_get_iv</A><BR>
<A HREF="silccipher-silc_cipher_get_key_len.html"><IMG SRC="index_pic.gif" BORDER="0" ALT="">silc_cipher_get_key_len</A><BR>
<A HREF="silccipher-silc_cipher_get_block_len.html"><IMG SRC="index_pic.gif" BORDER="0" ALT="">silc_cipher_get_block_len</A><BR>
<A HREF="silccipher-silc_cipher_get_iv_len.html"><IMG SRC="index_pic.gif" BORDER="0" ALT="">silc_cipher_get_iv_len</A><BR>
<A HREF="silccipher-silc_cipher_get_name.html"><IMG SRC="index_pic.gif" BORDER="0" ALT="">silc_cipher_get_name</A><BR>
<A HREF="silccipher-silc_cipher_get_mode.html"><IMG SRC="index_pic.gif" BORDER="0" ALT="">silc_cipher_get_mode</A><BR>
</font>
<br /><br /><br /><br />
    </td></tr>
    </table>
  </td>
</tr>
</table>
<table border="0" cellspacing="0" cellpadding="0" width="100%">
<tr bgcolor="#444444"><td><img src="space.gif" width="1" height="1"border="0" alt="" ></td></tr>
</table>
<table border="0" cellspacing="0" cellpadding="6" width="100%">
 <tr valign="top" bgcolor="#dddddd">
  <td><small>Copyright © 2001 - 2007 SILC Project<br />
    <a href="http://silcnet.org">SILC Project Website</a></small></td>
  <td align="right"><small>
   <a href="index.html">SILC Toolkit Reference Manual</a><br />
   <a href="toolkit_index.html">Index</a></small></td>
   </small></td>
 </tr>
</table>
</body>
</html>
 |