xref: /titanic_44/usr/src/cmd/ssh/libssh/common/xmalloc.c (revision 7aec1d6e253b21f9e9b7ef68b4d81ab9859b51fe)
1 /*
2  * Author: Tatu Ylonen <ylo@cs.hut.fi>
3  * Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
4  *                    All rights reserved
5  * Versions of malloc and friends that check their results, and never return
6  * failure (they call fatal if they encounter an error).
7  *
8  * As far as I am concerned, the code I have written for this software
9  * can be used freely for any purpose.  Any derived versions of this
10  * software must be clearly marked as such, and if the derived work is
11  * incompatible with the protocol description in the RFC file, it must be
12  * called by a name other than "ssh" or "Secure Shell".
13  */
14 
15 #include "includes.h"
16 RCSID("$OpenBSD: xmalloc.c,v 1.16 2001/07/23 18:21:46 stevesk Exp $");
17 
18 #pragma ident	"%Z%%M%	%I%	%E% SMI"
19 
20 #include "xmalloc.h"
21 #include "log.h"
22 
23 void *
24 xmalloc(size_t size)
25 {
26 	void *ptr;
27 
28 	if (size == 0)
29 		fatal("xmalloc: zero size");
30 	ptr = malloc(size);
31 	if (ptr == NULL)
32 		fatal("xmalloc: out of memory (allocating %lu bytes)", (u_long) size);
33 	return ptr;
34 }
35 
36 void *
37 xrealloc(void *ptr, size_t new_size)
38 {
39 	void *new_ptr;
40 
41 	if (new_size == 0)
42 		fatal("xrealloc: zero size");
43 	if (ptr == NULL)
44 		new_ptr = malloc(new_size);
45 	else
46 		new_ptr = realloc(ptr, new_size);
47 	if (new_ptr == NULL)
48 		fatal("xrealloc: out of memory (new_size %lu bytes)", (u_long) new_size);
49 	return new_ptr;
50 }
51 
52 void
53 xfree(void *ptr)
54 {
55 	if (ptr == NULL)
56 		fatal("xfree: NULL pointer given as argument");
57 	free(ptr);
58 }
59 
60 char *
61 xstrdup(const char *str)
62 {
63 	size_t len;
64 	char *cp;
65 
66 	len = strlen(str) + 1;
67 	cp = xmalloc(len);
68 	strlcpy(cp, str, len);
69 	return cp;
70 }
71