2 * Copyright (c) 2010 Your File System Inc. All rights reserved.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
13 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR `AS IS'' AND ANY EXPRESS OR
14 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
15 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
16 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
17 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
18 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
19 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
20 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
21 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
22 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 _afscrypto_calloc(int num
, size_t len
)
34 ptr
= afs_osi_Alloc(total
);
35 /* In practice, callers assume the afs_osi_Alloc() will not fail. */
37 memset(ptr
, 0, total
);
43 _afscrypto_malloc(size_t len
)
47 ptr
= afs_osi_Alloc(len
);
53 _afscrypto_free(void *ptr
)
60 _afscrypto_strdup(const char *str
) {
63 ptr
= malloc(strlen(str
) + 1);
66 memcpy(ptr
, str
, strlen(str
) + 1);
71 /* This is a horrible, horrible bodge, but the crypto code uses realloc,
72 * so we need to handle it too.
74 * There are two different call sites for realloc. Firstly, it's used
75 * in the decrypt case to shrink the size of the allotted buffer. In
76 * this case, we can just ignore the realloc and return the original
79 * Secondly, it's used when computing derived keys. In this case, the
80 * first call will be with a NULL input, and the size of a single
81 * derived key. So, we just give back space for 20 keys, and pray.
85 _afscrypto_realloc(void *ptr
, size_t len
) {
87 return calloc(20, len
);